亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

用Bouncy Castle實現AES-128-CBC加密解密

系統 1967 0

Bouncy Castle Crypto APIs 是一個開源的輕量級Java 加密解密包,實現了JCE/JCA的provider,支持AES等多種加密解密算法。
詳情請見主頁:http://www.bouncycastle.org/java.html
本文的示例代碼使用了http://www.bouncycastle.org/download/bcprov-jdk16-139.jar
1)使用JCE的AES-128-CBC加密解密

Java代碼 ? 收藏代碼
  1. package ?com.albertsong.aes;??
  2. ??
  3. import ?java.security.Key;??
  4. import ?java.security.Security;??
  5. ??
  6. import ?javax.crypto.Cipher;??
  7. import ?javax.crypto.spec.IvParameterSpec;??
  8. import ?javax.crypto.spec.SecretKeySpec;??
  9. ??
  10. import ?org.bouncycastle.jce.provider.BouncyCastleProvider;??
  11. import ?org.bouncycastle.util.encoders.Hex;??
  12. ??
  13. /** ?
  14. ?*?@author?Albert ?
  15. ?*?@version?1.0 ?
  16. ?*? ?
  17. ?*/ ??
  18. public ? class ?AESWithJCE?{??
  19. ??
  20. ???? /** ?
  21. ?????*?@param?args ?
  22. ?????*/ ??
  23. ???? public ? static ? void ?main(String[]?args)?{??
  24. ???????? byte []?keybytes?=?{? 0x31 ,? 0x32 ,? 0x33 ,? 0x34 ,? 0x35 ,? 0x36 ,? 0x37 ,? 0x38 ,??
  25. ???????????????? 0x31 ,? 0x32 ,? 0x33 ,? 0x34 ,? 0x35 ,? 0x36 ,? 0x37 ,? 0x38 ?};??
  26. ???????? byte []?iv?=?{? 0x38 ,? 0x37 ,? 0x36 ,? 0x35 ,? 0x34 ,? 0x33 ,? 0x32 ,? 0x31 ,? 0x38 ,??
  27. ???????????????? 0x37 ,? 0x36 ,? 0x35 ,? 0x34 ,? 0x33 ,? 0x32 ,? 0x31 ?};??
  28. ????????String?content?= "TEST1234567890ABCDEFGHIJKLMNOPQRSTUVWXYZ" ;??
  29. ????????System.out.println( "Original?content:" );??
  30. ????????System.out.println(content);??
  31. ???????? try ?{??
  32. ????????????Security.addProvider( new ?BouncyCastleProvider());??
  33. ????????????Key?key?=? new ?SecretKeySpec(keybytes,? "AES" );??
  34. ????????????Cipher?in?=?Cipher.getInstance( "AES/CBC/PKCS7Padding" , "BC" );??
  35. ????????????in.init(Cipher.ENCRYPT_MODE,?key,? new ?IvParameterSpec(iv));??
  36. ???????????? byte []?enc?=?in.doFinal(content.getBytes());??
  37. ????????????System.out.println( "Encrypted?Content:" );??
  38. ????????????System.out.println( new ?String(Hex.encode(enc)));??
  39. ??????????????
  40. ????????????Cipher?out?=?Cipher.getInstance( "AES/CBC/PKCS7Padding" ,? "BC" );??
  41. ????????????out.init(Cipher.DECRYPT_MODE,?key,? new ?IvParameterSpec(iv));??
  42. ???????????? byte []?dec?=?out.doFinal(enc);??
  43. ????????????System.out.println( "Decrypted?Content:" );??
  44. ????????????System.out.println( new ?String(dec));??
  45. ????????}? catch ?(Exception?ex)?{??
  46. ????????????ex.printStackTrace();??
  47. ????????}??
  48. ??
  49. ????}??
  50. ??
  51. }??

?2)不使用JCE的AES-128-CBC加密解密,可以用于J2ME程序中。

