如何通过exponent和modulus来生成真正的public key

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何通过exponent和modulus来生成真正的public key相关的知识,希望对你有一定的参考价值。

参考技术A 如何通过exponent和modulus来生成真正的public key
用公钥加密需要RSAParameters结构的e,n 2个参数,Exponent(e) 就是公钥指数,长度4字节吧,n是模数,算法对应的参数有公式的,010001是0x10001吗。自带类实现

JAVA JS 中的 modulus exponent 生成 C# 公匙

 C#用的是xml,里面是base64编码的。你上面的就是hex格式,只要把上面hex格式转成byte数组,然后在base64编码就可以了。

 public static byte[] Hex2Byte(string byteStr)
        {
            try
            {
                byteStr = byteStr.ToUpper().Replace(" ", "");
                int len = byteStr.Length / 2;
                byte[] data = new byte[len];
                for (int i = 0; i < len; i++)
                {
                    data[i] = Convert.ToByte(byteStr.Substring(i * 2, 2), 16);

                }
                return data;
            }
            catch (Exception ex)
            {
                // SystemLog.ErrLog("bin2byte失败:" + ex.Message);
                return new byte[] { };
            }
        }

 

用上面hex转byte[]可以然后再base64,可以得到

然后再根据xml格式组成xml就是C#的公钥

以上是关于如何通过exponent和modulus来生成真正的public key的主要内容,如果未能解决你的问题,请参考以下文章

使用 JWT 安全令牌访问 REST API

Nvidia Modulus仿真开发入门

百联网上商城加密

RSA:在给定公钥的情况下获取指数和模数

如何将 Java RSA 公钥移植到 c# 加密功能?

从模数和指数生成 RSA 公钥