MD5、SHA256、SHA512加密算法,以及可逆算法

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Security.Cryptography;
using System.Text;
  
public static string GetMD5Password(string password)
{
    MD5CryptoServiceProvider crypto = new MD5CryptoServiceProvider();
    byte[] bytes = Encoding.UTF7.GetBytes(password);
    bytes = crypto.ComputeHash(bytes);
    StringBuilder sb = new StringBuilder();
    foreach (byte num in bytes)
    {
        sb.AppendFormat("{0:x2}", num);
    }
    return sb.ToString();
}
public static string GetSHA512Password(string password)
{
    byte[] bytes = Encoding.UTF7.GetBytes(password);
    byte[] result;
    SHA512 shaM = new SHA512Managed();
    result = shaM.ComputeHash(bytes);
    StringBuilder sb = new StringBuilder();
    foreach (byte num in result)
    {
        sb.AppendFormat("{0:x2}", num);
    }
    return sb.ToString();
}
<pre class="csharp" name="code"> private static string HashString256(string stringToHash, string hachKey)
        {
            UTF8Encoding myEncoder = new UTF8Encoding();
            byte[] key = myEncoder.GetBytes(hachKey);
            byte[] text = myEncoder.GetBytes(stringToHash);

            System.Security.Cryptography.HMACSHA256 myHMACSHA256 = new System.Security.Cryptography.HMACSHA256(key);
            byte[] hashCode = myHMACSHA256.ComputeHash(text);
            string hash = BitConverter.ToString(hashCode).Replace("-", "");

            return hash.ToLower();
        }


//百度的MD5加密,与上面不太一样
public static string MD5(string password)
{
    byte[] textBytes = System.Text.Encoding.Default.GetBytes(password);
    try
    {
        System.Security.Cryptography.MD5CryptoServiceProvider cryptHandler;
        cryptHandler = new System.Security.Cryptography.MD5CryptoServiceProvider();
        byte[] hash = cryptHandler.ComputeHash(textBytes);
        string ret = "";
        foreach (byte a in hash)
        {
            if (a < 16)
                ret += "0" + a.ToString("x");
            else
                ret += a.ToString("x");
        }
        return ret;
    }
    catch
    {
        throw;
    }
} 


 

注:MD5生成32位的密码

SHA512生成128的密码

SHA256生成64的密码

 

可逆的加密码算法:产生的密码位数由密码本身长度决定

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Security.Cryptography;
using System.IO;

namespace GlacierV2.Common
{
    public static class Global
    {
        private static int _newDBPrimaryKeySeed = 0;

        #region 加密和解密算法
        private static SymmetricAlgorithm mobjCryptoService = new RijndaelManaged();
        /// <summary>   
        /// 获得密钥   
        /// </summary>   
        /// <returns>密钥</returns>   
        private static byte[] GetLegalKey()
        {
            string sTemp = "xfsdfgsfgsdgsdfgsdfg";
            mobjCryptoService.GenerateKey();
            byte[] bytTemp = mobjCryptoService.Key;
            int KeyLength = bytTemp.Length;
            if (sTemp.Length > KeyLength)
                sTemp = sTemp.Substring(0, KeyLength);
            else if (sTemp.Length < KeyLength)
                sTemp = sTemp.PadRight(KeyLength, ' ');
            return ASCIIEncoding.ASCII.GetBytes(sTemp);
        }
        /// <summary>   
        /// 获得初始向量IV   
        /// </summary>   
        /// <returns>初试向量IV</returns>   
        private static byte[] GetLegalIV()
        {
            string sTemp = "swetwerehetyeryertyerty";
            mobjCryptoService.GenerateIV();
            byte[] bytTemp = mobjCryptoService.IV;
            int IVLength = bytTemp.Length;
            if (sTemp.Length > IVLength)
                sTemp = sTemp.Substring(0, IVLength);
            else if (sTemp.Length < IVLength)
                sTemp = sTemp.PadRight(IVLength, ' ');
            return ASCIIEncoding.ASCII.GetBytes(sTemp);
        }
        /// <summary>   
        /// 加密方法   
        /// </summary>   
        /// <param name="Source">待加密的串</param>   
        /// <returns>经过加密的串</returns>   
        public static string Encrypto(string Source)
        {
            byte[] bytIn = UTF8Encoding.UTF8.GetBytes(Source);
            MemoryStream ms = new MemoryStream();
            mobjCryptoService.Key = GetLegalKey();
            mobjCryptoService.IV = GetLegalIV();
            ICryptoTransform encrypto = mobjCryptoService.CreateEncryptor();
            CryptoStream cs = new CryptoStream(ms, encrypto, CryptoStreamMode.Write);
            cs.Write(bytIn, 0, bytIn.Length);
            cs.FlushFinalBlock();
            ms.Close();
            byte[] bytOut = ms.ToArray();
            return Convert.ToBase64String(bytOut);
        }
        /// <summary>   
        /// 解密方法   
        /// </summary>   
        /// <param name="Source">待解密的串</param>   
        /// <returns>经过解密的串</returns>   
        public static string Decrypto(string Source)
        {
            byte[] bytIn = Convert.FromBase64String(Source);
            MemoryStream ms = new MemoryStream(bytIn, 0, bytIn.Length);
            mobjCryptoService.Key = GetLegalKey();
            mobjCryptoService.IV = GetLegalIV();
            ICryptoTransform encrypto = mobjCryptoService.CreateDecryptor();
            CryptoStream cs = new CryptoStream(ms, encrypto, CryptoStreamMode.Read);
            StreamReader sr = new StreamReader(cs);
            return sr.ReadToEnd();
        }
        #endregion

    }
}


 


  • 3
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 5
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值