1.方法一:

[c-sharp] view plaincopy

  1. //适用于C#语言
  2. //使用前需导入以下命名空间:using System.Web.Security;
  3. //第一个参数为需加密的字符串,第二个参数为加密的格式(只有SHA1和MD5两种,可任选一种)
  4. public string EncryptPassword(string PasswordString, string PasswordFormat)
  5. {
  6. string EncryptPassword = null;
  7. if ("SHA1".Equals(PasswordFormat))
  8. {
  9. EncryptPassword = FormsAuthentication.HashPasswordForStoringInConfigFile(PasswordString, "SHA1");
  10. }
  11. else if ("MD5".Equals(PasswordFormat))
  12. {
  13. EncryptPassword = FormsAuthentication.HashPasswordForStoringInConfigFile(PasswordString, "MD5");
  14. }
  15. else
  16. {
  17. EncryptPassword = PasswordString;
  18. }
  19. return EncryptPassword;
  20. }
  21. //======================加密解密方法=====================
  22. using System;
  23. using System.Security.Cryptography;
  24. using System.IO;
  25. using System.Text;/**//// <summary>
  26. /// DEC 加密过程
  27. /// </summary>
  28. /// <param name="pToEncrypt">被加密的字符串</param>
  29. /// <param name="sKey">密钥(只支持8个字节的密钥)</param>
  30. /// <returns>加密后的字符串</returns>
  31. public string Encrypt(string pToEncrypt, string sKey)
  32. ...{
  33. //访问数据加密标准(DES)算法的加密服务提供程序 (CSP) 版本的包装对象
  34. DESCryptoServiceProvider des = new DESCryptoServiceProvider(); 
  35. des.Key = ASCIIEncoding.ASCII.GetBytes(sKey); //建立加密对象的密钥和偏移量
  36. des.IV = ASCIIEncoding.ASCII.GetBytes(sKey);  //原文使用ASCIIEncoding.ASCII方法的GetBytes方法
  37. byte[] inputByteArray = Encoding.Default.GetBytes(pToEncrypt);//把字符串放到byte数组中
  38. MemoryStream ms = new MemoryStream();//创建其支持存储区为内存的流 
  39. //定义将数据流链接到加密转换的流
  40. CryptoStream cs = new CryptoStream(ms, des.CreateEncryptor(), CryptoStreamMode.Write);
  41. cs.Write(inputByteArray, 0, inputByteArray.Length);
  42. cs.FlushFinalBlock();
  43. //上面已经完成了把加密后的结果放到内存中去
  44. StringBuilder ret = new StringBuilder();
  45. foreach (byte b in ms.ToArray())
  46. ...{
  47. ret.AppendFormat("{0:X2}", b);
  48. }
  49. ret.ToString();
  50. return ret.ToString();
  51. }
  52. /**//**//**//// <summary>
  53. /// DEC 解密过程
  54. /// </summary>
  55. /// <param name="pToDecrypt">被解密的字符串</param>
  56. /// <param name="sKey">密钥(只支持8个字节的密钥,同前面的加密密钥相同)</param>
  57. /// <returns>返回被解密的字符串</returns>
  58. public string Decrypt(string pToDecrypt, string sKey)
  59. ...{
  60. DESCryptoServiceProvider des = new DESCryptoServiceProvider();
  61. byte[] inputByteArray = new byte[pToDecrypt.Length / 2];
  62. for (int x = 0; x < pToDecrypt.Length / 2; x++)
  63. ...{
  64. int i = (Convert.ToInt32(pToDecrypt.Substring(x * 2, 2), 16));
  65. inputByteArray[x] = (byte)i;
  66. }
  67. des.Key = ASCIIEncoding.ASCII.GetBytes(sKey); //建立加密对象的密钥和偏移量,此值重要,不能修改
  68. des.IV = ASCIIEncoding.ASCII.GetBytes(sKey);
  69. MemoryStream ms = new MemoryStream();
  70. CryptoStream cs = new CryptoStream(ms, des.CreateDecryptor(), CryptoStreamMode.Write);
  71. cs.Write(inputByteArray, 0, inputByteArray.Length);
  72. cs.FlushFinalBlock();
  73. //建立StringBuild对象,createDecrypt使用的是流对象,必须把解密后的文本变成流对象
  74. StringBuilder ret = new StringBuilder(); 
  75. return System.Text.Encoding.Default.GetString(ms.ToArray());
  76. }

具体在程序中使用加密解密算法的例子如下: 在发送页面 Response.Redirect("~/GridView.aspx?ID=" + Encrypt("zlh","abcdefgh"));

在接受页面 string acceptStr; acceptStr = Decrypt(Request.QueryString["ID"],"abcdefgh");

转贴来源:http://hi.baidu.com/4092887/blog/item/4dfd89efaf805ee5cf1b3e5a.html

2.方法二:(简单)

