古詩詞大全網 - 藝術簽名 - Java keytool工具的作用及使用方法

Java keytool工具的作用及使用方法

 Keytool 是安全鑰匙與證書的管理工具 它管理壹個存儲了私有鑰匙和驗證相應公***鑰匙的與它們相關聯的X 證書鏈的keystore(相當壹個數據庫)

 Keytool 是壹個有效的安全鑰匙和證書的管理工具 它能夠使用戶使用數字簽名來管理他們自己的私有/公***鑰匙對 管理用來作自我鑒定的相關的證書 管理數據完整性和鑒定服務 它還能使用戶在通信時緩存它們的公***鑰匙

 壹個證書是某壹實體(個人 公司等)的數字簽名 指出其他實體的公***鑰匙(或其他信息)的詳細的值 當數據被簽名後 這個簽名信息被用來檢驗數據的完整性和真實性 完整性指數據沒有被修改和篡改 真實性指數據從任何產生和簽名的壹方真正的傳輸到達

 Keytool 把鑰匙和證書儲存到壹個keystore 默任的實現keystore的是壹個文件 它用壹個密碼保護鑰匙

 而另外的壹個工具jarsigner用keystore中的信息產生或檢驗Java aRchive(jar文件)中的數字簽名

 Keystore有兩個不同的入口:

  鑰匙入口:保存了非常敏感的加密的鑰匙信息 並且是用壹個保護的格式存儲以防止未被授權的訪問 以這種形式存儲的鑰匙是秘密鑰匙 或是壹個對應證書鏈中公有鑰匙的私有鑰匙

  信任證書入口:包含壹個屬於其他部分的單壹公***鑰匙證書 它之所以被稱為 信任證書 是因為keystore信任的證書中的公***鑰匙真正屬於證書所有者的身份識別

 Keystore的別名:

 所有的keystore入口(鑰匙和信任證書入口)是通過唯壹的別名訪問 別名是 不區分大小寫的 如別名Hugo和hugo指向同壹個keystore入口

 可以在加壹個入口到keystore的時候使用 genkey參數來產生壹個鑰匙對(公***鑰匙和私有鑰匙)時指定別名 也可以用 import參數加壹個證書或證書鏈到信任證書

 如:

 keytool genkey alias duke keypass dukekeypasswd

 其中duke為別名 dukekeypasswd為duke別名的密碼 這行命令的作用是產生壹個新的公***/私有鑰匙對

 假如妳想修改密碼 可以用:

 keytool keypasswd alias duke keypass dukekeypasswd new newpass

 將舊密碼dukekeypasswd改為newpass

 Keystore的產生:

  當使用 genkey 或 import或 identitydb命令添加數據到壹個keystore 而當這個keystore不存在時 產生壹個keystore 默認名是 keystore 存放到user home目錄

  當用 keystore指定時 將產生指定的keystore

 Keystore的實現:

 Keytool 類位於java security包下 提供壹個非常好的接口去取得和修改壹個keystore中的信息 目前有兩個命令行:keytool和jarsinger 壹個GUI工具Policy 可以實現keystore 由於keystore是公開的 用戶可以用它寫壹些額外的安全應用程序

 Keystore還有壹個sun公司提供的內在實現 它把keystore作為壹個文件來實現 利用了壹個keystore類型(格式) JKS 它用單獨的密碼保護每壹個私有鑰匙 也用可能不同的密碼保護整個keystore的完整性

 支持的算法和鑰匙大小:

 keytool允許用戶指定鑰匙對和註冊密碼服務供應者所提供的簽名算法 缺省的鑰匙對產生算法是 DSA 假如私有鑰匙是 DSA 類型 缺省簽名算法是 SHA withDSA 假如私有鑰匙是 RSA 類型 缺省算法是 MD withRSA

 當產生壹個DSA鑰匙對 鑰匙必須在 位之間 對任何算法的缺省鑰匙大小是 位

 證書:

 壹個證書是壹個實體的數字簽名 指出其他實體的公***鑰匙有明確的值

  公***鑰匙 :是同壹個詳細的實體的數字關聯 並有意讓所有想同這個實體發生信任關系的其他實體知道 公***鑰匙用來檢驗簽名;

  數字簽名:假如數據已被簽名 並用身份存儲在壹個實體中 壹個簽名能夠證明這個實體知道這個數據 這個數據用實體私有鑰匙簽名並遞交;

  身份:知道實體的方法 在壹些系統中身份是公***鑰匙 其他系統中可以是從壹個X 名字的郵件地址的Unix UID來的任何東西;

  簽名:壹個簽名用用實體私有鑰匙來計算某些加密數據;

  私有鑰匙:是壹些數字 每壹個私有鑰匙只能被特定的擁有該私有鑰匙的實體知道 私有和公***鑰匙存在所有用公***鑰匙加密的系統的鑰匙對中 壹個公***鑰匙加密(如DSA) 壹個私有鑰匙與壹個正確的公***鑰匙通信 私有鑰匙用來計算簽名

  實體:壹個實體可以是壹個人 壹個組織 壹個程序 壹臺計算機 壹個商業 壹個銀行 或其他妳想信任的東西

 Keytool應用實例:

  產生壹個keystore:

 keytool genkey alias User(keystore的別名) keyalg RSA validity keystore keystore(指定keystore)

 運行這個命令 系統提示:

 Enter keystore password:yourpassword(輸入密碼)

 What is your first and last name?

 [Unknown]: your name(輸入妳的名字)

 What is the name of your anizational unit?

 [Unknown]:your anizational(輸入妳所在組織單位的名字)

 What is the name of your anization?

 [Unknown]:your anization name (輸入妳所在組織的名字)

 What is the name of your City or Locality?

 [Unknown]:your city name(輸入所在城市的名字)

 What is the name of your State or Province?

 [Unknown]:your provice name(輸入所在省份名字)

 What is the o letter country code for this unit?

 [Unknown]:cn(輸入國家名字)

 Is CN=your name OU=your anizaion O= your anization name

 L=your city name ST=your province name C=cn correct?

 [no]: yes

  檢查壹個keystore:

 keytool list v keystore keystore

 Enter keystore password:your password(輸入密碼)

 將顯示keystore內容如:

 Keystore type: jks

 Keystore provider: SUN

 Your keystore contains entry

 Alias name: yourname

 Creation date: Dec

 Entry type: keyEntry

 Certificate chain length:

 Certificate[ ]:

 Owner: CN=yourname OU=your anization O= your anization name

 L=your city name ST=your province name C=CN

 Issuer: CN=Duke OU=Java Sofare O= Sun Microsystems Inc L=Palo Alto ST=CA C=US

 Serial number: c adc

 Valid from: Thu Dec : : PST until: Thu Dec : : PST

 Certificate fingerprints:

 MD : F : B: B:A :F : :CF: :CF:F :FF: : F: C: C:F

 SHA : B : : :DD:B :CC: : : : : F: :AA:AF: A: D:E : : C:

  輸出keystore到壹個文件:testkey:

 keytool export alias duke keystore keystore rfc file testkey

 系統輸出:

 Enter keystore password:your password(輸入密碼)

 Certificate stored in file

  輸入證書到壹個新的truststore:

 keytool import alias dukecert file testkey keystore truststore

 Enter keystore password:your new password (輸入truststore新密碼)

  檢查truststore:

 keytool list v keystore truststore

 系統將顯示truststore的信息

 現在可以用適當的keystore運行妳的應用程序 如:

 java ssl keyStore=keystore ssl keyStorePassword=password Server

 和: java ssl trustStore=truststore

lishixinzhi/Article/program/Java/hx/201311/25684