C# RSA分段加解密實(shí)現(xiàn)方法詳解
本文實(shí)例講述了C# RSA分段加解密實(shí)現(xiàn)方法。分享給大家供大家參考,具體如下:
RSA加解密:
1024位的證書(shū),加密時(shí)最大支持117個(gè)字節(jié),解密時(shí)為128;
2048位的證書(shū),加密時(shí)最大支持245個(gè)字節(jié),解密時(shí)為256。
加密時(shí)支持的最大字節(jié)數(shù):證書(shū)位數(shù)/8 -11(比如:2048位的證書(shū),支持的最大加密字節(jié)數(shù):2048/8 - 11 = 245)
.NET中的RSA加密算法為了提高安全性,在待加密數(shù)據(jù)前要添加一些隨機(jī)數(shù),因此,使用.NET中的RSA加密算法一次最多加密117字節(jié)數(shù)據(jù)(多于117字節(jié)需要拆分成多段分別加密再連接起來(lái)),經(jīng)過(guò)加密后得到一個(gè)長(zhǎng)度為128字節(jié)的加密數(shù)據(jù)。
RSA實(shí)際可加密的明文長(zhǎng)度最大也是1024bits,但問(wèn)題就來(lái)了:如果小于這個(gè)長(zhǎng)度怎么辦?就需要進(jìn)行padding,因?yàn)槿绻麤](méi)有padding,用戶無(wú)法區(qū)分解密后內(nèi)容的真實(shí)長(zhǎng)度,字符串之類的內(nèi)容問(wèn)題還不大,以0作為結(jié)束符,但對(duì)二進(jìn)制數(shù)據(jù)就很難理解,因?yàn)椴淮_定后面的0是內(nèi)容還是內(nèi)容結(jié)束符。只要用到padding,那么就要占用實(shí)際的明文長(zhǎng)度,于是才有117字節(jié)的說(shuō)法。我們一般使用的padding標(biāo)準(zhǔn)有NoPPadding、OAEPPadding、PKCS1Padding等,其中PKCS#1建議的padding就占用了11個(gè)字節(jié)。如果大于這個(gè)長(zhǎng)度怎么辦?很多算法的padding往往是在后邊的,但PKCS的padding則是在前面的,此為有意設(shè)計(jì),有意的把第一個(gè)字節(jié)置0以確保m的值小于n。這樣,128字節(jié)(1024bits)-減去11字節(jié)正好是117字節(jié),但對(duì)于RSA加密來(lái)講,padding也是參與加密的,所以,依然按照1024bits去理解,但實(shí)際的明文只有117字節(jié)了。
C#代碼實(shí)現(xiàn):
internal static string GetEncryptedMsg(string xml) { byte[] encryptedData; using (var rsa = GetPublicKey(Configs.PublicKeyFilePath)) { var plainData = Encoding.UTF8.GetBytes(xml); using (var plaiStream = new MemoryStream(plainData)) { using (var crypStream = new MemoryStream()) { var offSet = 0; var inputLen = plainData.Length; for (var i = 0; inputLen - offSet > 0; offSet = i*244) { if (inputLen - offSet > 244) { var buffer = new Byte[244]; plaiStream.Read(buffer, 0, 244); var cryptograph = rsa.Encrypt(buffer, false); crypStream.Write(cryptograph, 0, cryptograph.Length); } else { var buffer = new Byte[inputLen - offSet]; plaiStream.Read(buffer, 0, inputLen - offSet); var cryptograph = rsa.Encrypt(buffer, false); crypStream.Write(cryptograph, 0, cryptograph.Length); } ++i; } crypStream.Position = 0; encryptedData = crypStream.ToBytes(); } } } return BitConverter.ToString(encryptedData).Replace("-", string.Empty); } internal static byte[] GetDecryptedMsg(byte[] encryptedBytes) { using (var rsa = GetPrivateKey(Configs.PrivateKeyFilePath, Configs.PrivateKeyPasswd)) { byte[] decryptedData; using (var plaiStream = new MemoryStream(encryptedBytes)) { using (var decrypStream = new MemoryStream()) { var offSet = 0; var inputLen = encryptedBytes.Length; for (var i = 0; inputLen - offSet > 0; offSet = i * 256) { if (inputLen - offSet > 256) { var buffer = new Byte[256]; plaiStream.Read(buffer, 0, 256); var decrypData = rsa.Decrypt(buffer, false); decrypStream.Write(decrypData, 0, decrypData.Length); } else { var buffer = new Byte[inputLen - offSet]; plaiStream.Read(buffer, 0, inputLen - offSet); var decrypData = rsa.Decrypt(buffer, false); decrypStream.Write(decrypData, 0, decrypData.Length); } ++i; } decrypStream.Position = 0; decryptedData = decrypStream.ToBytes(); } } return decryptedData; } }
PS:關(guān)于加密解密感興趣的朋友還可以參考本站在線工具:
MD5在線加密工具:
http://tools.jb51.net/password/CreateMD5Password
迅雷、快車(chē)、旋風(fēng)URL加密/解密工具:
http://tools.jb51.net/password/urlrethunder
在線散列/哈希算法加密工具:
http://tools.jb51.net/password/hash_encrypt
在線MD5/hash/SHA-1/SHA-2/SHA-256/SHA-512/SHA-3/RIPEMD-160加密工具:
http://tools.jb51.net/password/hash_md5_sha
在線sha1/sha224/sha256/sha384/sha512加密工具:
http://tools.jb51.net/password/sha_encode
更多關(guān)于C#相關(guān)內(nèi)容還可查看本站專題:《C#加密與解密算法與技巧總結(jié)》、《C#窗體操作技巧匯總》、《C#常見(jiàn)控件用法教程》、《WinForm控件用法總結(jié)》、《C#程序設(shè)計(jì)之線程使用技巧總結(jié)》、《C#操作Excel技巧總結(jié)》、《C#中XML文件操作技巧匯總》、《C#數(shù)據(jù)結(jié)構(gòu)與算法教程》、《C#數(shù)組操作技巧總結(jié)》及《C#面向?qū)ο蟪绦蛟O(shè)計(jì)入門(mén)教程》
希望本文所述對(duì)大家C#程序設(shè)計(jì)有所幫助。
欄 目:C#教程
下一篇:C#實(shí)現(xiàn)將32位MD5摘要串轉(zhuǎn)換為128位二進(jìn)制字符串的方法
本文標(biāo)題:C# RSA分段加解密實(shí)現(xiàn)方法詳解
本文地址:http://mengdiqiu.com.cn/a1/C_jiaocheng/5799.html
您可能感興趣的文章
- 01-10使用Nopcommerce為商城添加滿XX減XX優(yōu)惠券功能
- 01-10C#中DataGridView動(dòng)態(tài)添加行及添加列的方法
- 01-10C#實(shí)現(xiàn)基于加減按鈕形式控制系統(tǒng)音量及靜音的方法
- 01-10C#編程實(shí)現(xiàn)DataTable添加行的方法
- 01-10C#編程實(shí)現(xiàn)發(fā)送郵件的方法(可添加附件)
- 01-10C#給圖片添加水印完整實(shí)例
- 01-10C#代碼實(shí)現(xiàn)對(duì)AES加密解密
- 01-10基于C#對(duì)用戶密碼使用MD5加密與解密
- 01-10C#實(shí)現(xiàn)給圖片加水印的方法
- 01-10C#怎么給PDF添加背景圖片


