我在使用SSL麻煩,因爲我正在與我的密鑰庫下面的錯誤(自我創造和使用每keytool的自簽名:http://developer.android.com/tools/publishing/app-signing.html):「密鑰存儲版本錯誤」錯誤。我如何創建一個版本= 1的密鑰庫證書?
08-14 20:55:23.044: W/System.err(5430): java.io.IOException: Wrong version of key store. 08-14 20:55:23.060: W/System.err(5430): at org.bouncycastle.jce.provider.JDKKeyStore.engineLoad(JDKKeyStore.java:812) ...
在JDKKeyStore.java
類拋出的錯誤出現在下面的代碼:
Blockquote From JDKKeyStore.java:
if (version != STORE_VERSION) { if (version != 0) { throw new IOException("Wrong version of key store."); } }Blockquote
在這種情況下STORE_VERSION = 1,我的版本= 3基於閱讀由我創建密鑰庫舉行的證書的詳細信息。我不知道如何生成包含版本= 1證書的密鑰庫。
我發現這個答案有幫助: wrong version keystore when doing https call
但是它要求使用下列參數創建密鑰庫:
-storetype BKS
-provider org.bouncycastle.jce.provider.BouncyCastleProvider
-providerpath /path/to/bouncycastle.jar
然而,當我嘗試創建密鑰工具(在使用終端應用Mac)使用這些參數:
keytool -genkeypair -v -alias androiddebugkey -keyalg RSA -keysize 2048 -validity 10000 -keypass android -keystore /Users/djames/dropbox/bc146keystore/debug.keystore -storepass android -providerclass org.bouncycastle.jce.provider.BouncyCastleProvider –providerpath /Users/djames/dropbox/bc146keystore/
(其中/ Users/djames/dropbox/bc146keystore /是t他路徑充氣城堡的jar:bcprov-jdk16-146.jar)
我得到以下錯誤:
keytool error: java.lang.RuntimeException: Usage error, ?providerpath is not a legal command java.lang.RuntimeException: Usage error, ?providerpath is not a legal command at sun.security.tools.KeyTool.parseArgs(KeyTool.java:375) at sun.security.tools.KeyTool.run(KeyTool.java:171) at sun.security.tools.KeyTool.main(KeyTool.java:166)
我不明白這是什麼告訴我。如果我使用命令:keytool -help它告訴我,以下是該-genkeypair選擇有效的選項:
-genkeypair [-v] [-protected] [-alias ] [-keyalg ] [-keysize ] [-sigalg ] [-dname ] [-validity ] [-keypass ] [-keystore ] [-storepass ] [-storetype ] [-providername ] [-providerclass [-providerarg ]] ... [-providerpath ]
但在Oracle文檔Java版本6,我使用 (http://docs.oracle.com/javase/6/docs/technotes/tools/solaris/keytool.html)
它告訴我這些是選項:
-genkeypair {-alias alias} {-keyalg keyalg} {-keysize keysize} {-sigalg sigalg} [-dname dname] [-keypass keypass] {-validity valDays} {-storetype storetype} {-keystore keystore} [-storepass storepass] {-providerClass provider_class_name {-providerArg provider_arg}} {-v} {-protected} {-Jjavaoption}
其中不包括-providerpath option
。爲什麼不一致? (如果我不使用-providerpath選項,然後在我的選擇得到一個未知的類異常:"-providerclass org.bouncycastle.jce.provider.BouncyCastleProvider"
...)
當我谷歌:密鑰工具-providerpath
我得到什麼有用的解決這個問題。
我不知道如何解決我的密鑰庫版本問題,而不解決我的keytool問題。任何建議感激。
吉姆
(Mac OSX 10.6.8 if relevant)
這個問題已經在這裏解答: http://stackoverflow.com/a/33197845/5459467 – Cukic0d 2015-10-18 17:47:41