亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C# > 正文

C#自定義RSA加密解密及RSA簽名和驗證類實例

2020-01-24 02:05:56
字體:
來源:轉載
供稿:網友

本文實例講述了C#自定義RSA加密解密及RSA簽名和驗證類。分享給大家供大家參考。具體分析如下:

這個C#類自定義RSA加密解密及RSA簽名和驗證,包含了RSA加密、解密及簽名所需的相關函數,帶有詳細的注釋說明。

using System; using System.Text; using System.Security.Cryptography;namespace DotNet.Utilities{  /// <summary>  /// RSA加密解密及RSA簽名和驗證 /// </summary>  public class RSACryption  {     public RSACryption()   {      }     #region RSA 加密解密   #region RSA 的密鑰產生    /// <summary>  /// RSA 的密鑰產生 產生私鑰 和公鑰   /// </summary>  /// <param name="xmlKeys"></param>  /// <param name="xmlPublicKey"></param>  public void RSAKey(out string xmlKeys,out string xmlPublicKey)   {        System.Security.Cryptography.RSACryptoServiceProvider rsa=new RSACryptoServiceProvider();     xmlKeys=rsa.ToXmlString(true);     xmlPublicKey = rsa.ToXmlString(false);      }   #endregion   #region RSA的加密函數   //##############################################################################   //RSA 方式加密   //說明KEY必須是XML的行式,返回的是字符串   //在有一點需要說明??!該加密方式有 長度 限制的?。?  //##############################################################################   //RSA的加密函數 string  public string RSAEncrypt(string xmlPublicKey,string m_strEncryptString )   {       byte[] PlainTextBArray;    byte[] CypherTextBArray;    string Result;    RSACryptoServiceProvider rsa=new RSACryptoServiceProvider();    rsa.FromXmlString(xmlPublicKey);    PlainTextBArray = (new UnicodeEncoding()).GetBytes(m_strEncryptString);    CypherTextBArray = rsa.Encrypt(PlainTextBArray, false);    Result=Convert.ToBase64String(CypherTextBArray);    return Result;      }   //RSA的加密函數 byte[]  public string RSAEncrypt(string xmlPublicKey,byte[] EncryptString )   {       byte[] CypherTextBArray;    string Result;    RSACryptoServiceProvider rsa=new RSACryptoServiceProvider();    rsa.FromXmlString(xmlPublicKey);    CypherTextBArray = rsa.Encrypt(EncryptString, false);    Result=Convert.ToBase64String(CypherTextBArray);    return Result;      }   #endregion   #region RSA的解密函數   //RSA的解密函數 string  public string RSADecrypt(string xmlPrivateKey, string m_strDecryptString )   {      byte[] PlainTextBArray;    byte[] DypherTextBArray;    string Result;    System.Security.Cryptography.RSACryptoServiceProvider rsa=new RSACryptoServiceProvider();    rsa.FromXmlString(xmlPrivateKey);    PlainTextBArray =Convert.FromBase64String(m_strDecryptString);    DypherTextBArray=rsa.Decrypt(PlainTextBArray, false);    Result=(new UnicodeEncoding()).GetString(DypherTextBArray);    return Result;      }   //RSA的解密函數 byte  public string RSADecrypt(string xmlPrivateKey, byte[] DecryptString )   {      byte[] DypherTextBArray;    string Result;    System.Security.Cryptography.RSACryptoServiceProvider rsa=new RSACryptoServiceProvider();    rsa.FromXmlString(xmlPrivateKey);    DypherTextBArray=rsa.Decrypt(DecryptString, false);    Result=(new UnicodeEncoding()).GetString(DypherTextBArray);    return Result;      }   #endregion   #endregion   #region RSA數字簽名   #region 獲取Hash描述表   //獲取Hash描述表 ,sharejs.com  public bool GetHash(string m_strSource, ref byte[] HashData)   {       //從字符串中取得Hash描述    byte[] Buffer;    System.Security.Cryptography.HashAlgorithm MD5 = System.Security.Cryptography.HashAlgorithm.Create("MD5");    Buffer = System.Text.Encoding.GetEncoding("GB2312").GetBytes(m_strSource);    HashData = MD5.ComputeHash(Buffer);    return true;      }   //獲取Hash描述表   public bool GetHash(string m_strSource, ref string strHashData)   {       //從字符串中取得Hash描述    byte[] Buffer;    byte[] HashData;    System.Security.Cryptography.HashAlgorithm MD5 = System.Security.Cryptography.HashAlgorithm.Create("MD5");    Buffer = System.Text.Encoding.GetEncoding("GB2312").GetBytes(m_strSource);    HashData = MD5.ComputeHash(Buffer);    strHashData = Convert.ToBase64String(HashData);    return true;      }   //獲取Hash描述表   public bool GetHash(System.IO.FileStream objFile, ref byte[] HashData)   {       //從文件中取得Hash描述    System.Security.Cryptography.HashAlgorithm MD5 = System.Security.Cryptography.HashAlgorithm.Create("MD5");    HashData = MD5.ComputeHash(objFile);    objFile.Close();    return true;      }   //獲取Hash描述表   public bool GetHash(System.IO.FileStream objFile, ref string strHashData)   {       //從文件中取得Hash描述    byte[] HashData;    System.Security.Cryptography.HashAlgorithm MD5 = System.Security.Cryptography.HashAlgorithm.Create("MD5");    HashData = MD5.ComputeHash(objFile);    objFile.Close();    strHashData = Convert.ToBase64String(HashData);    return true;      }   #endregion   #region RSA簽名   //RSA簽名   public bool SignatureFormatter(string p_strKeyPrivate, byte[] HashbyteSignature, ref byte[] EncryptedSignatureData)   {        System.Security.Cryptography.RSACryptoServiceProvider RSA = new System.Security.Cryptography.RSACryptoServiceProvider();     RSA.FromXmlString(p_strKeyPrivate);     System.Security.Cryptography.RSAPKCS1SignatureFormatter RSAFormatter = new System.Security.Cryptography.RSAPKCS1SignatureFormatter(RSA);     //設置簽名的算法為MD5     RSAFormatter.SetHashAlgorithm("MD5");     //執行簽名     EncryptedSignatureData = RSAFormatter.CreateSignature(HashbyteSignature);     return true;      }   //RSA簽名   public bool SignatureFormatter(string p_strKeyPrivate, byte[] HashbyteSignature, ref string m_strEncryptedSignatureData)   {        byte[] EncryptedSignatureData;     System.Security.Cryptography.RSACryptoServiceProvider RSA = new System.Security.Cryptography.RSACryptoServiceProvider();     RSA.FromXmlString(p_strKeyPrivate);     System.Security.Cryptography.RSAPKCS1SignatureFormatter RSAFormatter = new System.Security.Cryptography.RSAPKCS1SignatureFormatter(RSA);     //設置簽名的算法為MD5     RSAFormatter.SetHashAlgorithm("MD5");     //執行簽名     EncryptedSignatureData = RSAFormatter.CreateSignature(HashbyteSignature);     m_strEncryptedSignatureData = Convert.ToBase64String(EncryptedSignatureData);     return true;      }   //RSA簽名   public bool SignatureFormatter(string p_strKeyPrivate, string m_strHashbyteSignature, ref byte[] EncryptedSignatureData)   {        byte[] HashbyteSignature;     HashbyteSignature = Convert.FromBase64String(m_strHashbyteSignature);     System.Security.Cryptography.RSACryptoServiceProvider RSA = new System.Security.Cryptography.RSACryptoServiceProvider();     RSA.FromXmlString(p_strKeyPrivate);     System.Security.Cryptography.RSAPKCS1SignatureFormatter RSAFormatter = new System.Security.Cryptography.RSAPKCS1SignatureFormatter(RSA);     //設置簽名的算法為MD5     RSAFormatter.SetHashAlgorithm("MD5");     //執行簽名     EncryptedSignatureData = RSAFormatter.CreateSignature(HashbyteSignature);     return true;      }   //RSA簽名   public bool SignatureFormatter(string p_strKeyPrivate, string m_strHashbyteSignature, ref string m_strEncryptedSignatureData)   {        byte[] HashbyteSignature;     byte[] EncryptedSignatureData;     HashbyteSignature = Convert.FromBase64String(m_strHashbyteSignature);     System.Security.Cryptography.RSACryptoServiceProvider RSA = new System.Security.Cryptography.RSACryptoServiceProvider();     RSA.FromXmlString(p_strKeyPrivate);     System.Security.Cryptography.RSAPKCS1SignatureFormatter RSAFormatter = new System.Security.Cryptography.RSAPKCS1SignatureFormatter(RSA);     //設置簽名的算法為MD5     RSAFormatter.SetHashAlgorithm("MD5");     //執行簽名     EncryptedSignatureData = RSAFormatter.CreateSignature(HashbyteSignature);     m_strEncryptedSignatureData = Convert.ToBase64String(EncryptedSignatureData);     return true;      }   #endregion   #region RSA 簽名驗證   public bool SignatureDeformatter(string p_strKeyPublic, byte[] HashbyteDeformatter, byte[] DeformatterData)   {        System.Security.Cryptography.RSACryptoServiceProvider RSA = new System.Security.Cryptography.RSACryptoServiceProvider();     RSA.FromXmlString(p_strKeyPublic);     System.Security.Cryptography.RSAPKCS1SignatureDeformatter RSADeformatter = new System.Security.Cryptography.RSAPKCS1SignatureDeformatter(RSA);     //指定解密的時候HASH算法為MD5     RSADeformatter.SetHashAlgorithm("MD5");     if(RSADeformatter.VerifySignature(HashbyteDeformatter,DeformatterData))     {      return true;     }     else     {      return false;     }      }   public bool SignatureDeformatter(string p_strKeyPublic, string p_strHashbyteDeformatter, byte[] DeformatterData)   {        byte[] HashbyteDeformatter;     HashbyteDeformatter = Convert.FromBase64String(p_strHashbyteDeformatter);     System.Security.Cryptography.RSACryptoServiceProvider RSA = new System.Security.Cryptography.RSACryptoServiceProvider();     RSA.FromXmlString(p_strKeyPublic);     System.Security.Cryptography.RSAPKCS1SignatureDeformatter RSADeformatter = new System.Security.Cryptography.RSAPKCS1SignatureDeformatter(RSA);     //指定解密的時候HASH算法為MD5     RSADeformatter.SetHashAlgorithm("MD5");     if(RSADeformatter.VerifySignature(HashbyteDeformatter,DeformatterData))     {      return true;     }     else     {      return false;     }      }   public bool SignatureDeformatter(string p_strKeyPublic, byte[] HashbyteDeformatter, string p_strDeformatterData)   {        byte[] DeformatterData;     System.Security.Cryptography.RSACryptoServiceProvider RSA = new System.Security.Cryptography.RSACryptoServiceProvider();     RSA.FromXmlString(p_strKeyPublic);     System.Security.Cryptography.RSAPKCS1SignatureDeformatter RSADeformatter = new System.Security.Cryptography.RSAPKCS1SignatureDeformatter(RSA);     //指定解密的時候HASH算法為MD5     RSADeformatter.SetHashAlgorithm("MD5");     DeformatterData =Convert.FromBase64String(p_strDeformatterData);     if(RSADeformatter.VerifySignature(HashbyteDeformatter,DeformatterData))     {      return true;     }     else     {      return false;     }      }   public bool SignatureDeformatter(string p_strKeyPublic, string p_strHashbyteDeformatter, string p_strDeformatterData)   {        byte[] DeformatterData;     byte[] HashbyteDeformatter;     HashbyteDeformatter = Convert.FromBase64String(p_strHashbyteDeformatter);     System.Security.Cryptography.RSACryptoServiceProvider RSA = new System.Security.Cryptography.RSACryptoServiceProvider();     RSA.FromXmlString(p_strKeyPublic);     System.Security.Cryptography.RSAPKCS1SignatureDeformatter RSADeformatter = new System.Security.Cryptography.RSAPKCS1SignatureDeformatter(RSA);     //指定解密的時候HASH算法為MD5     RSADeformatter.SetHashAlgorithm("MD5");     DeformatterData =Convert.FromBase64String(p_strDeformatterData);     if(RSADeformatter.VerifySignature(HashbyteDeformatter,DeformatterData))     {      return true;     }     else     {      return false;     }      }   #endregion   #endregion  } }

希望本文所述對大家的C#程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美国产中文字幕| 成人美女免费网站视频| 成人性教育视频在线观看| 亚洲欧美日韩在线高清直播| 尤物精品国产第一福利三区| 欧美三级xxx| 国产精品中文字幕久久久| 69av在线播放| 亚洲精品国产精品乱码不99按摩| 中文字幕在线观看亚洲| 国产成人免费91av在线| 日韩中文字幕在线免费观看| 日本三级久久久| 亚洲视频视频在线| www.久久撸.com| 91精品国产成人www| 高潮白浆女日韩av免费看| 中文字幕日本精品| 亚洲激情小视频| 欧美电影免费观看大全| 狠狠色香婷婷久久亚洲精品| 亚洲午夜未删减在线观看| 欧美高跟鞋交xxxxhd| 奇门遁甲1982国语版免费观看高清| 91精品国产电影| 中文字幕一精品亚洲无线一区| 亚洲欧洲偷拍精品| 欧美成人四级hd版| 中文字幕亚洲一区二区三区| 亚洲欧美日韩一区二区在线| 欧美日韩激情网| 2021久久精品国产99国产精品| 粉嫩老牛aⅴ一区二区三区| 欧美日韩成人黄色| 国产一区玩具在线观看| 久久不射热爱视频精品| 国产欧美日韩中文字幕在线| 97精品久久久中文字幕免费| 欧美精品免费播放| 综合激情国产一区| 高清欧美性猛交| 国产精欧美一区二区三区| 亚洲欧美一区二区三区在线| 韩剧1988在线观看免费完整版| 国产精品爱啪在线线免费观看| 日韩电影中文字幕一区| 91久久精品国产91性色| 日韩av123| 精品久久久久久久久久ntr影视| 精品久久久久久久久中文字幕| 91夜夜揉人人捏人人添红杏| 欧美一级片久久久久久久| 国产精品成人免费视频| 国产精品96久久久久久又黄又硬| 欧美性videos高清精品| 亚洲日本aⅴ片在线观看香蕉| 国产91精品高潮白浆喷水| 久久中文字幕在线| 国产不卡av在线免费观看| 欧美成人合集magnet| 亚洲iv一区二区三区| 国产剧情久久久久久| 国产精品偷伦免费视频观看的| 久久久国产精彩视频美女艺术照福利| 色综合色综合网色综合| 国产香蕉97碰碰久久人人| 全亚洲最色的网站在线观看| 成人免费xxxxx在线观看| 日本免费一区二区三区视频观看| 日本成人激情视频| 午夜精品在线观看| 亚洲性生活视频在线观看| 久久成人人人人精品欧| 91色中文字幕| 国产精品成av人在线视午夜片| 日韩av黄色在线观看| 超碰精品一区二区三区乱码| 欧美在线视频网| 欧美日韩加勒比精品一区| 3344国产精品免费看| 国产精品无av码在线观看| 在线一区二区日韩| 亚洲色图国产精品| 中文字幕一区二区精品| 久久精品美女视频网站| 中文字幕日韩免费视频| 国产精品美女在线观看| 久久色免费在线视频| 欧美亚洲国产日韩2020| 中文字幕久热精品视频在线| 按摩亚洲人久久| 日韩欧美在线看| 亚洲精品视频中文字幕| 欧美伦理91i| 亚洲日韩欧美视频一区| 在线观看欧美日韩国产| 欧美精品videos另类日本| 日韩欧美一区视频| 九九热在线精品视频| 精品国产一区二区三区四区在线观看| 久久伊人色综合| 中文字幕综合一区| 亚洲一区二区三区久久| 欧美日韩中文字幕| 亚洲男人7777| 亚洲一区久久久| 亚洲欧美福利视频| 国产一区二区三区直播精品电影| 亚洲欧美综合另类中字| 97在线看免费观看视频在线观看| 日韩有码在线电影| 日韩欧美亚洲成人| 成人午夜在线影院| 97精品视频在线观看| 俺去啦;欧美日韩| 亚洲欧美中文在线视频| 成人福利视频在线观看| 日韩欧美中文第一页| 久久av.com| 人妖精品videosex性欧美| 亚洲免费电影一区| 亚洲国产古装精品网站| 欧美一区深夜视频| 国产日韩欧美中文| 成人a视频在线观看| 黄色精品一区二区| 欧美性jizz18性欧美| 丝袜亚洲另类欧美重口| 88国产精品欧美一区二区三区| 国产精品白嫩初高中害羞小美女| 久久久精品国产一区二区| 视频一区视频二区国产精品| 日韩高清中文字幕| 中文字幕欧美在线| 欧美一区二区三区四区在线| 伊是香蕉大人久久| 欧美日韩另类字幕中文| 青青草国产精品一区二区| 亚洲精品日韩丝袜精品| 国产精品日本精品| 亚洲区一区二区| 亚洲欧美精品一区| 亚洲精品视频播放| 日本韩国在线不卡| 亚洲国产精品专区久久| 久久人人爽人人爽人人片av高清| 欧美激情精品久久久久久变态| 日韩电影在线观看中文字幕| 国产精品久久久久久久久久免费| 国产精品久久久久久久久久尿| 狠狠躁夜夜躁人人爽天天天天97| 成人做爽爽免费视频| 欧美激情亚洲综合一区| 欧美黑人一级爽快片淫片高清| 欧美日韩国产黄| 91日本在线观看| 欧美亚洲国产日本| 精品久久香蕉国产线看观看gif| 欧美精品日韩三级| 91久久精品国产91久久性色| 一区二区亚洲欧洲国产日韩| 国产一区二区三区四区福利| 九九精品在线视频| 久久久久国产精品免费网站|