FormsAuthentication.HashPasswordForStoringInConfigFile(string, "SHA1");

FormsAuthentication.HashPasswordForStoringInConfigFile(String, "MD5");

C# 哈希加密的更多相关文章

  1. 哈希加密算法 MD5,SHA-1,SHA-2,SHA-256,SHA-512,SHA-3,RIPEMD-160 - aTool

    一.MD5哈希加密算法 atool.org MD5即Message-Digest Algorithm 5(信息-摘要算法 5),用于确保信息传输完整一致.是计算机广泛使用的散列算法之一(又译摘要算法. ...

  2. MySQL数据库中的哈希加密

    数据库安全是数据库中最为重要的环节,只有确保了数据库中数据的安全,才能够更好的发挥数据库的功能,本文将为大家介绍一种很好的数据库加密方法,即哈希加密. 导读:MySQL数据库加密的方法有很多种,不同的 ...

  3. 微信小程序 HMACSHA256 哈希加密

    下载CryptoJS, 增加红色的这句 module.exports = CryptoJS /* CryptoJS code.google.com/p/crypto-js (c) 2009-2012 ...

  4. 转载:哈希加密算法 MD5,SHA-1,SHA-2,SHA-256,SHA-512,SHA-3,RIPEMD-160 - aTool

    http://www.atool.org/hash.php 一.MD5哈希加密算法 MD5即Message-Digest Algorithm 5(信息-摘要算法 5),用于确保信息传输完整一致.是计算 ...

  5. spring security使用哈希加密的密码

    之前我们都是使用MD5 Md5PasswordEncoder 或者SHA ShaPasswordEncoder 的哈希算法进行密码加密,在spring security中依然使用只要指定使用自定义加密 ...

  6. MD5,SHA1及SHA256等哈希加密方法实现:Java,C#,Golang,Python

    哈希算法又称散列算法,它可以从任何数据中快速的创建一个凭证,而这个凭证很难被推倒出来,因为一丁点的变化会导致凭证的差别恨到,也就是说哈希算法具有不可逆性,因此它在密码数据校验方面用的很广,比如我们常用 ...

  7. Flask_generate_password_hash的加盐哈希加密算法与check_password_hash的校验

    密码加密简介 密码存储的主要形式: 明文存储:肉眼就可以识别,没有任何安全性. 加密存储:通过一定的变换形式,使得密码原文不易被识别. 密码加密的几类方式: 明文转码加密算法:BASE64, 7BIT ...

  8. .NET下的加密解密大全(1): 哈希加密

    .NET有丰富的加密解密API库供我们使用,本博文总结了.NET下的Hash散列算法,并制作成简单的DEMO,希望能对大家有所帮助. MD5[csharp]using System; using Sy ...

  9. Md5加密秘钥加密哈希加密

    加密通用类: public class EncryptClass { /// <summary> /// 返回MD5加密字符串 /// </summary> /// <p ...

随机推荐

  1. "高级"数据库小结

    刚刚考完高级数据库,这里有多高级等后面考完组合数学和算法再细聊.试卷在往年基础上改进了部分题目(貌似有人知道新题目的来源,如查询优化树),也可能是两份试卷交叉年份考.总之会的还是会,没看过的当然不会只 ...

  2. Spark性能优化(1)——序列化、内存、并行度、数据存储格式、Shuffle

    序列化 背景: 在以下过程中,需要对数据进行序列化: shuffling data时需要通过网络传输数据 RDD序列化到磁盘时 性能优化点: Spark默认的序列化类型是Java序列化.Java序列化 ...

  3. 有趣的switch应用(填入种类,显示响应的价格)

    <!doctype html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  4. 一些有用的Sql语句

    1.插入数据后,返回插入的Id ')

  5. Navicat Premium 链接 ORACLE

    http://www.oracle.com/technetwork/database/features/instant-client/index-097480.html 下载地址 Navicat Pr ...

  6. druid使用

    https://blog.csdn.net/weinichendian/article/details/78503469

  7. 百度编辑器UEditor不能插入音频视频的解决方法

    引用:https://my.oschina.net/u/379795/blog/787985 xssFilter导致插入视频异常,编辑器在切换源码的过程中过滤掉img的_url属性(用来存储视频url ...

  8. 推荐一款编辑SQL的工具:jsqlparser

    这个工具真的挺好用的,采用的是观察者模式,Visitor. 虽然我学过这个模式,但是乍一用还是有点懵逼的. 给好一个SQL语句之后,jsqlparser可以把这个sql语句给分解成all kind o ...

  9. eclipse中maven打包

    第一种方式:将依赖包打包进一个jar包中. <build> <plugins> <plugin> <artifactId>maven-compiler- ...

  10. umount 强制卸载

    umount -lf /mnt  强制卸载文件 -f     Force unmount (in case of an unreachable NFS system).  (Requires kern ...