Случайно сгенерированное шестнадцатеричное число в C#
Вопрос
Как я могу сгенерировать случайное шестнадцатеричное число выбранной мной длины с помощью C#?
Решение
static Random random = new Random();
public static string GetRandomHexNumber(int digits)
{
byte[] buffer = new byte[digits / 2];
random.NextBytes(buffer);
string result = String.Concat(buffer.Select(x => x.ToString("X2")).ToArray());
if (digits % 2 == 0)
return result;
return result + random.Next(16).ToString("X");
}
Другие советы
Random random = new Random();
int num = random.Next();
string hexString = num.ToString("X");
Случайный.Next() принимает аргументы, которые позволяют вам указать минимальное и максимальное значение, так что именно так вы будете контролировать длину.
Зависит от того, насколько случайным вы этого хотите, но вот 3 альтернативы:1) Обычно я просто использую Guid.NewGuid и выбираю его часть (dep.от того, какое большое количество я хочу).
2) System.Random (см. другие ответы) хорош, если вы просто хотите «достаточно случайно».
3) System.Security.Cryptography.RNGCryptoServiceProvider
Вот тот, который возвращает 256-битную шестнадцатеричную строку (8x8=256):
private static string RandomHexString()
{
// 64 character precision or 256-bits
Random rdm = new Random();
string hexValue = string.Empty;
int num;
for (int i = 0; i < 8; i++)
{
num = rdm.Next(0, int.MaxValue);
hexValue += num.ToString("X8");
}
return hexValue;
}
....с LINQ
private static readonly Random _RND = new Random();
public static string GenerateHexString(int digits) {
return string.Concat(Enumerable.Range(0, digits).Select(_ => _RND.Next(16).ToString("X")));
}
Если вы хотите, чтобы он был криптографически безопасным, вам следует использовать RNGCryptoServiceProvider.
public static string BuildSecureHexString(int hexCharacters)
{
var byteArray = new byte[(int)Math.Ceiling(hexCharacters / 2.0)];
using (var rng = new RNGCryptoServiceProvider())
{
rng.GetBytes(byteArray);
}
return String.Concat(Array.ConvertAll(byteArray, x => x.ToString("X2")));
}
Создайте n символов (~n/2 байт), случайную шестнадцатеричную строку:
var randBytes = new byte[n/2 + n%2>0?1:0];
new Random().NextBytes(randBytes);
var hex = BitConverter.ToString(randBytes).Replace("-", string.Empty).Substring(0,n);
Вы рассматривали строки Base64?В зависимости от вашего приложения они часто могут быть более полезными.Они гарантированно будут ASCII и содержат примерно 4/3 символа на входной байт.Чтобы создать строку символов n:
var randBytes = new byte[(n/4 + n%4>0?1:0)*3];
new Random().NextBytes(randBytes);
var base64 = Convert.ToBase64String(randBytes).Substring(0,n);
Очевидно, вы можете опустить .Substring(0,n), если вашему приложению не требуется ни нечетное количество шестнадцатеричных символов, ни Base64, не кратное 4 символам.
Не стесняйтесь расширять примеры, делая Random() статическим, как предлагали другие авторы.