1.MD5加密算法(Unicode)编码适用
public static string EncryptMD5(string oldData)
{
//对字节序列进行编码
Byte[] clearBytes = new UnicodeEncoding().GetBytes(oldData);
//计算哈希值字节数组
Byte[] hashedBytes = ((HashAlgorithm)CryptoConfig.CreateFromName("MD5")).ComputeHash(clearBytes);
//返回字符串加密密文
return BitConverter.ToString(hashedBytes);
}
2.MD5加密算法(UTF8编码,推荐使用)
public static string MD5(string s)
{
var md5 = new System.Security.Cryptography.MD5CryptoServiceProvider();
var result = BitConverter.ToString(md5.ComputeHash(UnicodeEncoding.UTF8.GetBytes(s.Trim())));
return result;
}
3.SHA1哈希加密
public static string EncryptSHA1(string oldData)
{
//生成哈希码
string sha1EncryptString = FormsAuthentication.HashPasswordForStoringInConfigFile(oldData, "SHA1");
return sha1EncryptString;
}
4.RC4算法(初始化和伪随机子密码算法)
public static string Rc4EncryptMethod(string DataString)
{
string EncodeKeyString = "wsiosviolet";
int[] intArray = new int[256];
char[] charArray = new char[256];
int int_j = 0;
int int_i = 0;
for (int i = 0; i < 256; i++)
{
intArray[i] = i;
}
int_j = 1;
for (short i = 0; i < 256; i++)
{
char c = EncodeKeyString.ToCharArray()[i % EncodeKeyString.Length];
charArray[i] = c;
}
int_j = 0;
for (int i = 0; i < 255; i++)
{
int _int_a = intArray[i];
char _char_a = charArray[i];
int_j = (int_j + _int_a + _char_a) % 256;
int _int_tmp = intArray[i];
intArray[i] = intArray[int_j];
intArray[int_j] = _int_tmp;
}
int_j = 0;
int_i = 0;
string value = DataString;
for (short x = 0; x < DataString.Length; x++)
{
int_i = (int_i + 1) % 256;
int _int_is = intArray[int_i];
int_j = (int_j + _int_is) % 256;
int _int_is_i = intArray[int_i];
int _int_is_j = intArray[int_j];
int _int_t = (_int_is_i + _int_is_j) % 256;
int _int_iY = intArray[_int_t];
char _char_c = DataString.ToCharArray()[x];
char _char_y = (char)(_char_c ^ _int_iY);
char[] _char_list = value.ToCharArray();
_char_list[x] = _char_y;
String _str = System.Text.Encoding.Unicode.GetString(System.Text.Encoding.Unicode.GetBytes(_char_list));
value = _str;
}
return value;
}