閱讀排行
- 1C語(yǔ)言 while語(yǔ)句的用法詳解
- 2java 實(shí)現(xiàn)簡(jiǎn)單圣誕樹(shù)的示例代碼(圣誕
- 3利用C語(yǔ)言實(shí)現(xiàn)“百馬百擔(dān)”問(wèn)題方法
- 4C語(yǔ)言中計(jì)算正弦的相關(guān)函數(shù)總結(jié)
- 5c語(yǔ)言計(jì)算三角形面積代碼
- 6什么是 WSH(腳本宿主)的詳細(xì)解釋
- 7C++ 中隨機(jī)函數(shù)random函數(shù)的使用方法
- 8正則表達(dá)式匹配各種特殊字符
- 9C語(yǔ)言十進(jìn)制轉(zhuǎn)二進(jìn)制代碼實(shí)例
- 10C語(yǔ)言查找數(shù)組里數(shù)字重復(fù)次數(shù)的方法
本欄相關(guān)
- 01-10C#通過(guò)反射獲取當(dāng)前工程中所有窗體并
- 01-10關(guān)于ASP網(wǎng)頁(yè)無(wú)法打開(kāi)的解決方案
- 01-10WinForm限制窗體不能移到屏幕外的方法
- 01-10WinForm繪制圓角的方法
- 01-10C#實(shí)現(xiàn)txt定位指定行完整實(shí)例
- 01-10WinForm實(shí)現(xiàn)仿視頻播放器左下角滾動(dòng)新
- 01-10C#停止線程的方法
- 01-10C#實(shí)現(xiàn)清空回收站的方法
- 01-10C#通過(guò)重寫(xiě)Panel改變邊框顏色與寬度的
- 01-10C#實(shí)現(xiàn)讀取注冊(cè)表監(jiān)控當(dāng)前操作系統(tǒng)已
隨機(jī)閱讀
- 01-11Mac OSX 打開(kāi)原生自帶讀寫(xiě)NTFS功能(圖文
- 08-05dedecms(織夢(mèng))副欄目數(shù)量限制代碼修改
- 01-10SublimeText編譯C開(kāi)發(fā)環(huán)境設(shè)置
- 04-02jquery與jsp,用jquery
- 01-10C#中split用法實(shí)例總結(jié)
- 08-05DEDE織夢(mèng)data目錄下的sessions文件夾有什
- 01-10delphi制作wav文件的方法
- 01-10使用C語(yǔ)言求解撲克牌的順子及n個(gè)骰子
- 01-11ajax實(shí)現(xiàn)頁(yè)面的局部加載
- 08-05織夢(mèng)dedecms什么時(shí)候用欄目交叉功能?