在使用C#的不對(duì)稱加密
RSACryptoServiceProvider
類的時(shí)候,會(huì)遇到異常:System.Security.Cryptography.CryptographicException: The data to be decrypted exceeds the maximum for this modulus of 128 bytes.
異常詳細(xì)信息:?System.Security.Cryptography.CryptographicException:?要解密的數(shù)據(jù)超過(guò)此模塊的最大值?128?字節(jié)。
錯(cuò)誤發(fā)生在
rsa.Decrypt
這一行。通常不對(duì)稱加密的過(guò)程:1. A端數(shù)據(jù)用公鑰加密,通過(guò)網(wǎng)絡(luò)傳輸 2. B端用私鑰解密這些數(shù)據(jù)。但.net中的rsa加密最多只能對(duì)117字節(jié)數(shù)據(jù)進(jìn)行操作(128位減去隨機(jī)數(shù)),導(dǎo)致128位數(shù)據(jù)不得不分兩部分進(jìn)行處理,于是加密數(shù)據(jù)不斷膨脹。更多詳細(xì)討論參考
StackOverflow這
個(gè)帖子。
解決辦法
在CodeProject上有一篇 文章 , 可以很好的解決這個(gè)問(wèn)題,先下載BigInteger class。

????{
???????? /// ? <summary>
???????? /// ?RSAs?the?encrypt.
???????? /// ? </summary>
???????? /// ? <param?name="datatoencrypt"> The?datatoencrypt. </param>
???????? /// ? <param?name="exponent"> The?exponent. </param>
???????? /// ? <param?name="modulus"> The?modulus. </param>
???????? /// ? <returns></returns>
???????? public ? static ? byte []?RsaEncrypt( byte []?datatoencrypt,? byte []?exponent,? byte []?modulus)
????????{
???????????? var ?original?=? new ?BigInteger(datatoencrypt);
???????????? var ?e?=? new ?BigInteger(exponent);
???????????? var ?n?=? new ?BigInteger(modulus);
???????????? var ?encrypted?=?original.modPow(e,?n);
???????????? return ?HexstringTobyte(encrypted.ToHexString());
????????}
???????? /// ? <summary>
???????? /// ?RSAs?the?decrypt.
???????? /// ? </summary>
???????? /// ? <param?name="encrypteddata"> The?encrypteddata. </param>
???????? /// ? <param?name="d"> The?d. </param>
???????? /// ? <param?name="modulus"> The?modulus. </param>
???????? /// ? <returns></returns>
???????? public ? static ? byte []?RsaDecrypt( byte []?encrypteddata,? byte []?d,? byte []?modulus)
????????{
???????????? var ?encrypted?=? new ?BigInteger(encrypteddata);
???????????? var ?dd?=? new ?BigInteger(d);
???????????? var ?n?=? new ?BigInteger(modulus);
???????????? var ?decrypted?=?encrypted.modPow(dd,?n);
???????????? return ?HexstringTobyte(decrypted.ToHexString());
????????}
???????? /// ? <summary>
???????? /// ?Generate?random?bytes?with?given?length
???????? /// ? </summary>
???????? /// ? <param?name="bytelength"></param>
???????? /// ? <returns></returns>
???????? public ? static ? byte []?GenerateRandomBytes( int ?bytelength)
????????{
???????????? var ?buff?=? new ? byte [bytelength];
???????????? var ?rng?=? new ?RNGCryptoServiceProvider();
????????????rng.GetBytes(buff);
???????????? return ?buff;
????????}
????}

var ?rsa?=? new ?RSACryptoServiceProvider();
rsa.ImportParameters(_publicKey? /* Type:?RSAParameters */ );
byte []?encryptedData?=?RSAHelper.RsaEncrypt(Encoding.Unicode.GetBytes(stringDataToEncrypt? /* Type:?string */ ),?data.parameters.Exponent,?data.parameters.Modulus);
return ?Convert.ToBase64String(encryptedData);

var ?rsa?=? new ?RSACryptoServiceProvider();
// Import?private?key
rsa.ImportParameters(_privateKey? /* ?Type:?RSAParameters? */ );
byte []?encryptedData?=?RSAHelper.RsaDecrypt(Convert.FromBase64String(encryptedBase64String /* ?Type:?string,?but?base64?format? */ ),?_privateKey.D,?_privateKey.Modulus);
return ?Encoding.Unicode.GetString(encryptedData);
更多討論
?
?
?
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號(hào)聯(lián)系: 360901061
您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對(duì)您有幫助就好】元
