C#_加密解密

时间:2022-11-01 07:58:11

一、MD5加密解密

1、加密

public static string ToMd5(string clearString)

C#_加密解密

{
C#_加密解密 Byte[] clearBytes = System.Text.Encoding.Unicode.GetBytes(clearString);
C#_加密解密 string hashedPwd = BitConverter.ToString(((HashAlgorithm)CryptoConfig.CreateFromName("MD5")).ComputeHash(clearBytes));
C#_加密解密 return hashedPwd;
C#_加密解密 }

2、32位MD5加密

        public static string GetMd5Base32(string sInput)

C#_加密解密

        {
C#_加密解密 System.Text.ASCIIEncoding encoding = new System.Text.ASCIIEncoding();
C#_加密解密 System.Security.Cryptography.MD5 md5;
C#_加密解密 byte[] bytesSrc;
C#_加密解密 byte[] result;
C#_加密解密 StringBuilder sb = new StringBuilder();
C#_加密解密 bytesSrc = encoding.GetBytes(sInput);
C#_加密解密 md5 = new System.Security.Cryptography.MD5CryptoServiceProvider();
C#_加密解密 result = md5.ComputeHash(bytesSrc);
C#_加密解密 for (int i = 0; i < result.Length; i++)
C#_加密解密 {
C#_加密解密 sb.AppendFormat("{0:x2}", result[i]);
C#_加密解密 }
C#_加密解密 return sb.ToString();
C#_加密解密 }

二、base64算法加密解密

C#_加密解密C#_加密解密
    /// <summary>
C#_加密解密 /// 有关base64编码算法的相关操作
C#_加密解密 /// </summary>
C#_加密解密 public class Base64
C#_加密解密 {
C#_加密解密 public Base64()
C#_加密解密 {
C#_加密解密
C#_加密解密 }
C#_加密解密
C#_加密解密 /// <summary>
C#_加密解密 /// 将字符串使用base64算法加密
C#_加密解密 /// </summary>
C#_加密解密 /// <param name="sourceString">待加密的字符串</param>
C#_加密解密 /// <param name="ens">System.Text.Encoding 对象,如创建中文编码集对象:System.Text.Encoding.GetEncoding(54936)</param>
C#_加密解密 /// <returns>加码后的文本字符串</returns>
C#_加密解密 public static string EncodingForString(string sourceString, System.Text.Encoding ens)
C#_加密解密 {
C#_加密解密 return Convert.ToBase64String(ens.GetBytes(sourceString));
C#_加密解密 }
/// <summary>
C#_加密解密 /// 将字符串使用base64算法加密
C#_加密解密 /// </summary>
C#_加密解密 /// <param name="sourceString">待加密的字符串</param>
C#_加密解密 /// <returns>加码后的文本字符串</returns>
C#_加密解密 public static string EncodingForString(string sourceString)
C#_加密解密 {
C#_加密解密 return EncodingForString(sourceString, System.Text.Encoding.GetEncoding(54936));
C#_加密解密 }
C#_加密解密
C#_加密解密
C#_加密解密 /// <summary>
C#_加密解密 /// 从base64编码的字符串中还原字符串,支持中文
C#_加密解密 /// </summary>
C#_加密解密 /// <param name="base64String">base64加密后的字符串</param>
C#_加密解密 /// <param name="ens">System.Text.Encoding 对象,如创建中文编码集对象:System.Text.Encoding.GetEncoding(54936)</param>
C#_加密解密 /// <returns>还原后的文本字符串</returns>
C#_加密解密 public static string DecodingForString(string base64String, System.Text.Encoding ens)
C#_加密解密 {
C#_加密解密 /**
C#_加密解密 * ***********************************************************
C#_加密解密 *
C#_加密解密 * 从base64String中取得的字节值为字符的机内码(ansi字符编码)
C#_加密解密 * 一般的,用机内码转换为汉字是公式:
C#_加密解密 * (char)(第一字节的二进制值*256+第二字节值)
C#_加密解密 * 而在c#中的char或string由于采用了unicode编码,就不能按照上面的公式计算了
C#_加密解密 * ansi的字节编和unicode编码不兼容
C#_加密解密 * 故利用.net类库提供的编码类实现从ansi编码到unicode代码的转换
C#_加密解密 *
C#_加密解密 * GetEncoding 方法依赖于基础平台支持大部分代码页。但是,对于下列情况提供系统支持:默认编码,即在执行此方法的计算机的区域设置中指定的编码;Little- Endian Unicode (UTF-16LE);Big-Endian Unicode (UTF-16BE);Windows 操作系统 (windows-1252);UTF-7;UTF-8;ASCII 以及 GB18030(简体中文)。
C#_加密解密 *
C#_加密解密 *指定下表 中列出的其中一个名称以获取具有对应代码页的系统支持的编码。
C#_加密解密 *
C#_加密解密 * 代码页 名称
C#_加密解密 * 1200 “UTF-16LE”、“utf-16”、“ucs-2”、“unicode”或“ISO-10646-UCS-2”
C#_加密解密 * 1201 “UTF-16BE”或“unicodeFFFE”
C#_加密解密 * 1252 “windows-1252”
C#_加密解密 * 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”
C#_加密解密 * 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”
C#_加密解密 * 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”
C#_加密解密 * 54936 “GB18030”
C#_加密解密 *
C#_加密解密 * 某些平台可能不支持特定的代码页。例如,Windows 98 的美国版本可能不支持日语 Shift-jis 代码页(代码页 932)。这种情况下,GetEncoding 方法将在执行下面的 C# 代码时引发 NotSupportedException:
C#_加密解密 *
C#_加密解密 * Encoding enc = Encoding.GetEncoding("shift-jis");
C#_加密解密 **************************************************************/
C#_加密解密 // 从base64String中得到原始字符
C#_加密解密 return ens.GetString(Convert.FromBase64String(base64String));
C#_加密解密 }
C#_加密解密
C#_加密解密 /// <summary>
C#_加密解密 /// 从base64编码的字符串中还原字符串,支持中文
C#_加密解密 /// </summary>
C#_加密解密 /// <param name="base64String">base64加密后的字符串</param>
C#_加密解密 /// <returns>还原后的文本字符串</returns>
C#_加密解密 public static string DecodingForString(string base64String)
C#_加密解密 {
C#_加密解密 return DecodingForString(base64String, System.Text.Encoding.GetEncoding(54936));
C#_加密解密 }
C#_加密解密
C#_加密解密
C#_加密解密 //--------------------------------------------------------------------------------------
C#_加密解密
C#_加密解密 /// <summary>
C#_加密解密 /// 对任意类型的文件进行base64加码
C#_加密解密 /// </summary>
C#_加密解密 /// <param name="fileName">文件的路径和文件名</param>
C#_加密解密 /// <returns>对文件进行base64编码后的字符串</returns>
C#_加密解密 public static string EncodingForFile(string fileName)
C#_加密解密 {
C#_加密解密 System.IO.FileStream fs = System.IO.File.OpenRead(fileName);
C#_加密解密 System.IO.BinaryReader br = new System.IO.BinaryReader(fs);
C#_加密解密
C#_加密解密 /*System.Byte[] b=new System.Byte[fs.Length];
C#_加密解密 fs.Read(b,0,Convert.ToInt32(fs.Length));*/
C#_加密解密
C#_加密解密
C#_加密解密 string base64String = Convert.ToBase64String(br.ReadBytes((int)fs.Length));
C#_加密解密
C#_加密解密
C#_加密解密 br.Close();
C#_加密解密 fs.Close();
C#_加密解密 return base64String;
C#_加密解密 }
C#_加密解密
C#_加密解密 /// <summary>
C#_加密解密 /// 把经过base64编码的字符串保存为文件
C#_加密解密 /// </summary>
C#_加密解密 /// <param name="base64String">经base64加码后的字符串</param>
C#_加密解密 /// <param name="fileName">保存文件的路径和文件名</param>
C#_加密解密 /// <returns>保存文件是否成功</returns>
C#_加密解密 public static bool SaveDecodingToFile(string base64String, string fileName)
C#_加密解密 {
C#_加密解密 System.IO.FileStream fs = new System.IO.FileStream(fileName, System.IO.FileMode.Create);
C#_加密解密 System.IO.BinaryWriter bw = new System.IO.BinaryWriter(fs);
C#_加密解密 bw.Write(Convert.FromBase64String(base64String));
C#_加密解密 bw.Close();
C#_加密解密 fs.Close();
C#_加密解密 return true;
C#_加密解密 }
C#_加密解密
C#_加密解密
C#_加密解密 //-------------------------------------------------------------------------------
C#_加密解密
C#_加密解密 /// <summary>
C#_加密解密 /// 从网络地址一取得文件并转化为base64编码
C#_加密解密 /// </summary>
C#_加密解密 /// <param name="url">文件的url地址,一个绝对的url地址</param>
C#_加密解密 /// <param name="objWebClient">System.Net.WebClient 对象</param>
C#_加密解密 /// <returns></returns>
C#_加密解密 public static string EncodingFileFromUrl(string url, System.Net.WebClient objWebClient)
C#_加密解密 {
C#_加密解密 return Convert.ToBase64String(objWebClient.DownloadData(url));
C#_加密解密 }
C#_加密解密
C#_加密解密
C#_加密解密 /// <summary>
C#_加密解密 /// 从网络地址一取得文件并转化为base64编码
C#_加密解密 /// </summary>
C#_加密解密 /// <param name="url">文件的url地址,一个绝对的url地址</param>
C#_加密解密 /// <returns>将文件转化后的base64字符串</returns>
C#_加密解密 public static string EncodingFileFromUrl(string url)
C#_加密解密 {
C#_加密解密 //System.Net.WebClient myWebClient = new System.Net.WebClient();
C#_加密解密 return EncodingFileFromUrl(url, new System.Net.WebClient());
C#_加密解密 }
C#_加密解密 }

三、SHA1加密

private string getSHA(string code)

C#_加密解密

{
C#_加密解密 if (!String.IsNullOrEmpty(code))
C#_加密解密 {
C#_加密解密 return System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(code, "SHA1").ToLower();
C#_加密解密 }
C#_加密解密 else
{
C#_加密解密
C#_加密解密 return string.Empty;
C#_加密解密 }
C#_加密解密}

四、AES加密解密

C#_加密解密C#_加密解密
/// <summary>
C#_加密解密 /// AES加密解密
C#_加密解密 /// </summary>
C#_加密解密 public class AES
C#_加密解密 {
C#_加密解密 /// <summary>
C#_加密解密 /// 获取密钥
C#_加密解密 /// </summary>
C#_加密解密 private static string Key
C#_加密解密 {
C#_加密解密 get { return @")O[NB]6,YF}+efcaj{+oESb9d8>Z'e9M"; }
C#_加密解密 }
C#_加密解密
C#_加密解密 /// <summary>
C#_加密解密 /// 获取向量
C#_加密解密 /// </summary>
C#_加密解密 private static string IV
C#_加密解密 {
C#_加密解密 get { return @"L+/~f4,Ir)b$=pkf"; }
C#_加密解密 }
C#_加密解密
C#_加密解密 /// <summary>
C#_加密解密 /// AES加密
C#_加密解密 /// </summary>
C#_加密解密 /// <param name="plainStr">明文字符串</param>
C#_加密解密 /// <returns>密文</returns>
C#_加密解密 public static string AESEncrypt(string plainStr)
C#_加密解密 {
C#_加密解密 byte[] bKey = Encoding.UTF8.GetBytes(Key);
C#_加密解密 byte[] bIV = Encoding.UTF8.GetBytes(IV);
C#_加密解密 byte[] byteArray = Encoding.UTF8.GetBytes(plainStr);
C#_加密解密
C#_加密解密 string encrypt = null;
C#_加密解密 Rijndael aes = Rijndael.Create();
C#_加密解密 try
C#_加密解密 {
C#_加密解密 using (MemoryStream mStream = new MemoryStream())
C#_加密解密 {
C#_加密解密 using (CryptoStream cStream = new CryptoStream(mStream, aes.CreateEncryptor(bKey, bIV), CryptoStreamMode.Write))
C#_加密解密 {
C#_加密解密 cStream.Write(byteArray, 0, byteArray.Length);
C#_加密解密 cStream.FlushFinalBlock();
C#_加密解密 encrypt = Convert.ToBase64String(mStream.ToArray());
C#_加密解密 }
C#_加密解密 }
C#_加密解密 }
C#_加密解密 catch { }
C#_加密解密 aes.Clear();
C#_加密解密
C#_加密解密 return encrypt;
C#_加密解密 }
C#_加密解密
C#_加密解密 /// <summary>
C#_加密解密 /// AES加密
C#_加密解密 /// </summary>
C#_加密解密 /// <param name="plainStr">明文字符串</param>
C#_加密解密 /// <param name="returnNull">加密失败时是否返回 null,false 返回 String.Empty</param>
C#_加密解密 /// <returns>密文</returns>
C#_加密解密 public static string AESEncrypt(string plainStr, bool returnNull)
C#_加密解密 {
C#_加密解密 string encrypt = AESEncrypt(plainStr);
C#_加密解密 return returnNull ? encrypt : (encrypt == null ? String.Empty : encrypt);
C#_加密解密 }
C#_加密解密
C#_加密解密 /// <summary>
C#_加密解密 /// AES解密
C#_加密解密 /// </summary>
C#_加密解密 /// <param name="encryptStr">密文字符串</param>
C#_加密解密 /// <returns>明文</returns>
C#_加密解密 public static string AESDecrypt(string encryptStr)
C#_加密解密 {
C#_加密解密 byte[] bKey = Encoding.UTF8.GetBytes(Key);
C#_加密解密 byte[] bIV = Encoding.UTF8.GetBytes(IV);
C#_加密解密 byte[] byteArray = Convert.FromBase64String(encryptStr);
C#_加密解密
C#_加密解密 string decrypt = null;
C#_加密解密 Rijndael aes = Rijndael.Create();
C#_加密解密 try
C#_加密解密 {
C#_加密解密 using (MemoryStream mStream = new MemoryStream())
C#_加密解密 {
C#_加密解密 using (CryptoStream cStream = new CryptoStream(mStream, aes.CreateDecryptor(bKey, bIV), CryptoStreamMode.Write))
C#_加密解密 {
C#_加密解密 cStream.Write(byteArray, 0, byteArray.Length);
C#_加密解密 cStream.FlushFinalBlock();
C#_加密解密 decrypt = Encoding.UTF8.GetString(mStream.ToArray());
C#_加密解密 }
C#_加密解密 }
C#_加密解密 }
C#_加密解密 catch { }
C#_加密解密 aes.Clear();
C#_加密解密
C#_加密解密 return decrypt;
C#_加密解密 }
C#_加密解密
C#_加密解密 /// <summary>
C#_加密解密 /// AES解密
C#_加密解密 /// </summary>
C#_加密解密 /// <param name="encryptStr">密文字符串</param>
C#_加密解密 /// <param name="returnNull">解密失败时是否返回 null,false 返回 String.Empty</param>
C#_加密解密 /// <returns>明文</returns>
C#_加密解密 public static string AESDecrypt(string encryptStr, bool returnNull)
C#_加密解密 {
C#_加密解密 string decrypt = AESDecrypt(encryptStr);
C#_加密解密 return returnNull ? decrypt : (decrypt == null ? String.Empty : decrypt);
C#_加密解密 }
C#_加密解密 }
 
 

C#_加密解密的更多相关文章

  1. php使用内置的mcrypt&lowbar;encrypt和mcrypt&lowbar;decrypt进行字符串加密解密

    <?php /*****************************加密*******************************/$key = "miyao";// ...

  2. Go加密解密之RSA&lbrack;转&rsqb;

    安全总是很重要的,各个语言对于通用的加密算法都会有实现.前段时间,用Go实现了RSA和DES的加密解密,在这分享一下.(对于RSA和DES加密算法本身,请查阅相关资料) 在PHP中,很多功能经常是一个 ...

  3. golang AES&sol;ECB&sol;PKCS5 加密解密 url-safe-base64

    因为项目的需要用到golang的一种特殊的加密解密算法AES/ECB/PKCS5,但是算法并没有包含在标准库中,经过多次失败的尝试,终于解码成功,特此分享: /* 描述 : golang AES/EC ...

  4. PHP加密解密类

    <?php class Mypass { static function encrypt($data, $key){ $key = md5($key); $x = 0; $len = strle ...

  5. onethink加密解密函数

    onethink中封装的加密解密函数 <?php /** * 系统加密方法 * @param string $data 要加密的字符串 * @param string $key 加密密钥 * @ ...

  6. password学3——Java BASE64加密解密

    Base64是网络上最常见的用于传输8Bit字节代码的编码方式之中的一个,大家能够查看RFC2045-RFC2049.上面有MIME的具体规范.Base64编码可用于在HTTP环境下传递较长的标识信息 ...

  7. C&num;&sol;IOS&sol;Android通用加密解密方法

    原文:C#/IOS/Android通用加密解密方法 公司在做移动端ios/android,服务器提供接口使用的.net,用到加密解密这一块,也在网上找了一些方法,有些是.net加密了android解密 ...

  8. 在JavaWeb项目中URL中字符串加密解密方案

    URL由来: 一般来说,URL只能使用英文字母.阿拉伯数字和某些标点符号,不能使用其他文字和符号.比如,世界上有英文字母的网址 “http://www.abc.com”,但是没有希腊字母的网址“htt ...

  9. golang实现aes-cbc-256加密解密过程记录

    我为什么吃撑了要实现go的aes-cbc-256加密解密功能? 之前的项目是用php实现的,现在准备用go重构,需要用到这个功能,这么常用的功能上网一搜一大把现成例子,于是基于go现有api分分钟实现 ...

随机推荐

  1. HTML 定时页面跳转

    有 2 种方法可以实现 html 的定时页面跳转,1.meta refresh 实现.2.JavaScript 实现. 1.通过 meta refresh 实现 3 秒后自动跳转到 http://ww ...

  2. 如何启动另一个应用的activity

    1.使用action Intent i=new Intent(); i.setAction(".........."); startActivity(i); 前提条件:要启动的ac ...

  3. xml存储bug

    最近遇到了一个bug,详细情况如下:用linq to xml写xml文件,在加载的时候代码为xDocument.Load(filePath),保存的时候为xDocument.Save(filePath ...

  4. CentOS修改163源(转载)

    From:http://www.linuxidc.com/Linux/2012-08/69043.htm #CentOS-Base.repo其他版本文件在http://mirrors.163.com/ ...

  5. struts2学生信息管理系统篇章①

    最近在看java1234分享的一个Struts2的学生信息管理系统的知识.因为本身java没什么底子.所以就没有什么好的技术去解决问题.一直在百度,不懂就百度.这样子下来其实也能学到一些东西,过阵子等 ...

  6. cf471B MUH and Important Things

    B. MUH and Important Things time limit per test 1 second memory limit per test 256 megabytes input s ...

  7. OO&lowbar;BLOG2&lowbar;多线程电梯模拟

    作业2-1 单部多线程傻瓜调度(FAFS)电梯的模拟 I. 基于度量的程序结构分析 1)程序结构与基本度量统计图 2)分析 ​ 这次作业基本奠定了本人三次电梯作业的基本架构,简述如下: Elevato ...

  8. JS控制语句(if、for等)、数组(例题)、方法(常用方法介绍)

    控制语句 If if (1>2){ alert() } var a= parseInt(prompt('请输入数字')); if (isNaN(a)) { alert("输入的不是数字 ...

  9. 如何引入iconfont图标与Element-UI组件

    一.iconfont图标 iconfont方便又好用,介绍一下如何在vue项目中引入iconfont 1.进入iconfont官网 www.iconfont.cn 2.登录自己账户 3.选择图标后下载 ...

  10. 51Nod 算法马拉松28 C题 栈 单调队列

    欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - 51Nod1952 题意概括 有一个栈,有3种操作: Ο 从栈顶加入一个元素 Ο 从栈底加入一个元素 Ο 从栈 ...