溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

如何利用java security進(jìn)行RSA加密解密流程整理

發(fā)布時(shí)間:2021-10-21 09:54:24 來源:億速云 閱讀:418 作者:柒染 欄目:大數(shù)據(jù)

今天就跟大家聊聊有關(guān)如何利用java security進(jìn)行RSA加密解密流程整理,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。

1. RSA加密生成簽名的過程【私鑰加密】

1.1 準(zhǔn)備參數(shù)封裝成Map

參見代碼

getSignResult方法

1.2 去掉Map中value為空及key為簽名參數(shù)的元素

參見代碼

MagCoreUtil中方法paraFilter(sParaTemp)

1.3 生成簽名結(jié)果

1.3.1 將參數(shù)的key按照ASCII順序排序

參見代碼

MagCoreUtil中的createLinkString方法
1.3.2 將Map中參數(shù)按照“參數(shù)=參數(shù)值”模式并以“&”符號連接成String

參見代碼

MagCoreUtil中的createLinkString方法
1.3.3 利用上述字符串、私鑰及編碼格式獲取簽名結(jié)果

參見代碼

RSA.sign(prestr, privateKey, inputCharset);

1.4 將簽名結(jié)果和簽名方式添加到Map中

參見代碼

MagCoreUtil中buildRequestPara方法

2. RSA解密驗(yàn)證簽名的過程【公鑰解密】

2.1 流讀取方式獲取“參數(shù)=參數(shù)值”并以“&”連接的參數(shù)

參見代碼

驗(yàn)簽代碼部分getPostData方法
2.1.1 Spring Boot流讀取參數(shù)方法

地址

https://my.oschina.net/u/3193075/blog/3080552

2.2 將獲取的參數(shù)封裝成Map

參見代碼

驗(yàn)簽部分 transferToMap方法

2.3 驗(yàn)證數(shù)字簽名

2.3.1 去掉value為空及key為sign(簽名結(jié)果)的數(shù)據(jù)得到新的Map

參見代碼

MagCoreUtil中paraFilter
2.3.2 將上述處理完的Map的Key按照ASCII碼排序并封裝成“參數(shù)=參數(shù)值”模式以“&”連接得到String
MagCoreUtil中方法createLinkString
2.3.3 利用RSA驗(yàn)簽,參數(shù)上述String、簽名方式、編碼格式和公鑰

參見代碼

RSA的RSA.verify(src, sign, BdPayCommData.BD_PUBLIC_KEY, charset)方法

2.4 繼續(xù)其他業(yè)務(wù)

3. 說明

完整代碼參考

https://gitee.com/YuHuaShan/codes/ewaqxptsri46u1lc53nm097

看完上述內(nèi)容,你們對如何利用java security進(jìn)行RSA加密解密流程整理有進(jìn)一步的了解嗎?如果還想了解更多知識(shí)或者相關(guān)內(nèi)容,請關(guān)注億速云行業(yè)資訊頻道,感謝大家的支持。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI