RSA加密

最近在整理公司iOS項目,覺得目前的網(wǎng)絡(luò)架構(gòu)實在難修改,固決定重新構(gòu)建一個網(wǎng)絡(luò)請求庫,因請求中經(jīng)常用到加密,正好把加密篇給整理出來。

加密有很多種,項目中常用的有DES\3DES, RSA, AES, MD5。

本篇介紹RSA加密:

第一步:生成公鑰私鑰

生成環(huán)境是在mac系統(tǒng)下,使用openssl進行生成,首先打開終端,按下面這些步驟依次來做:

0.新建保存用文件夾,終端cd到對應(yīng)文件夾下

1. 生成模長為1024bit的私鑰文件private_key.pem

openssl genrsa -out private_key.pem 1024

2. 生成證書請求文件rsaCertReq.csr

openssl req -new -key private_key.pem -out rsaCerReq.csr

注意:這一步會提示輸入國家、省份、mail等信息,可以根據(jù)實際情況填寫,或者全部不用填寫,直接全部敲回車.

3. 生成證書rsaCert.crt,并設(shè)置有效時間為10年

openssl x509 -req -days 3650 -in rsaCerReq.csr -signkey private_key.pem -out rsaCert.crt

4. 生成供iOS使用的公鑰文件public_key.der

openssl x509 -outform der -in rsaCert.crt -out public_key.der

5. 生成供iOS使用的私鑰文件private_key.p12

openssl pkcs12 -export -out private_key.p12 -inkey private_key.pem -in rsaCert.crt

注意:這一步會提示給私鑰文件設(shè)置密碼,直接輸入想要設(shè)置密碼即可,然后敲回車,然后再驗證剛才設(shè)置的密碼,再次輸入密碼,然后敲回車,完畢!

在解密時,private_key.p12文件需要和這里設(shè)置的密碼配合使用,因此需要牢記此密碼.

6. 生成供Java使用的公鑰rsa_public_key.pem

openssl rsa -in private_key.pem -out rsa_public_key.pem -pubout

7. 生成供Java使用的私鑰pkcs8_private_key.pem

openssl pkcs8 -topk8 -in private_key.pem -out pkcs8_private_key.pem -nocrypt

全部執(zhí)行成功后,會生成如下文件,其中public_key.der和private_key.p12就是iOS需要用到的文件

第二步:將文件導(dǎo)入工程使用

1.新建工程, 并導(dǎo)入Security.framework框架

2.導(dǎo)入秘鑰文件

3.上代碼 ?https://github.com/gexinwei/RSA.git

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容