<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    Junky's IT Notebook

    統(tǒng)計(jì)

    留言簿(8)

    積分與排名

    WebSphere Studio

    閱讀排行榜

    評論排行榜

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

    Keytool 是安全鑰匙與證書的管理工具.它管理一個存儲了私有鑰匙和驗(yàn)證相應(yīng)公共鑰匙的與它們相關(guān)聯(lián)的X.509 證書鏈的keystore(相當(dāng)一個數(shù)據(jù)庫).

    Keytool 是一個有效的安全鑰匙和證書的管理工具. 它能夠使用戶使用數(shù)字簽名來管理他們自己的私有/公共鑰匙對,管理用來作自我鑒定的相關(guān)的證書,管理數(shù)據(jù)完整性和鑒定服務(wù).它還能使用戶在通信時緩存它們的公共鑰匙.

    一個證書是某一實(shí)體(個人,公司等)的數(shù)字簽名,指出其他實(shí)體的公共鑰匙(或其他信息)的詳細(xì)的值.當(dāng)數(shù)據(jù)被簽名后,這個簽名信息被用來檢驗(yàn)數(shù)據(jù)的完整性和真實(shí)性.完整性指數(shù)據(jù)沒有被修改和篡改,真實(shí)性指數(shù)據(jù)從任何產(chǎn)生和簽名的一方真正的傳輸?shù)竭_(dá).

    Keytool 把鑰匙和證書儲存到一個keystore.默任的實(shí)現(xiàn)keystore的是一個文件.它用一個密碼保護(hù)鑰匙.

    而另外的一個工具jarsigner用keystore中的信息產(chǎn)生或檢驗(yàn)Java aRchive(jar文件)中的數(shù)字簽名.

    Keystore有兩個不同的入口:
    1.鑰匙入口:保存了非常敏感的加密的鑰匙信息,并且是用一個保護(hù)的格式存儲以防止未被授權(quán)的訪問.以這種形式存儲的鑰匙是秘密鑰匙,或是一個對應(yīng)證書鏈中公有鑰匙的私有鑰匙.
    2.信任證書入口:包含一個屬于其他部分的單一公共鑰匙證書.它之所以被稱為"信任證書",是因?yàn)閗eystore信任的證書中的公共鑰匙真正屬于證書所有者的身份識別.

    Keystore的別名:
    所有的keystore入口(鑰匙和信任證書入口)是通過唯一的別名訪問.別名是 不區(qū)分大小寫的.如別名Hugo和hugo指向同一個keystore入口.
    可以在加一個入口到keystore的時候使用-genkey參數(shù)來產(chǎn)生一個鑰匙對(公共鑰匙和私有鑰匙)時指定別名.也可以用-import參數(shù)加一個證書或證書鏈到信任證書.
    如:
    keytool -genkey -alias duke -keypass dukekeypasswd
    其中duke為別名,dukekeypasswd為duke別名的密碼.這行命令的作用是產(chǎn)生一個新的公共/私有鑰匙對.

    假如你想修改密碼,可以用:
    keytool -keypasswd -alias duke -keypass dukekeypasswd -new newpass
    將舊密碼dukekeypasswd改為newpass.

    Keystore的產(chǎn)生:
    1.當(dāng)使用-genkey 或-import或-identitydb命令添加數(shù)據(jù)到一個keystore,而當(dāng)這個keystore不存在時,產(chǎn)生一個keystore.默認(rèn)名是.keystore,存放到user-home目錄.
    2.當(dāng)用-keystore指定時,將產(chǎn)生指定的keystore.

    Keystore的實(shí)現(xiàn):
    Keytool 類位于java.security包下,提供一個非常好的接口去取得和修改一個keystore中的信息. 目前有兩個命令行:keytool和jarsinger,一個GUI工具Policy 可以實(shí)現(xiàn)keystore.由于keystore是公開的,用戶可以用它寫一些額外的安全應(yīng)用程序.
    Keystore還有一個sun公司提供的內(nèi)在實(shí)現(xiàn).它把keystore作為一個文件來實(shí)現(xiàn).利用了一個keystore類型(格式)"JKS".它用單獨(dú)的密碼保護(hù)每一個私有鑰匙.也用可能不同的密碼保護(hù)整個keystore的完整性.

    支持的算法和鑰匙大小:
    keytool允許用戶指定鑰匙對和注冊密碼服務(wù)供應(yīng)者所提供的簽名算法.缺省的鑰匙對產(chǎn)生算法是"DSA".假如私有鑰匙是"DSA"類型,缺省簽名算法是"SHA1withDSA",假如私有鑰匙是"RSA"類型,缺省算法是"MD5withRSA".
    當(dāng)產(chǎn)生一個DSA鑰匙對,鑰匙必須在512-1024位之間.對任何算法的缺省鑰匙大小是1024位.

    證書:
    一個證書是一個實(shí)體的數(shù)字簽名,指出其他實(shí)體的公共鑰匙有明確的值.
    1.公共鑰匙 :是同一個詳細(xì)的實(shí)體的數(shù)字關(guān)聯(lián),并有意讓所有想同這個實(shí)體發(fā)生信任關(guān)系的其他實(shí)體知道.公共鑰匙用來檢驗(yàn)簽名;
    2.數(shù)字簽名:假如數(shù)據(jù)已被簽名,并用身份存儲在一個實(shí)體中,一個簽名能夠證明這個實(shí)體知道這個數(shù)據(jù).這個數(shù)據(jù)用實(shí)體私有鑰匙簽名并遞交;
    3.身份:知道實(shí)體的方法.在一些系統(tǒng)中身份是公共鑰匙,其他系統(tǒng)中可以是從一個X.509名字的郵件地址的Unix UID來的任何東西;
    4.簽名:一個簽名用用實(shí)體私有鑰匙來計(jì)算某些加密數(shù)據(jù);
    5.私有鑰匙:是一些數(shù)字,每一個私有鑰匙只能被特定的擁有該私有鑰匙的實(shí)體知道.私有和公共鑰匙存在所有用公共鑰匙加密的系統(tǒng)的鑰匙對中.一個公共鑰匙加密(如DSA),一個私有鑰匙與一個正確的公共鑰匙通信.私有鑰匙用來計(jì)算簽名.
    6.實(shí)體:一個實(shí)體可以是一個人,一個組織,一個程序,一臺計(jì)算機(jī),一個商業(yè),一個銀行,或其他你想信任的東西.

    Keytool應(yīng)用實(shí)例:

    1.產(chǎn)生一個keystore:
    keytool -genkey -alias User(keystore的別名) -keyalg RSA -validity 7 -keystore keystore(指定keystore).
    運(yùn)行這個命令,系統(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

    2.檢查一個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到一個文件:testkey:
    keytool -export -alias duke -keystore keystore -rfc -file testkey
    系統(tǒng)輸出:
    Enter keystore password:your password(輸入密碼)
    Certificate stored in file

    4.輸入證書到一個新的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 2007-05-22 14:00 junky 閱讀(401) 評論(0)  編輯  收藏 所屬分類: security

    主站蜘蛛池模板: 香蕉免费看一区二区三区| 在线免费中文字幕| 久久久综合亚洲色一区二区三区| 久久亚洲精品无码gv| 伊人久久亚洲综合| 91av免费观看| 国产成人亚洲午夜电影| 亚洲AV无码专区国产乱码4SE| 1000部拍拍拍18免费网站| 无码天堂va亚洲va在线va| 久久精品国产亚洲av麻豆色欲| 在线a毛片免费视频观看| 两个人日本免费完整版在线观看1| 久久亚洲AV成人出白浆无码国产| 日韩精品视频免费在线观看| 东方aⅴ免费观看久久av| 亚洲色偷偷综合亚洲AV伊人蜜桃| 最新精品亚洲成a人在线观看| 噼里啪啦电影在线观看免费高清| 国产黄在线播放免费观看| 亚洲偷自精品三十六区| 国产亚洲精品成人AA片新蒲金| 成年女人免费v片| 日韩精品无码免费专区午夜不卡| 亚洲精品无码久久久久YW| 久久精品亚洲中文字幕无码网站| 精品国产免费观看久久久| 无码囯产精品一区二区免费| 色婷婷精品免费视频| 亚洲天堂中文字幕在线观看| 国产亚洲精品国产| 亚洲av片一区二区三区| 91在线品视觉盛宴免费| 国产免费一区二区三区在线观看| 男男gay做爽爽的视频免费| 亚洲av无码电影网| 亚洲天天在线日亚洲洲精| 亚洲人成色77777| 亚洲国产综合精品一区在线播放| 和日本免费不卡在线v| 99xxoo视频在线永久免费观看|