我正在尝试使用 Mega 加密 API,但我被 RSA 解密部分卡住了。
使用的 JavaScript 是这样的:
// Compute m**d mod p*q for RSA private key operations.
function RSAdecrypt(m, d, p, q, u)
{
var xp = bmodexp(bmod(m,p), bmod(d,bsub(p,[1])), p);
var xq = bmodexp(bmod(m,q), bmod(d,bsub(q,[1])), q);
var t=bsub(xq,xp);
if(t.length==0)
{
t=bsub(xp,xq);
t=bmod(bmul(t, u), q);
t=bsub(q,t);
}
else
{
t=bmod(bmul(t, u), q);
}
return badd(bmul(t,p), xp);
}
我正在使用 .NET(支持 BigInteger 的 4.0)并且我正在尝试复制相同的行为。
我拥有的 RSA 数据是:
p (1024 bits)
q (1024 bits)
d (2044 bits)
u (1024 bits)
m (2044 bits) (the ciphered data)
我尝试使用 RSACryptoServiceProvider 没有运气。在另一篇文章中,另一位用户报告说他使用基本的 RSA 解密算法 (m**d mod p*q) 并避免使用 RSACryptoServiceProvider。
我实现了它(我理解 U 部分不是必需的),确保输入与 Javascript 输入完全相同,但仍然没有运气。输出与 Javascript 代码的预期不同。
这是实现的功能:
Public Shared Function RSA_Decrypt(ByVal P As Numerics.BigInteger, ByVal Q As Numerics.BigInteger, ByVal D As Numerics.BigInteger, ByVal M As Numerics.BigInteger) As Byte()
Dim N As System.Numerics.BigInteger = Numerics.BigInteger.Multiply(P, Q)
Dim DecryptedData As System.Numerics.BigInteger = Numerics.BigInteger.ModPow(M, D, N)
Return DecryptedData.ToByteArray
End Function
测试代码:
Dim P As New Numerics.BigInteger(Convert.FromBase64String("gbb1FjTy...s="))
Dim Q As New Numerics.BigInteger(Convert.FromBase64String("o0fGo0v...8="))
Dim D As New Numerics.BigInteger(Convert.FromBase64String("GFVe9C...bQ=="))
Dim Data As New Numerics.BigInteger(Convert.FromBase64String("BnrSc/..Dg=="))
Dim ResultBytes As Byte() = cripto.RSA_Decrypt(P, Q, D, Data)
Dim ResultStr As String = Convert.ToBase64String(ResultBytes)
此代码返回:
Vd2jBCzObTx...QW1y+VRSZHAw==
但是,JavaScript 函数返回
LUyj3pyIyr4g...1aZU=
你知道我做错了什么,我该如何解决这个问题?