世界因你而精彩  
          日歷
          <2008年11月>
          2627282930311
          2345678
          9101112131415
          16171819202122
          23242526272829
          30123456
          統(tǒng)計(jì)
          • 隨筆 - 169
          • 文章 - 1
          • 評(píng)論 - 138
          • 引用 - 0

          導(dǎo)航

          常用鏈接

          留言簿(9)

          隨筆分類(163)

          隨筆檔案(154)

          文章檔案(1)

          新聞檔案(1)

          相冊(cè)

          收藏夾(1)

          個(gè)人雜雜

          友情鏈接

          自學(xué)考試

          資料搜索

          最新隨筆

          搜索

          •  

          積分與排名

          • 積分 - 359436
          • 排名 - 153

          最新評(píng)論

          閱讀排行榜

          評(píng)論排行榜

           
          Keytool 是安全鑰匙與證書的管理工具。它管理一個(gè)存儲(chǔ)了私有鑰匙和驗(yàn)證相應(yīng)公共鑰匙的與它們相關(guān)聯(lián)的X.509 證書鏈的keystore(相當(dāng)一個(gè)數(shù)據(jù)庫)。
          Keytool 是一個(gè)有效的安全鑰匙和證書的管理工具。它能夠使用戶使用數(shù)字簽名來管理他們自己的私有/公共鑰匙對(duì),管理用來作自我鑒定的相關(guān)的證書,管理數(shù)據(jù)完整性和鑒定服務(wù)。它還能使用戶在通信時(shí)緩存它們的公共鑰匙.
          一個(gè)證書是某一實(shí)體(個(gè)人,公司等)的數(shù)字簽名,指出其他實(shí)體的公共鑰匙(或其他信息)的詳細(xì)的值.當(dāng)數(shù)據(jù)被簽名后,這個(gè)簽名信息被用來檢驗(yàn)數(shù)據(jù)的完整性和真實(shí)性.完整性指數(shù)據(jù)沒有被修改和篡改,真實(shí)性指數(shù)據(jù)從任何產(chǎn)生和簽名的一方真正的傳輸?shù)竭_(dá)。
          Keytool 把鑰匙和證書儲(chǔ)存到一個(gè)keystore.默任的實(shí)現(xiàn)keystore的是一個(gè)文件。它用一個(gè)密碼保護(hù)鑰匙。而另外的一個(gè)工具jarsigner用keystore中的信息產(chǎn)生或檢驗(yàn)Java aRchive(jar文件)中的數(shù)字簽名。
          Keystore有兩個(gè)不同的入口:
          1.       鑰匙入口:保存了非常敏感的加密的鑰匙信息,并且是用一個(gè)保護(hù)的格式存儲(chǔ)以防止未被授權(quán)的訪問.以這種形式存儲(chǔ)的鑰匙是秘密鑰匙,或是一個(gè)對(duì)應(yīng)證書鏈中公有鑰匙的私有鑰匙.
          2.    信任證書入口:包含一個(gè)屬于其他部分的單一公共鑰匙證書.它之所以被稱為"信任證書",是因?yàn)閗eystore信任的證書中的公共鑰匙真正屬于證書所有者的身份識(shí)別.
           
          Keystore的別名:
          所有的keystore入口(鑰匙和信任證書入口)是通過唯一的別名訪問.別名是不區(qū)分大小寫的。如別名Hugo和hugo指向同一個(gè)keystore入口.
          可以在加一個(gè)入口到keystore的時(shí)候使用-genkey參數(shù)來產(chǎn)生一個(gè)鑰匙對(duì)(公共鑰匙和私有鑰匙)時(shí)指定別名.也可以用-import參數(shù)加一個(gè)證書或證書鏈到信任證書。
           
          如:keytool -genkey -alias duke -keypass dukekeypasswd
           
          其中duke為別名,dukekeypasswd為duke別名的密碼。這行命令的作用是產(chǎn)生一個(gè)新的公共/私有鑰匙對(duì). 其中duke為別名,dukekeypasswd為duke別名的密碼.這行命令的作用是產(chǎn)生一個(gè)新的公共/私有鑰匙對(duì).
          假如你想修改密碼,可以用:
          keytool -keypasswd -alias duke -keypass dukekeypasswd -new newpass
          將舊密碼dukekeypasswd改為newpass.
           
          Keystore的產(chǎn)生:
          1.       當(dāng)使用-genkey 或-import或-identitydb命令添加數(shù)據(jù)到一個(gè)keystore,而當(dāng)這個(gè)keystore不存在時(shí),產(chǎn)生一個(gè)keystore.默認(rèn)名是.keystore,存放到user-home目錄.
          2.    當(dāng)用-keystore指定時(shí),將產(chǎn)生指定的keystore.
           
          Keystore的實(shí)現(xiàn):
          Keytool 類位于java.security包下,提供一個(gè)非常好的接口去取得和修改一個(gè)keystore中的信息. 目前有兩個(gè)命令行:keytool和jarsinger,一個(gè)GUI工具Policy 可以實(shí)現(xiàn)keystore.由于keystore是公開的,用戶可以用它寫一些額外的安全應(yīng)用程序。
          Keystore還有一個(gè)sun公司提供的內(nèi)在實(shí)現(xiàn).它把keystore作為一個(gè)文件來實(shí)現(xiàn).利用了一個(gè)keystore類型(格式)"JKS".它用單獨(dú)的密碼保護(hù)每一個(gè)私有鑰匙.也用可能不同的密碼保護(hù)整個(gè)keystore的完整性.
           
          支持的算法和鑰匙大小:
          keytool允許用戶指定鑰匙對(duì)和注冊(cè)密碼服務(wù)供應(yīng)者所提供的簽名算法.缺省的鑰匙對(duì)產(chǎn)生算法是"DSA"。假如私有鑰匙是"DSA"類型,缺省簽名算法是"SHA1withDSA",假如私有鑰匙是"RSA"類型,缺省算法是"MD5withRSA".
          當(dāng)產(chǎn)生一個(gè)DSA鑰匙對(duì),鑰匙必須在512-1024位之間.對(duì)任何算法的缺省鑰匙大小是1024位.
           
          1.       證書:一個(gè)證書是一個(gè)實(shí)體的數(shù)字簽名,指出其他實(shí)體的公共鑰匙有明確的值。
          2.       公共鑰匙:是同一個(gè)詳細(xì)的實(shí)體的數(shù)字關(guān)聯(lián),并有意讓所有想同這個(gè)實(shí)體發(fā)生信任關(guān)系的其他實(shí)體知道,公共鑰匙用來檢驗(yàn)簽名;
          3.    數(shù)字簽名:假如數(shù)據(jù)已被簽名,并用身份存儲(chǔ)在一個(gè)實(shí)體中,一個(gè)簽名能夠證明這個(gè)實(shí)體知道這個(gè)數(shù)據(jù).這個(gè)數(shù)據(jù)用實(shí)體私有鑰匙簽名并遞交;
          4.    身份:知道實(shí)體的方法.在一些系統(tǒng)中身份是公共鑰匙,其他系統(tǒng)中可以是從一個(gè)X.509名字的郵件地址的Unix UID來的任何東西;
          5.    簽名:一個(gè)簽名用實(shí)體私有鑰匙來計(jì)算某些加密數(shù)據(jù);
          6.    私有鑰匙:是一些數(shù)字,每一個(gè)私有鑰匙只能被特定的擁有該私有鑰匙的實(shí)體知道.私有和公共鑰匙存在所有用公共鑰匙加密的系統(tǒng)的鑰匙對(duì)中.一個(gè)公共鑰匙加密(如DSA),一個(gè)私有鑰匙與一個(gè)正確的公共鑰匙通信.私有鑰匙用來計(jì)算簽名。
          7.    實(shí)體:一個(gè)實(shí)體可以是一個(gè)人,一個(gè)組織,一個(gè)程序,一臺(tái)計(jì)算機(jī),一個(gè)商業(yè),一個(gè)銀行,或其他你想信任的東西.
           
          Keytool應(yīng)用實(shí)例:
           
          1.產(chǎn)生一個(gè)keystore:
           
          keytool -genkey -alias User(keystore的別名) -keyalg RSA -validity 7 -keystore keystore(指定keystore).
           
          運(yùn)行這個(gè)命令,系統(tǒng)提示:
          Enter keystore password:yourpassword(輸入密碼)
           
          What is your first and last name?
          [Unknown]: your name(輸入你的名字)
           
          What is the name of your organizational unit?
          [Unknown]:your organizational(輸入你所在組織單位的名字)
           
          What is the name of your organization?
          [Unknown]:your organization 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 two-letter country code for this unit?
          [Unknown]:cn(輸入國家名字)
          Is CN=your name, OU=your organizaion, O="your organization name",L=your city name, ST=your province name, C=cn correct?
          [no]: yes
           
          3.    檢查一個(gè)keystore:
          keytool -list -v -keystore keystore
          Enter keystore password:your password(輸入密碼)
           
          將顯示keystore內(nèi)容如:
          Keystore type: jks
          Keystore provider: SUN
           
          Your keystore contains 1 entry
          Alias name: yourname
          Creation date: Dec 20, 2001
          Entry type: keyEntry
          Certificate chain length: 1
          Certificate[1]:
          Owner: CN=yourname, OU=your organization, O="your organization name",
          L=your city name, ST=your province name, C=CN
          Issuer: CN=Duke, OU=Java Software, O="Sun Microsystems, Inc.", L=Palo Alto, ST=CA, C=US
          Serial number: 3c22adc1
          Valid from: Thu Dec 20 19:34:25 PST 2001 until: Thu Dec 27 19:34:25 PST 2001
          Certificate fingerprints:
          MD5: F1:5B:9B:A1:F7:16:CF:25:CF:F4:FF:35:3F:4C:9C:F0
          SHA1: B2:00:50:DD:B6:CC:35:66:21:45:0F:96:AA:AF:6A:3D:E4:03:7C:74
           
          3.輸出keystore到一個(gè)文件:testkey:
          keytool -export -alias duke -keystore keystore -rfc -file testkey
          系統(tǒng)輸出:Enter keystore password:your password(輸入密碼)
          Certificate stored in file < td>
           
          4.輸入證書到一個(gè)新的truststore:
          keytool -import -alias dukecert -file testkey -keystore truststore
          Enter keystore password:your new password.(輸入truststore新密碼)
           
           
          5.檢查truststore:
          keytool -list -v -keystore truststore
          系統(tǒng)將顯示truststore的信息.
           
          現(xiàn)在可以用適當(dāng)?shù)膋eystore運(yùn)行你的應(yīng)用程序.如:
          java -Djavax.net.ssl.keyStore = keystore
          -Djavax.net.ssl.keyStorePassword=password Server
           
          和:
           java -Djavax.net.ssl.trustStore=truststore
          -Djavax.net.ssl.trustStorePassword=trustword Client
          posted on 2008-11-05 15:11 張秀蘭 閱讀(465) 評(píng)論(0)  編輯  收藏 所屬分類: 學(xué)習(xí)園地
           
          Copyright © 張秀蘭 Powered by: 博客園 模板提供:滬江博客
          主站蜘蛛池模板: 南城县| 台江县| 安多县| 华池县| 松原市| 新田县| 隆化县| 惠州市| 开封市| 屏山县| 平昌县| 美姑县| 镇坪县| 尼木县| 南阳市| 介休市| 门源| 八宿县| 沾化县| 通河县| 搜索| 赤壁市| 广灵县| 乳山市| 永年县| 开封县| 中江县| 屏边| 江陵县| 革吉县| 宜兰县| 阜平县| 余干县| 大埔县| 德昌县| 嘉黎县| 阿勒泰市| 大同市| 黎平县| 鄄城县| 嵊州市|