SHA1加签名

一、计算文件

public static string HashCode(string str) 
    string rethash = ""
    try 
    
 
          System.Security.Cryptography.SHA1 hash = System.Security.Cryptography.SHA1.Create(); 
           System.Text.ASCIIEncoding encoder = new System.Text.ASCIIEncoding(); 
           byte[] combined = encoder.GetBytes(str); 
           hash.ComputeHash(combined); 
           rethash = Convert.ToBase64String(hash.Hash); 
    
    catch (Exception ex) 
    
           string strerr = "Error in HashCode : " + ex.Message; 
    
    return rethash; 
}
 
using System;
namespace myMethod
{
    class computeMD5andSHA1
    {
        /// <summary>
        /// 计算文件的 MD5 值
        /// </summary>
        /// <param name="fileName">要计算 MD5 值的文件名和路径</param>
        /// <returns>MD5 值16进制字符串</returns>
        public string MD5File(string fileName)
        {
            return HashFile(fileName , "md5");
        }
 
        /// <summary>
        /// 计算文件的 sha1 值
        /// </summary>
        /// <param name="fileName">要计算 sha1 值的文件名和路径</param>
        /// <returns>sha1 值16进制字符串</returns>
        public string SHA1File(string fileName)
        {
            return HashFile(fileName , "sha1");
        }
 
        /// <summary>
        /// 计算文件的哈希值
        /// </summary>
        /// <param name="fileName">要计算哈希值的文件名和路径</param>
        /// <param name="algName">算法:sha1,md5</param>
        /// <returns>哈希值16进制字符串</returns>
        private string HashFile(string fileName , string algName)
        {
            if ( !System.IO.File.Exists(fileName) )
                return string.Empty;
 
            System.IO.FileStream fs = new System.IO.FileStream(fileName , System.IO.FileMode.Open , System.IO.FileAccess.Read);
            byte[] hashBytes = HashData(fs , algName);
            fs.Close();
            return ByteArrayToHexString(hashBytes);
        }
 
        /// <summary>
        /// 计算哈希值
        /// </summary>
        /// <param name="stream">要计算哈希值的 Stream</param>
        /// <param name="algName">算法:sha1,md5</param>
        /// <returns>哈希值字节数组</returns>
        private byte[] HashData(System.IO.Stream stream , string algName)
        {
            System.Security.Cryptography.HashAlgorithm algorithm;
            if ( algName == null )
            {
                throw new ArgumentNullException("algName 不能为 null");
            }
            if string.Compare(algName , "sha1" true) == 0 )
            {
                algorithm = System.Security.Cryptography.SHA1.Create();
            }
            else
            {
                if string.Compare(algName , "md5" true) != 0 )
                {
                    throw new Exception("algName 只能使用 sha1 或 md5");
                }
                algorithm = System.Security.Cryptography.MD5.Create();
            }
            return algorithm.ComputeHash(stream);
        }
 
        /// <summary>
        /// 字节数组转换为16进制表示的字符串
        /// </summary>
        private string ByteArrayToHexString(byte[] buf)
        {
            return BitConverter.ToString(buf).Replace("-" "");
        }
    }
}

、计算文本

  1. /// <summary>  
  2. /// SHA1 加密,返回大写字符串  
  3. /// </summary>  
  4. /// <param name="content">需要加密字符串</param>  
  5. /// <returns>返回40位UTF8 大写</returns>  
  6. public static string SHA1(string content)  
  7. {  
  8.     return SHA1(content, Encoding.UTF8);  
  9. }  
  10. /// <summary>  
  11. /// SHA1 加密,返回大写字符串  
  12. /// </summary>  
  13. /// <param name="content">需要加密字符串</param>  
  14. /// <param name="encode">指定加密编码</param>  
  15. /// <returns>返回40位大写字符串</returns>  
  16. public static string SHA1(string content, Encoding encode)  
  17. {  
  18.     try  
  19.     {  
  20.         SHA1 sha1 = new SHA1CryptoServiceProvider();  
  21.         byte[] bytes_in = encode.GetBytes(content);  
  22.         byte[] bytes_out = sha1.ComputeHash(bytes_in);  
  23.         sha1.Dispose();  
  24.         string result = BitConverter.ToString(bytes_out);  
  25.         result = result.Replace("-""");  
  26.         return result;  
  27.     }  
  28.     catch (Exception ex)  
  29.     {  
  30.         throw new Exception("SHA1加密出错:" + ex.Message);  
  31.     }  
  32. }  

、加密文本

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
class  A
{
   static  string  GetPwd( string  Pwd)
   {
     byte [] data = System.Text.Encoding.Default.GetBytes(Pwd); //以字节方式存储
     System.Security.Cryptography.SHA1 sha1 =  new  System.Security.Cryptography.SHA1CryptoServiceProvider();
     byte [] result = sha1.ComputeHash(data); //得到哈希值
     return  System.BitConverter.ToString(result).Replace( "-" "" );  //转换成为字符串的显示
   }
 
   static  void  Main()
   {
     string  input =  "ABCD" ;
     string  Pwd1  = System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(input,  "SHA1" );
     System.Console.WriteLine(Pwd1);
     string  Pwd2 = GetPwd(input);
     System.Console.WriteLine(Pwd2);
   }
}
 
/* 程序输出:
FB2F85C88567F3C8CE9B799C7C54642D0C7B41F6
FB2F85C88567F3C8CE9B799C7C54642D0C7B41F6
*/




  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值