C#中随机生成的十六进制数

Posted

技术标签:

【中文标题】C#中随机生成的十六进制数【英文标题】:Randomly generated hexadecimal number in C# 【发布时间】:2010-11-06 10:43:15 【问题描述】:

如何使用 C# 生成具有我选择的长度的随机十六进制数?

【问题讨论】:

【参考方案1】:
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");

【讨论】:

【参考方案2】:
    Random random = new Random();
    int num = random.Next();
    string hexString = num.ToString("X");

random.Next() 接受允许您指定最小值和最大值的参数,这就是您控制长度的方式。

【讨论】:

只有当length <= 8 as int.MaxValue 适合 8 个十六进制数字时才会起作用。 如果他确实希望十六进制字符串具有他选择的长度,您将需要计算十六进制长度为“x”的最小数字和长度为“x”的最大值的代码。跨度> 是的。我故意省略了它,但您基本上只需要在 0xF 上进行转换? ('怪不得我的正则表达式)找到任何与你想要的长度匹配的整数。 int num = random.Next(1000, 5000); - 你可以设置任意数量的 Range random.Next(1000, 5000); 这里随机数生成在 1000 到 5000 之间【参考方案3】:

取决于你想要的随机性,但这里有 3 种选择: 1)我通常只使用 Guid.NewGuid 并选择其中的一部分(取决于我想要多少)。

2) System.Random(请参阅其他回复)如果您只想要“足够随机”就很好。

3) System.Security.Cryptography.RNGCryptoServiceProvider

【讨论】:

切片 GUID 对我来说似乎是个坏主意。它们只是整体上独一无二的。 GUID 的许多位肯定不符合随机条件。 @spender 是正确的,例如许多 GUID 包含生成它们的 PC 的 MAC 地址。 呃,不,基于 mac 地址的 guid 早在 2000 年就被淘汰了,因为它们被认为是潜在的安全问题。 GUID 现在由随机数生成器生成(122 位随机,6 位非随机)。无论哪种方式,使用 32 位(或更多)位的 guid 切片都会提供比 System.Random 更多的随机数。那就是 - 除非您调用 UuidCreateSequential ,这是为了向后兼容而添加的,以防有人想要旧式 guid,但这是另一回事。 是的。请参阅 msdn.microsoft.com/en-us/library/system.random.aspx 的 System.Random 文档【参考方案4】:

这是一个返回 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;

【讨论】:

按顺序调用多次随机十六进制字符串将不唯一。【参考方案5】:

.... 使用 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")));

【讨论】:

【参考方案6】:

如果您希望它是加密安全的,您应该使用 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")));

【讨论】:

【参考方案7】:

创建一个 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);

显然,如果您的应用程序不需要奇数个十六进制字符或不是 4 个字符的倍数的 Base64,您可以省略 .Substring(0,n)。

按照其他发帖人的建议,随意通过将 Random() 设为静态来扩展示例。

【讨论】:

【参考方案8】:

我需要类似于 Python 的 secrets.token_hex 函数的东西。

如果您需要加密安全的随机字节,您可以在 System.Security.Cryptography 命名空间中使用 RNGCryptoServiceProvider,如下所示:

using var csprng = new RNGCryptoServiceProvider();
var bytes = new byte[16];

csprng.GetNonZeroBytes(bytes); // or csprng.GetBytes(…)

要将字节数组转换为十六进制字符串,使用 LINQ 似乎是最易读的选项:

string.Join("", bytes.Select(b => b.ToString("x2"))); // or "X2" for upper case

输出可能如下所示:

7fb70c709a5eed32d37ed5771f09c0fe

【讨论】:

以上是关于C#中随机生成的十六进制数的主要内容,如果未能解决你的问题,请参考以下文章

c语言 随机生成一个32位的16进制数的代码

如何在R中生成随机的64位十六进制数?

在两个十进制数之间生成一个随机数[重复]

js生成十六进制随机数(验证码)

在 C# 中将十进制数转换为双精度数会产生差异

在 C# 中格式化十进制数