C# javascript 采用 RSA 加密解密

C# javascript 采用 RSA 加密解密

1.C#提供公钥

2.javascript用公钥加密

3.C#用私钥解密

 

4.javascript 类库 https://www.pidder.de/pidcrypt/

 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
<script src="pidcrypt.js"></script>
<script src="pidcrypt_util.js"></script>
<script src="asn1.js"></script>
<script src="jsbn.js"></script>
<script src="rng.js"></script>
<script src="prng4.js"></script>
<script src="rsa.js"></script>
<script type="text/javascript">
    function submit1() {
        var input = document.getElementById("txtPwd").value;
        //var n_str = "kaYjgFd9yA68TbFH/E57B3QeO4Ch0+7jFil4HfGqVfACKbUIybBcHuifVKUSYxrdfKQ+cIHPmMq0JpXnOX2Y5AZs7mVUWWlFFu35Rjc4oiKrd0z95opjPp8s6WYIgtr3BDs3ja0W7cCl5xIrDD/5SF4IM9ui9uqy9iHGSG57XRs=";
        //var e_str = "AQAB";
        var n_str = document.getElementById("txtN").value;
        var e_str = document.getElementById("txtE").value;
        var n = pidCryptUtil.convertToHex(pidCryptUtil.decodeBase64(n_str));
        var e = pidCryptUtil.convertToHex(pidCryptUtil.decodeBase64(e_str));
 
        var rsa = new pidCrypt.RSA();
        rsa.setPublic(n, e, 16);
        crypted = rsa.encrypt(input);
        var result = pidCryptUtil.encodeBase64(pidCryptUtil.convertFromHex(crypted));
        document.getElementById("txtPwd").value = result;
    }
</script>

 

复制代码
        protected void Page_Load(object sender, EventArgs e)
        {
            InitRSA();
        }

        private void InitRSA()
        {
            if (Session["RSA"] == null)
            {
                RSACryptoServiceProvider rsa = new RSACryptoServiceProvider();
                Session["RSA"] = rsa.ToXmlString(true);
                txtE.Text = Convert.ToBase64String(rsa.ExportParameters(false).Exponent);
                txtN.Text = Convert.ToBase64String(rsa.ExportParameters(false).Modulus);
            }
        }



        protected void Button1_Click(object sender, EventArgs e)
        {
            var pwd = txtPwd.Text;
            RSACryptoServiceProvider rsa = new RSACryptoServiceProvider();
            //rsa.FromXmlString("<RSAKeyValue><Modulus>kaYjgFd9yA68TbFH/E57B3QeO4Ch0+7jFil4HfGqVfACKbUIybBcHuifVKUSYxrdfKQ+cIHPmMq0JpXnOX2Y5AZs7mVUWWlFFu35Rjc4oiKrd0z95opjPp8s6WYIgtr3BDs3ja0W7cCl5xIrDD/5SF4IM9ui9uqy9iHGSG57XRs=</Modulus><Exponent>AQAB</Exponent><P>ywkLeqqcXpAgx1aaadnFDDDTgjNEnqv0PYlNNMgJ30IHGb+YtOediosMKrM3YZbSRoYrVf9W0UPP0+k5c4VqZQ==</P><Q>t6TCzhVl1hCgwfYGgxOHxGQCsgLwgRLCm5f/RXRfBEvag2RmuiKm9yY6cOHEcrJD9fnFm3t0SJPruaFQhjFxfw==</Q><DP>KQIxrFwLa1onFLwcQib3EshF4DVktbu7gDZcPr3sqIhYkM3PFTL28gW1tmYuWGqzHAV7eUoyid/teTrRHNEktQ==</DP><DQ>PJlX1x1kf2D5S0feGj7FnF7MLOWfa1g/c4ySpd6ixA4ryxPEekOZCRFKU5mMc7SzjGWheY8hbhmxvY2nvsBuDQ==</DQ><InverseQ>dc/pyOJ7UxdUO4kj/bHv7n6PLiS7x6JhkmuXvlxvQb1td4jSVl2EaGROzc9W2SAXWFTa3N4G5KzUYF4CKwSp8A==</InverseQ><D>BQJfyjQ4IT9QfqOQRD82wATgXU+JQU7ABK0ccnszTo1YpbKSQM2N/YomoLSksz/jSjwj4Z61Ux31oDYbo8CMF45MboBNIcqvtDgoL+8kNCUEnjnJ9HIkgn7vO1BozqPRu90P8x5zNQbzRumNM7dgcfjxRMvk4cznHVanz18YuxE=</D></RSAKeyValue>");
            rsa.FromXmlString((string)Session["RSA"]);
            var bytes1 = Convert.FromBase64String(pwd);
            byte[] bytes2 = rsa.Decrypt(bytes1, false);
            var p = Encoding.Default.GetString(bytes2);
            bytes1 = Convert.FromBase64String(p);
            p = Encoding.Default.GetString(bytes1);
            TextBox1.Text = p;
            Session["RSA"] = null;
            InitRSA();
        }
复制代码

 

文件下载

 

posted @   I'm CY  阅读(1028)  评论(0编辑  收藏  举报
编辑推荐:
· 软件产品开发中常见的10个问题及处理方法
· .NET 原生驾驭 AI 新基建实战系列:向量数据库的应用与畅想
· 从问题排查到源码分析:ActiveMQ消费端频繁日志刷屏的秘密
· 一次Java后端服务间歇性响应慢的问题排查记录
· dotnet 源代码生成器分析器入门
阅读排行:
· ThreeJs-16智慧城市项目(重磅以及未来发展ai)
· .NET 原生驾驭 AI 新基建实战系列(一):向量数据库的应用与畅想
· Ai满嘴顺口溜,想考研?浪费我几个小时
· Browser-use 详细介绍&使用文档
· 软件产品开发中常见的10个问题及处理方法
点击右上角即可分享
微信分享提示