国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

jQuery+C#實現參數RSA加密傳輸功能【附jsencrypt.js下載】

2019-11-19 16:15:25
字體:
來源:轉載
供稿:網友

本文實例講述了jQuery+C#實現參數RSA加密傳輸功能。分享給大家供大家參考,具體如下:

注意:

參數傳遞的+號處理,在傳輸時會把+變成空格,不處理后端就報錯了。

1、前端代碼

<!DOCTYPE html><html><head>  <meta name="viewport" content="width=device-width" />  <title>Login</title>  <script src="jquery-1.10.2.min.js"></script>  <script src="jsencrypt.min.js"></script>  <script type="text/javascript">    $(function () {      var encrypt = new JSEncrypt();      encrypt.setPublicKey($("#tra").val());      var data = encrypt.encrypt("123456789");      alert(data);      $("#btn").click(function () {        $.ajax({          url: '@Url.Action("Login")',          data: "pwd=" + encodeURI(data).replace(//+/g, '%2B'), //+號的處理:因為數據在網絡上傳輸時,非字母數字字符都將被替換成百分號(%)后跟兩位十六進制數,而base64編碼在傳輸到后端的時候,+會變成空格,因此先替換掉。后端再替換回來          type: 'post',          success: function (msg) {            alert(msg);          }        });      });    });  </script></head><body>  <div>    <input type="button" id="btn" value="點我" />    <textarea id="tra" rows="15" cols="65">      MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCa4KHNwDX44gGmmIAtRu4gjVYtGWZzcm4t+1wjUD4dn7fMLPvuK7ai4UrfDeEJE1RPwudJw+lJ6crql8wSIg7/DbTl      G3ihsCT6dT9H5B9OoeR7K9VWUesaW/iyVL6HXiYOANabW14pvJATDmdq91Tfgp6P      SQyvdfiRdV4r07crpQIDAQAB    </textarea>    <hr/>    注意+號的處理  </div></body></html>

2、后端代碼

public class IndexController : Controller{    public ActionResult Login()    {      return View();    }    [HttpPost]    public ActionResult Login(string pwd)    {      //密鑰格式要生成pkcs#1格式的  而不是pkcs#8格式的      string privateKey = @"MIICWwIBAAKBgQCa4KHNwDX44gGmmIAtRu4gjVYtGWZzcm4t+1wjUD4dn7fMLPvuK7ai4UrfDeEJE1RPwudJw+lJ6crql8wSIg7/DbTlG3ihsCT6dT9H5B9OoeR7K9VWUesaW/iyVL6HXiYOANabW14pvJATDmdq91Tfgp6PSQyvdfiRdV4r07crpQIDAQABAoGABb+3gdb+qeG0b1CogVsT/7//UOaTzPk/FGneKQQTf4SsN+H7lVhTYTG9ARFCJyoWg8IXqmn2ljhywHPTWWD2RCZIn2sYT1sVkGb70EgHGQLBraFHElmw+DsVJ+nDfBCfMrJ1TYXlwigjRkaueaoGgG8LdR8XD+Xs5LersPLjZgECQQCguSB7C4wF6oSwEDmwNF8ffT5cQc1U2OIq6NBG8rafrjb7LsjhOd03pmY7i4LbW3Vvq4AhQpJEdF1Cvd+Sk/BBAkEA9rBhqnyumV09zFEomSX3zZu+bdhTzM4bJDfEa95swp1gANCVvF/tDCnlBf51EhCWdeGSpARPUkQnXrYfFUDiZQJAAZEshuaa6+fYeVr/JP+tucHf3MhrdxtSQTbZ6QcuzqnFMXfIT6HfzU4bCxOWKAthPsB+VFSw1mgIDMGLL4OvwQJAJlVyV9PYLezXVZCnBmVoBINXLCqZmxHMFey0kS6XKAbcjEPdgNBHPcSk2jGYb540Q00yRFqHGPmORKF4Yw0aIQJAd5JRtD3z2MgP/vPoKHJNHqY8bboVcmwqVAm6xCZoTCZzjNV1Cnsdf4wBV3LCDzYBy+xR4qYNUy5CFXN+8WzzAA==";      try      {        RSACryptoServiceProvider rsaCryptoServiceProvider = CreateRsaProviderFromPrivateKey(privateKey);        //把+號,再替換回來        byte[] res = rsaCryptoServiceProvider.Decrypt(Convert.FromBase64String(pwd.Replace("%2B","+")), false);        return Content(Encoding.UTF8.GetString(res));      }      catch (Exception exception)      {      }      return Content("");    }    private RSACryptoServiceProvider CreateRsaProviderFromPrivateKey(string privateKey)    {      var privateKeyBits = System.Convert.FromBase64String(privateKey);      var RSA = new RSACryptoServiceProvider();      var RSAparams = new RSAParameters();      using (BinaryReader binr = new BinaryReader(new MemoryStream(privateKeyBits)))      {        byte bt = 0;        ushort twobytes = 0;        twobytes = binr.ReadUInt16();        if (twobytes == 0x8130)          binr.ReadByte();        else if (twobytes == 0x8230)          binr.ReadInt16();        else          throw new Exception("Unexpected value read binr.ReadUInt16()");        twobytes = binr.ReadUInt16();        if (twobytes != 0x0102)          throw new Exception("Unexpected version");        bt = binr.ReadByte();        if (bt != 0x00)          throw new Exception("Unexpected value read binr.ReadByte()");        RSAparams.Modulus = binr.ReadBytes(GetIntegerSize(binr));        RSAparams.Exponent = binr.ReadBytes(GetIntegerSize(binr));        RSAparams.D = binr.ReadBytes(GetIntegerSize(binr));        RSAparams.P = binr.ReadBytes(GetIntegerSize(binr));        RSAparams.Q = binr.ReadBytes(GetIntegerSize(binr));        RSAparams.DP = binr.ReadBytes(GetIntegerSize(binr));        RSAparams.DQ = binr.ReadBytes(GetIntegerSize(binr));        RSAparams.InverseQ = binr.ReadBytes(GetIntegerSize(binr));      }      RSA.ImportParameters(RSAparams);      return RSA;    }    private int GetIntegerSize(BinaryReader binr)    {      byte bt = 0;      byte lowbyte = 0x00;      byte highbyte = 0x00;      int count = 0;      bt = binr.ReadByte();      if (bt != 0x02)        return 0;      bt = binr.ReadByte();      if (bt == 0x81)        count = binr.ReadByte();      else        if (bt == 0x82)        {          highbyte = binr.ReadByte();          lowbyte = binr.ReadByte();          byte[] modint = { lowbyte, highbyte, 0x00, 0x00 };          count = BitConverter.ToInt32(modint, 0);        }        else        {          count = bt;        }      while (binr.ReadByte() == 0x00)      {        count -= 1;      }      binr.BaseStream.Seek(-1, SeekOrigin.Current);      return count;    }}

附:jsencrypt.min.js點擊此本站下載。

PS:關于加密解密感興趣的朋友還可以參考本站在線工具:

MD5在線加密工具:
http://tools.VeVB.COm/password/CreateMD5Password

迅雷、快車、旋風URL加密/解密工具:
http://tools.VeVB.COm/password/urlrethunder

在線散列/哈希算法加密工具:
http://tools.VeVB.COm/password/hash_encrypt

在線MD5/hash/SHA-1/SHA-2/SHA-256/SHA-512/SHA-3/RIPEMD-160加密工具:
http://tools.VeVB.COm/password/hash_md5_sha

在線sha1/sha224/sha256/sha384/sha512加密工具:
http://tools.VeVB.COm/password/sha_encode

更多關于jQuery相關內容感興趣的讀者可查看本站專題:《jQuery常用插件及用法總結》、《jQuery擴展技巧總結》、《jQuery切換特效與技巧總結》、《jQuery遍歷算法與技巧總結》、《jQuery常見經典特效匯總》、《jQuery動畫與特效用法總結》及《jquery選擇器用法總結

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 永清县| 乌什县| 工布江达县| 常山县| 嘉义市| 买车| 西华县| 长泰县| 安西县| 绿春县| 本溪| 尼玛县| 满洲里市| 黔江区| 左云县| 宁陵县| 白河县| 醴陵市| 丁青县| 阿图什市| 常熟市| 萍乡市| 万宁市| 高唐县| 洛扎县| 遵化市| 乐山市| 仙游县| 大名县| 五指山市| 江西省| 沧州市| 林口县| 金昌市| 连山| 凤翔县| 嘉善县| 合水县| 曲阜市| 延寿县| 外汇|