Случайно сгенерированное шестнадцатеричное число в C#

StackOverflow https://stackoverflow.com/questions/1054076

  •  20-08-2019
  •  | 
  •  

Вопрос

Как я могу сгенерировать случайное шестнадцатеричное число выбранной мной длины с помощью 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() статическим, как предлагали другие авторы.

Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top