Java代碼 ? 收藏代碼
  1. package ?com.albertsong.aes;??
  2. ??
  3. import ?org.bouncycastle.crypto.BufferedBlockCipher;??
  4. import ?org.bouncycastle.crypto.engines.AESFastEngine;??
  5. import ?org.bouncycastle.crypto.modes.CBCBlockCipher;??
  6. import ?org.bouncycastle.crypto.paddings.PaddedBufferedBlockCipher;??
  7. import ?org.bouncycastle.crypto.params.KeyParameter;??
  8. import ?org.bouncycastle.crypto.params.ParametersWithIV;??
  9. import ?org.bouncycastle.util.encoders.Hex;??
  10. ??
  11. /** ?
  12. ?*?@author?Albert ?
  13. ?*?@version?1.0 ?
  14. ?* ?
  15. ?*/ ??
  16. public ? class ?AESWithoutJCE?{??
  17. ??
  18. ???? /** ?
  19. ?????*?@param?args ?
  20. ?????*/ ??
  21. ???? public ? static ? void ?main(String[]?args)?{??
  22. ???????? byte []?keybytes?=?{? 0x31 ,? 0x32 ,? 0x33 ,? 0x34 ,? 0x35 ,? 0x36 ,? 0x37 ,? 0x38 ,??
  23. ???????????????? 0x31 ,? 0x32 ,? 0x33 ,? 0x34 ,? 0x35 ,? 0x36 ,? 0x37 ,? 0x38 ?};??
  24. ???????? byte []?iv?=?{? 0x38 ,? 0x37 ,? 0x36 ,? 0x35 ,? 0x34 ,? 0x33 ,? 0x32 ,? 0x31 ,? 0x38 ,??
  25. ???????????????? 0x37 ,? 0x36 ,? 0x35 ,? 0x34 ,? 0x33 ,? 0x32 ,? 0x31 ?};??
  26. ????????String?content?= "TEST1234567890ABCDEFGHIJKLMNOPQRSTUVWXYZ" ;??
  27. ????????System.out.println( "Original?content:" );??
  28. ????????System.out.println(content);??
  29. ???????? try ?{??
  30. ????????????BufferedBlockCipher?engine?=? new ?PaddedBufferedBlockCipher( new ?CBCBlockCipher( new ?AESFastEngine()));??
  31. ????????????engine.init( true ,? new ?ParametersWithIV( new ?KeyParameter(keybytes),iv));??
  32. ???????????? byte []?enc?=? new ? byte [engine.getOutputSize(content.getBytes().length)];??
  33. ???????????? int ?size1?=?engine.processBytes(content.getBytes(),? 0 ,?content.getBytes().length,?enc,? 0 );??
  34. ???????????? int ?size2?=?engine.doFinal(enc,?size1);??
  35. ????????????System.out.println( "size2?=" +size2);??
  36. ???????????? byte []?encryptedContent?= new ? byte [size1+size2];??
  37. ????????????System.arraycopy(enc,? 0 ,?encryptedContent,? 0 ,?encryptedContent.length);??
  38. ????????????System.out.println( "Encrypted?Content:" );??
  39. ????????????System.out.println( new ?String(Hex.encode(encryptedContent)));??
  40. ??????????????
  41. ??????????????
  42. ????????????engine.init( false ,? new ?ParametersWithIV( new ?KeyParameter(keybytes),iv));??
  43. ???????????? byte []?dec?=? new ? byte [engine.getOutputSize(encryptedContent.length)];??
  44. ????????????size1?=?engine.processBytes(encryptedContent,? 0 ,?encryptedContent.length,?dec,? 0 );??
  45. ????????????size2?=?engine.doFinal(dec,?size1);??
  46. ????????????System.out.println( "size2?=" +size2);??
  47. ???????????? byte []?decryptedContent?= new ? byte [size1+size2];??
  48. ????????????System.arraycopy(dec,? 0 ,?decryptedContent,? 0 ,?decryptedContent.length);??
  49. ????????????System.out.println( "Decrypted?Content:" );??
  50. ????????????System.out.println( new ?String(decryptedContent));??
  51. ??
  52. ????????}? catch ?(Exception?ex)?{??
  53. ????????????ex.printStackTrace();??
  54. ????????}??
  55. ??
  56. ????}??
  57. ??
  58. }?

用Bouncy Castle實現AES-128-CBC加密解密


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: youjizz欧美粗又大中国 | 伊人久久一本大道 | 久久91精品国产91久久户 | 亚洲欧美综合久久 | 综合图区亚洲 | 久久综合给合久久97色美利坚 | 国产成人一区二区三中文 | 久操国产视频 | 99在线视频播放 | 中文国产成人久久精品小说 | 中文字幕久久亚洲一区 | 亚洲最大在线 | 视频一区二区三区在线观看 | 老黄网站 | 一区二区精品在线观看 | 久久一本久综合久久爱 | 免费国产视频 | 免费视频国产 | 亚洲国产一区在线 | 日韩va亚洲va欧美va浪潮 | 欧美aaaa在线观看视频免费 | 日本夜夜夜 | 亚洲香蕉一区二区三区在线观看 | 久久88色综合色鬼 | 奇米777第四 | 国产精品高清一区二区三区 | 国产精品成人久久久久久久 | 国产国拍亚洲精品福利 | 欧美精品国产综合久久 | 久久久精品免费视频 | 天天干在线影院 | 99精彩视频在线观看 | 国内精品久久久久久久久 | 99久久综合九九亚洲 | 老司机福利深夜亚洲入口 | 日韩国产欧美一区二区三区在线 | 国产精品女在线观看 | 成人私拍福利视频在线 | 九九免费观看全部免费视频 | 亚洲欧美中文字幕 | 九九热最新视频 |