python实现的jsencryp加密后端无法解密_使用jsencrypt.js实现前端加密,C#后端解密...

在分享源码之前,先准备一些东西:

1、下载一个js加密帮助文件,下载地址:https://passport.cnblogs.com/scripts/jsencrypt.min.js,在项目中以JavaScript.js保存,以方便引用:,当然了,也可以直接引用网页的,即:

2、生成一对RSA密钥对,可以在这个网址生成:http://web.chacuo.net/netrsakeypair,也可以下载一个工具来生成。

3、创建一个JsEncryptHelper.cs,包含后台的加密和解决功能,要把第2步生成的密钥对放置在此文件中,之前本来想在前台js中有参调用加密函数来加密不成功,就是我楼上提出的问题。后面就采用JavaScript.js够进行加密了,为了展示效果,把加密的结果保存在文本框中,如果在实际项目中可以把密文保存在一个隐藏的文本框中。后面会把这个类JsEncryptHelper.cs的代码一并分享。

一、前台代码:

function pwd()

{

var encrypt = new JSEncrypt();

encrypt.setPublicKey("MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCC0hrRIjb3noDWNtbDpANbjt5Iwu2NFeDwU16Ec87ToqeoIm2KI+cOs81JP9aTDk/jkAlU97mN8wZkEMDr5utAZtMVht7GLX33Wx9XjqxUsDfsGkqNL8dXJklWDu9Zh80Ui2Ug+340d5dZtKtd+nv09QZqGjdnSp9PTfFDBY133QIDAQAB");

var str = document.getElementById("tmpPWD").value;

var encryptData = encrypt.encrypt(str);//加密后的字符串

console.log(encryptData);

document.getElementById("miwen").value = encryptData;

}

输入密码:

密码加密密文:

密文解密:

二、后台解密按钮代码 :

protected void Button1_Click(object sender, EventArgs e)

{

JsEncryptHelper newRSA = new JsEncryptHelper();

mingwen.Text = newRSA.Decrypt(miwen.Text);

}

三、JsEncryptHelper.cs代码:

using System;

using System.Collections.Generic;

using System.Linq;

using System.Web;

using System.IO;

using System.Security.Cryptography;

using System.Text;

using System.Threading.Tasks;

///

/// JsEncryptHelper 的摘要说明

///

///

/// AJax提交参数加密帮助类

///

public class JsEncryptHelper

{

private const string defaultprivateKey = @"MIICXAIBAAKBgQCC0hrRIjb3noDWNtbDpANbjt5Iwu2NFeDwU16Ec87ToqeoIm2K

I+cOs81JP9aTDk/jkAlU97mN8wZkEMDr5utAZtMVht7GLX33Wx9XjqxUsDfsGkqN

L8dXJklWDu9Zh80Ui2Ug+340d5dZtKtd+nv09QZqGjdnSp9PTfFDBY133QIDAQAB

AoGAJBNTOITaP6LCyKVKyEdnHaKNAz0DS+

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值