如何把安全證書導入到java中的cacerts證書庫

轉載:http://blog.sina.com.cn/s/blog_56d8ea9001017uo4.html

在項目開發中,有時會遇到與SSL安全證書導入打交道的,如何把證書導入java中的cacerts證書庫呢?

其實很簡單,方法如下:


每一步:進入某個https://www.xxx.com開頭的網站,把要導入的證書下載過來,


    在該網頁上右鍵 >> 屬性 >> 點擊"證書" >>


    再點擊上面的"詳細信息"切換欄 >>


    再點擊右下角那個"複製到文件"的按鈕


    就會彈出一個證書導出的嚮導對話框,按提示一步一步完成就行了。


    例如:保存爲abc.cer,放在C盤下



第二步:如何把上面那步的(abc.cer)這個證書導入java中的cacerts證書庫裏?


    方法如下


    假設你的jdk安裝在C:\jdk1.5這個目錄,


    開始 >> 運行 >> 輸入cmd 進入dos命令行 >>


    再用cd進入到C:\jdk1.5\jre\lib\security這個目錄下


    敲入如下命令回車執行


    keytool -import -alias cacerts -keystore cacerts -file d:\software\AKAZAM-Mail.cer


    此時命令行會提示你輸入cacerts證書庫的密碼,


    你敲入changeit就行了,這是java中cacerts證書庫的默認密碼,


    你自已也可以修改的。


導入後用-list查看(沒有使用-alias指定別名,所以是mykey),其中md5會和證書的md5對應上。

mykey, 2012-10-26, trustedCertEntry,

認證指紋 (MD5): 8D:A2:89:9A:E4:17:07:0B:BD:B0:0C:36:11:39:D0:3D

以後更新時,先刪除原來的證書,然後導入新的證書

keytool -list -keystore cacerts

keytool -delete -alias akazam_email -keystore cacerts

keytool -import -alias akazam_email -file akazam_email.cer -keystore cacerts



自定義文件和密碼路徑,還沒有驗證:

Define the TrustStore using the JAVA_OPTS variable on the Stash Server:

You will have to do the following:

    On Windows:

    JAVA_OPTS = -Djavax.net.ssl.trustStore="%JAVA_HOME%\jre\lib\security\cacerts" -Djavax.net.ssl.trustStorePassword="changeit"

    On Linux:

    JAVA_OPTS = -Djavax.net.ssl.trustStore="$JAVA_HOME/jre/lib/security/cacerts" -Djavax.net.ssl.trustStorePassword="changeit"

(info) On my local instance trustStore password is changeit so I belive, if you didn′t changed it, your is changeit as well.


tomcat、junit運行時會從默認路徑加載cacerts文件,如果main函數直接運行需要指定javax.net.ssl.trustStore文件路徑,比如:

java -Djavax.net.ssl.trustStore=$JAVA_HOME/jre/lib/security/cacerts -jar XXX.jar &


注意JAVA_HOME設置中如果有空格,會java執行錯誤,可以把環境變量JAVA_HOME中C:\Program Files縮寫爲C:\Progra~1


linux下該方法同樣適用!


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章