ASP.NET常用加密解密方法

一、MD5加密解密

 

1、加密

 
C# 代码    复制
public static string ToMd5(string clearString) { Byte[] clearBytes = System.Text.Encoding.Unicode.GetBytes(clearString); string hashedPwd = BitConverter.ToString(((HashAlgorithm)CryptoConfig.CreateFromName("MD5")).ComputeHash(clearBytes)); return hashedPwd; } 

 

2、32位MD5加密

 
C# 代码    复制
public static string GetMd5Base32(string sInput) { System.Text.ASCIIEncoding encoding = new System.Text.ASCIIEncoding(); System.Security.Cryptography.MD5 md5; byte[] bytesSrc; byte[] result; StringBuilder sb = new StringBuilder(); bytesSrc = encoding.GetBytes(sInput); md5 = new System.Security.Cryptography.MD5CryptoServiceProvider(); result = md5.ComputeHash(bytesSrc); for (int i = 0; i < result.Length; i++) { sb.AppendFormat("{0:x2}", result[i]); } return sb.ToString(); } 

 

 

二、DES加密解密

 

1、加密

 
C# 代码    复制
DESEncrypt DES加密

 

2、解密

 
C# 代码    复制
DESDecrypt DES解密

 

三、base64算法加密解密

 
 
C# 代码    复制
/// <summary> /// 有关base64编码算法的相关操作 /// </summary>  public class Base64 { public Base64() { } /// <summary> /// 将字符串使用base64算法加密 /// </summary> /// <param name="sourceString">待加密的字符串</param> /// <param name="ens">System.Text.Encoding 对象,如创建中文编码集对象:System.Text.Encoding.GetEncoding(54936)</param> /// <returns>加码后的文本字符串</returns>  public static string EncodingForString(string sourceString, System.Text.Encoding ens) { return Convert.ToBase64String(ens.GetBytes(sourceString)); } /// <summary> /// 将字符串使用base64算法加密 /// </summary> /// <param name="sourceString">待加密的字符串</param> /// <returns>加码后的文本字符串</returns>  public static string EncodingForString(string sourceString) { return EncodingForString(sourceString, System.Text.Encoding.GetEncoding(54936)); } /// <summary> /// 从base64编码的字符串中还原字符串,支持中文 /// </summary> /// <param name="base64String">base64加密后的字符串</param> /// <param name="ens">System.Text.Encoding 对象,如创建中文编码集对象:System.Text.Encoding.GetEncoding(54936)</param> /// <returns>还原后的文本字符串</returns>  public static string DecodingForString(string base64String, System.Text.Encoding ens) { /** * *********************************************************** * * 从base64String中取得的字节值为字符的机内码(ansi字符编码) * 一般的,用机内码转换为汉字是公式: * (char)(第一字节的二进制值*256+第二字节值) * 而在c#中的char或string由于采用了unicode编码,就不能按照上面的公式计算了 * ansi的字节编和unicode编码不兼容 * 故利用.net类库提供的编码类实现从ansi编码到unicode代码的转换 * * GetEncoding 方法依赖于基础平台支持大部分代码页。但是,对于下列情况提供系统支持:默认编码,即在执行此方法的计算机的区域设置中指定的编码;Little- Endian Unicode (UTF-16LE);Big-Endian Unicode (UTF-16BE);Windows 操作系统 (windows-1252);UTF-7;UTF-8;ASCII 以及 GB18030(简体中文)。 * *指定下表 中列出的其中一个名称以获取具有对应代码页的系统支持的编码。 * * 代码页 名称 * 1200 “UTF-16LE”、“utf-16”、“ucs-2”、“unicode”或“ISO-10646-UCS-2” * 1201 “UTF-16BE”或“unicodeFFFE” * 1252 “windows-1252” * 65000 “utf-7”、“csUnicode11UTF7”、“unicode-1-1-utf-7”、“unicode-2-0-utf-7”、“x- unicode-1-1-utf-7”或“x-unicode-2-0-utf-7” * 65001 “utf-8”、“unicode-1-1-utf-8”、“unicode-2-0-utf-8”、“x-unicode-1-1-utf-8”或 “x-unicode-2-0-utf-8” * 20127 “us-ascii”、“us”、“ascii”、“ANSI_X3.4-1968”、“ANSI_X3.4-1986”、“cp367”、 “csASCII”、“IBM367”、“iso-ir-6”、“ISO646-US”或“ISO_646.irv:1991” * 54936 “GB18030” * * 某些平台可能不支持特定的代码页。例如,Windows 98 的美国版本可能不支持日语 Shift-jis 代码页(代码页 932)。这种情况下,GetEncoding 方法将在执行下面的 C# 代码时引发 NotSupportedException: * * Encoding enc = Encoding.GetEncoding("shift-jis"); **************************************************************/ // 从base64String中得到原始字符  return ens.GetString(Convert.FromBase64String(base64String)); } /// <summary> /// 从base64编码的字符串中还原字符串,支持中文 /// </summary> /// <param name="base64String">base64加密后的字符串</param> /// <returns>还原后的文本字符串</returns>  public static string DecodingForString(string base64String) { return DecodingForString(base64String, System.Text.Encoding.GetEncoding(54936)); } //--------------------------------------------------------------------------------------  /// <summary> /// 对任意类型的文件进行base64加码 /// </summary> /// <param name="fileName">文件的路径和文件名</param> /// <returns>对文件进行base64编码后的字符串</returns>  public static string EncodingForFile(string fileName) { System.IO.FileStream fs = System.IO.File.OpenRead(fileName); System.IO.BinaryReader br = new System.IO.BinaryReader(fs); /*System.Byte[] b=new System.Byte[fs.Length]; fs.Read(b,0,Convert.ToInt32(fs.Length));*/ 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
自己写的简单DES加密加密 public partial class _Default : System.Web.UI.Page { private static byte[] Key64 = { 42, 16, 93, 156, 78, 4, 218, 32 }; private static byte[] IV64 = { 55, 103, 246, 79, 36, 99, 167, 3 }; protected void Page_Load(object sender, EventArgs e) { } protected void Button1_Click(object sender, EventArgs e) { string p = Server.MapPath("~/wcn/"); int i; FileStream fin = new FileStream(p+TextBox1.Text, FileMode.Open, FileAccess.Read); FileStream fout = new FileStream(p+TextBox2.Text, FileMode.OpenOrCreate, FileAccess.Write); FileStream skey = new FileStream(p + "key.txt", FileMode.OpenOrCreate, FileAccess.ReadWrite); FileStream siv = new FileStream(p + "key.txt", FileMode.OpenOrCreate, FileAccess.ReadWrite); fout.SetLength(0); byte[] bin = new byte[100]; long rdlen = 0; long totlen = fin.Length; int len; DES des = new DESCryptoServiceProvider(); des.Key = Key64; des.IV = IV64; TextBox3.Text = des.Key[0].ToString(); StreamWriter w = new StreamWriter(skey); w.Write(des.Key[0]); w.Flush(); for (i = 0; i < 8; i++) { TextBox3.Text = TextBox3.Text + "," + des.Key[i].ToString(); //StreamWriter w = new StreamWriter(skey); w.Write(","+des.Key[i]); w.Flush(); } CryptoStream encStream = new CryptoStream(fout, des.CreateEncryptor(), CryptoStreamMode.Write); while (rdlen < totlen) { len = fin.Read(bin, 0, 100); encStream.Write(bin, 0, len); rdlen = rdlen + len; } encStream.Close(); fout.Close(); fin.Close(); } protected void Button3_Click(object sender, EventArgs e) { string p = Server.MapPath("~/wcn/"); FileStream fin = new FileStream(p + TextBox4.Text, FileMode.Open, FileAccess.Read); FileStream fout = new FileStream(p + TextBox5.Text, FileMode.OpenOrCreate, FileAccess.Write); fout.SetLength(0); byte[] bin = new byte[100]; long rdlen = 0; long totlen = fin.Length; int len; DES des = new DESCryptoServiceProvider(); des.Key = Key64; des.IV = IV64; CryptoStream decStream = new CryptoStream(fout, des.CreateDecryptor(), CryptoStreamMode.Write); while (rdlen < totlen) { len = fin.Read(bin, 0, 100); decStream.Write(bin, 0, len); rdlen = rdlen + len; } decStream.Close(); fout.Close(); fin.Close(); } }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值