java - RSA 签名 Java 到 C#
问题描述
我有一个创建签名的工具。我正在寻找 dot net core 2.1 中的等效代码。
Java 代码:sign(currentdate,'some text','SHA1WithRSA')
public String sign(String date, String subjectId, String algorithm){
Signature rsa = Signature.getInstance(algorithm);
rsa.initSign(this.getPrivate());
rsa.update(subjectId.getBytes());
rsa.update(date.getBytes());
String signature = new String(Base64.getEncoder().encode(rsa.sign()));
return signature;
}
public PrivateKey getPrivate() {
String privateKeyPEM = "<This is the private key string";
byte[] encoded = Base64.getDecoder().decode(privateKeyPEM);
KeyFactory kf = KeyFactory.getInstance("RSA");
PKCS8EncodedKeySpec spec = new PKCS8EncodedKeySpec(encoded);
return kf.generatePrivate(spec);
}
建议使用或不使用 3rd 方工具为上述生成 dot net core 2.1 等效代码的方法。
解决方案
这是我使用Portable.BouncyCastle
图书馆的工作。
private string GetSign(string data)
{
using (var rsa = new RSACryptoServiceProvider())
{
var privateKey = new StringBuilder();
privateKey.AppendLine("-----BEGIN RSA PRIVATE KEY-----");
privateKey.AppendLine("private key as string");
privateKey.AppendLine("-----END RSA PRIVATE KEY-----");
var pem = new PemReader(new StringReader(privateKey.ToString()));
var keyPair = (AsymmetricCipherKeyPair)pem.ReadObject();
var privateKeyParameters = (RsaPrivateCrtKeyParameters)keyPair.Private;
var rsaParameters = DotNetUtilities.ToRSAParameters(privateKeyParameters);
rsa.ImportParameters(rsaParameters);
var sign = rsa.SignData(Encoding.UTF8.GetBytes(data), new HashAlgorithmName("SHA1") /*pass your algorithm*/,
RSASignaturePadding.Pkcs1);
return Convert.ToBase64String(sign);
}
}
推荐阅读
- mysql - 如何排除两个日期之间的某些时间?
- node.js - NodeJS i18n 用参数(url)表达改变语言
- javascript - 如何将多个数组合并为多个单独的对象?
- assembly - 为什么虚拟地址内存 0xXX 0x90 0x04 0x08 和 0xXX 0x80 0x04 0x08 具有相同的行为?
- pyspark - 从数据框名称中删除数字
- java - 二维数组随机索引乐透游戏
- android - 使用 FlexboxLayoutManger 作为 RecyclerView 的 layoutManager 时,所有获取行函数返回 0
- r - 将 json 类型列转换为 R 数据框
- docker - 从外部主机访问 docker-compose api
- jenkins - 推内部工作时如何避免工作触发?