解決JAVA非對稱加密不同系統(tǒng)加密結(jié)果不一致的問題
最近在做一個項目,需要用到非對稱加密,但是出現(xiàn)一個很詭異的情況,本地開發(fā)環(huán)境是Windows環(huán)境,測試環(huán)境是Linux環(huán)境,出現(xiàn)一個問題, 那就是本地環(huán)境與開發(fā)環(huán)境同一個私鑰字符串加密加密同一個信息,得到的加密結(jié)果不一樣。
經(jīng)過查詢網(wǎng)絡得知,這是由于填充的規(guī)則不同導致。
原來的加密的部分代碼
byte[] keyBytes = Base64.decodeBase64(privateKey);PKCS8EncodedKeySpec pkcs8KeySpec = new PKCS8EncodedKeySpec(keyBytes);KeyFactory keyFactory = KeyFactory.getInstance('RSA');Key privateK = keyFactory.generatePrivate(pkcs8KeySpec) ; Cipher cipher = Cipher.getInstance(keyFactory.getAlgorithm());cipher.init(Cipher.DECRYPT_MODE, privateK);
修改后的加密的部分代碼
byte[] keyBytes = Base64.decodeBase64(privateKey);PKCS8EncodedKeySpec pkcs8KeySpec = new PKCS8EncodedKeySpec(keyBytes);KeyFactory keyFactory = KeyFactory.getInstance(KEY_ALGORITHM);Key privateK = keyFactory.generatePrivate(pkcs8KeySpec);// Cipher cipher = Cipher.getInstance(keyFactory.getAlgorithm());Cipher cipher = Cipher.getInstance('RSA/ECB/PKCS1Padding');cipher.init(Cipher.ENCRYPT_MODE, privateK);
因此差異部分就是Cipher cipher的獲取存在差異導致不同系統(tǒng)下同一秘鑰,同一信息加密結(jié)果不一致
補充知識:Java RSA3加密時因編碼不同導致結(jié)果不同
最近遇到一個問題,使用RSA3加密及驗證時候,因為我方與客戶方工程的編碼格式不同,導致我方使用私鑰加密后,客戶使用公鑰解密失敗。
最后問題定位到src.getBytes()代碼,因我方工程使用GBK編碼,src.getBytes()執(zhí)行時獲取默認編碼為GBK(即src.getBytes('GBK')),而客戶方工程使用UTF-8編碼,解密執(zhí)行src.getBytes()時獲取默認編碼為UTF-8(即src.getBytes('UTF-8'))。造成解密校驗失敗。
解決方法:加密時設置UTF-8編碼格式—src.getBytes('UTF-8',如下:
測試(file的默認編碼為GBK):
以上這篇解決JAVA非對稱加密不同系統(tǒng)加密結(jié)果不一致的問題就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. 利用promise及參數(shù)解構(gòu)封裝ajax請求的方法2. JSP數(shù)據(jù)交互實現(xiàn)過程解析3. windows服務器使用IIS時thinkphp搜索中文無效問題4. .NET中l(wèi)ambda表達式合并問題及解決方法5. Nginx+php配置文件及原理解析6. 淺談python出錯時traceback的解讀7. ASP 信息提示函數(shù)并作返回或者轉(zhuǎn)向8. Ajax實現(xiàn)表格中信息不刷新頁面進行更新數(shù)據(jù)9. Python importlib動態(tài)導入模塊實現(xiàn)代碼10. python matplotlib:plt.scatter() 大小和顏色參數(shù)詳解
