zoukankan      html  css  js  c++  java
  • C# 标准的MD5加密32位

    标准的MD5加密32位小写的:

        public static string GetMD5(string myString)
            {
                MD5 md5 = new MD5CryptoServiceProvider();
                //byte[] fromData = System.Text.Encoding.Unicode.GetBytes(myString);
                byte[] fromData = System.Text.Encoding.UTF8.GetBytes(myString);//
                byte[] targetData = md5.ComputeHash(fromData);
                string byte2String = null;
    
                for (int i = 0; i < targetData.Length; i++)
                {
                    byte2String += targetData[i].ToString("x");
                }
    
                return byte2String;
            }

     如果用上面这个标准的会有一个问题,就是丢失位数,所以字节转换成字符串的时候要保证是2位宽度啊,某个字节为0转换成字符串的时候必须是00的,否则就会丢失位数啊。不仅是0,1~9也一样。

    用以下代码就可以避免:

      public static string GetMD5(string myString)
            {
                MD5 md5 = new MD5CryptoServiceProvider();
                //byte[] fromData = System.Text.Encoding.Unicode.GetBytes(myString);
                byte[] fromData = System.Text.Encoding.UTF8.GetBytes(myString);//
                byte[] targetData = md5.ComputeHash(fromData);
                string byte2String = null;
    
                for (int i = 0; i < targetData.Length; i++)
                {
                    //这个是很常见的错误,你字节转换成字符串的时候要保证是2位宽度啊,某个字节为0转换成字符串的时候必须是00的,否则就会丢失位数啊。不仅是0,1~9也一样。
                    //byte2String += targetData[i].ToString("x");//这个会丢失
                    byte2String = byte2String+ targetData[i].ToString("x2");
                }
    
                return byte2String;
            }
  • 相关阅读:
    JAVA AES加密算法实现代码
    JAVA BASE64 加密解密实现代码
    eclipseLuna (4.4.0) 安装velocity 插件
    NIO中的Buffer
    Oracle死锁处理
    DWR、Comet4j在Nginx+Tomcat组合下的优化
    网站已运行时间代码
    常用DB2命令
    DB2分页查询简单示例
    comet4j推送 405/500 JSON转换异常
  • 原文地址:https://www.cnblogs.com/aijiao/p/10240366.html
Copyright © 2011-2022 走看看