关于C# 的高效随机字符串
2003-06-13 11:23
549 查看
使用RNGCryptoServiceProvider 做种,可以在一秒内产生的随机数重复率非常的低,对于以往使用时间做种的方法是个升级,代码如下:
using System;
using System.Security.Cryptography;
namespace ArLi.CommonPrj
{
/// <summary>
/// 随机密码
/// </summary>
public sealed class RandomStr {
public const string myVersion = "1.2";
/********
* Const and Function
* ********/
private static readonly int defaultLength = 8;
private static int GetNewSeed(){
byte[] rndBytes = new byte[4];
RNGCryptoServiceProvider rng = new RNGCryptoServiceProvider();
rng.GetBytes(rndBytes);
return BitConverter.ToInt32(rndBytes,0);
}
/********
* getRndCode of all char .
* ********/
private static string BuildRndCodeAll(int strLen) {
System.Random RandomObj = new System.Random(GetNewSeed());
string buildRndCodeReturn = null;
for(int i=0; i<strLen; i++) {
buildRndCodeReturn += (char)RandomObj.Next(33,125);
}
return buildRndCodeReturn;
}
public static string GetRndStrOfAll() {
return BuildRndCodeAll(defaultLength);
}
public static string GetRndStrOfAll(int LenOf) {
return BuildRndCodeAll(LenOf);
}
/********
* getRndCode of only .
* ********/
private static string sCharLow = "abcdefghijklmnopqrstuvwxyz";
private static string sCharUpp = "ABCDEFGHIJKLMNOPQRSTUVWXYZ";
private static string sNumber = "0123456789";
private static string BuildRndCodeOnly(string StrOf,int strLen) {
System.Random RandomObj = new System.Random(GetNewSeed());
string buildRndCodeReturn = null;
for(int i=0; i<strLen; i++) {
buildRndCodeReturn += StrOf.Substring(RandomObj.Next(0,StrOf.Length-1),1);
}
return buildRndCodeReturn;
}
public static string GetRndStrOnlyFor() {
return BuildRndCodeOnly(sCharLow + sNumber,defaultLength);
}
public static string GetRndStrOnlyFor(int LenOf) {
return BuildRndCodeOnly(sCharLow + sNumber,LenOf);
}
public static string GetRndStrOnlyFor(bool bUseUpper,bool bUseNumber) {
string strTmp = sCharLow;
if (bUseUpper) strTmp += sCharUpp;
if (bUseNumber) strTmp += sNumber;
return BuildRndCodeOnly(strTmp,defaultLength);
}
public static string GetRndStrOnlyFor(int LenOf,bool bUseUpper,bool bUseNumber) {
string strTmp = sCharLow;
if (bUseUpper) strTmp += sCharUpp;
if (bUseNumber) strTmp += sNumber;
return BuildRndCodeOnly(strTmp,LenOf);
}
}
}
using System;
using System.Security.Cryptography;
namespace ArLi.CommonPrj
{
/// <summary>
/// 随机密码
/// </summary>
public sealed class RandomStr {
public const string myVersion = "1.2";
/********
* Const and Function
* ********/
private static readonly int defaultLength = 8;
private static int GetNewSeed(){
byte[] rndBytes = new byte[4];
RNGCryptoServiceProvider rng = new RNGCryptoServiceProvider();
rng.GetBytes(rndBytes);
return BitConverter.ToInt32(rndBytes,0);
}
/********
* getRndCode of all char .
* ********/
private static string BuildRndCodeAll(int strLen) {
System.Random RandomObj = new System.Random(GetNewSeed());
string buildRndCodeReturn = null;
for(int i=0; i<strLen; i++) {
buildRndCodeReturn += (char)RandomObj.Next(33,125);
}
return buildRndCodeReturn;
}
public static string GetRndStrOfAll() {
return BuildRndCodeAll(defaultLength);
}
public static string GetRndStrOfAll(int LenOf) {
return BuildRndCodeAll(LenOf);
}
/********
* getRndCode of only .
* ********/
private static string sCharLow = "abcdefghijklmnopqrstuvwxyz";
private static string sCharUpp = "ABCDEFGHIJKLMNOPQRSTUVWXYZ";
private static string sNumber = "0123456789";
private static string BuildRndCodeOnly(string StrOf,int strLen) {
System.Random RandomObj = new System.Random(GetNewSeed());
string buildRndCodeReturn = null;
for(int i=0; i<strLen; i++) {
buildRndCodeReturn += StrOf.Substring(RandomObj.Next(0,StrOf.Length-1),1);
}
return buildRndCodeReturn;
}
public static string GetRndStrOnlyFor() {
return BuildRndCodeOnly(sCharLow + sNumber,defaultLength);
}
public static string GetRndStrOnlyFor(int LenOf) {
return BuildRndCodeOnly(sCharLow + sNumber,LenOf);
}
public static string GetRndStrOnlyFor(bool bUseUpper,bool bUseNumber) {
string strTmp = sCharLow;
if (bUseUpper) strTmp += sCharUpp;
if (bUseNumber) strTmp += sNumber;
return BuildRndCodeOnly(strTmp,defaultLength);
}
public static string GetRndStrOnlyFor(int LenOf,bool bUseUpper,bool bUseNumber) {
string strTmp = sCharLow;
if (bUseUpper) strTmp += sCharUpp;
if (bUseNumber) strTmp += sNumber;
return BuildRndCodeOnly(strTmp,LenOf);
}
}
}
相关文章推荐
- 关于C# 的高效随机字符串
- 关于unity c#脚本中将string字符串进行分割
- c# 生成指定位数的随机字符串
- C#生成随机字符串
- c#中关于字符串的一些函数
- C# 关于字符、字符串和文本处理
- C#实现方便又高效的字符串拼接类StringJoiner
- C# 产生随机字符串!
- C#生成随机字符串的实例
- 关于c# byte[]型数组转换成字符串
- C#生成随机字符串(数字,字母,特殊符号)
- C#随机生成中文字符串
- C# 生成不重复随机字符串 (1秒内生成1000000个)
- C# 随机生成中文字符串
- C#关于使用正则表达式解析字符串
- C#生成随机字符串
- C#中关于字符串和类型转换的一些注意点
- 关于C#截取字符串问题!
- asp.net学习笔记——关于字符串的一些(c#)
- 详解关于 C# 中 Linq 随机排序的有效解决方法