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

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

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

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

    導航

    常用鏈接

    留言簿(9)

    隨筆分類(163)

    隨筆檔案(154)

    文章檔案(1)

    新聞檔案(1)

    相冊

    收藏夾(1)

    個人雜雜

    友情鏈接

    自學考試

    資料搜索

    最新隨筆

    搜索

    •  

    積分與排名

    • 積分 - 359147
    • 排名 - 153

    最新評論

    閱讀排行榜

    評論排行榜

     
    Keytool 是安全鑰匙與證書的管理工具。它管理一個存儲了私有鑰匙和驗證相應公共鑰匙的與它們相關聯的X.509 證書鏈的keystore(相當一個數據庫)。
    Keytool 是一個有效的安全鑰匙和證書的管理工具。它能夠使用戶使用數字簽名來管理他們自己的私有/公共鑰匙對,管理用來作自我鑒定的相關的證書,管理數據完整性和鑒定服務。它還能使用戶在通信時緩存它們的公共鑰匙.
    一個證書是某一實體(個人,公司等)的數字簽名,指出其他實體的公共鑰匙(或其他信息)的詳細的值.當數據被簽名后,這個簽名信息被用來檢驗數據的完整性和真實性.完整性指數據沒有被修改和篡改,真實性指數據從任何產生和簽名的一方真正的傳輸到達。
    Keytool 把鑰匙和證書儲存到一個keystore.默任的實現keystore的是一個文件。它用一個密碼保護鑰匙。而另外的一個工具jarsigner用keystore中的信息產生或檢驗Java aRchive(jar文件)中的數字簽名。
    Keystore有兩個不同的入口:
    1.       鑰匙入口:保存了非常敏感的加密的鑰匙信息,并且是用一個保護的格式存儲以防止未被授權的訪問.以這種形式存儲的鑰匙是秘密鑰匙,或是一個對應證書鏈中公有鑰匙的私有鑰匙.
    2.    信任證書入口:包含一個屬于其他部分的單一公共鑰匙證書.它之所以被稱為"信任證書",是因為keystore信任的證書中的公共鑰匙真正屬于證書所有者的身份識別.
     
    Keystore的別名:
    所有的keystore入口(鑰匙和信任證書入口)是通過唯一的別名訪問.別名是不區分大小寫的。如別名Hugo和hugo指向同一個keystore入口.
    可以在加一個入口到keystore的時候使用-genkey參數來產生一個鑰匙對(公共鑰匙和私有鑰匙)時指定別名.也可以用-import參數加一個證書或證書鏈到信任證書。
     
    如:keytool -genkey -alias duke -keypass dukekeypasswd
     
    其中duke為別名,dukekeypasswd為duke別名的密碼。這行命令的作用是產生一個新的公共/私有鑰匙對. 其中duke為別名,dukekeypasswd為duke別名的密碼.這行命令的作用是產生一個新的公共/私有鑰匙對.
    假如你想修改密碼,可以用:
    keytool -keypasswd -alias duke -keypass dukekeypasswd -new newpass
    將舊密碼dukekeypasswd改為newpass.
     
    Keystore的產生:
    1.       當使用-genkey 或-import或-identitydb命令添加數據到一個keystore,而當這個keystore不存在時,產生一個keystore.默認名是.keystore,存放到user-home目錄.
    2.    當用-keystore指定時,將產生指定的keystore.
     
    Keystore的實現:
    Keytool 類位于java.security包下,提供一個非常好的接口去取得和修改一個keystore中的信息. 目前有兩個命令行:keytool和jarsinger,一個GUI工具Policy 可以實現keystore.由于keystore是公開的,用戶可以用它寫一些額外的安全應用程序。
    Keystore還有一個sun公司提供的內在實現.它把keystore作為一個文件來實現.利用了一個keystore類型(格式)"JKS".它用單獨的密碼保護每一個私有鑰匙.也用可能不同的密碼保護整個keystore的完整性.
     
    支持的算法和鑰匙大小:
    keytool允許用戶指定鑰匙對和注冊密碼服務供應者所提供的簽名算法.缺省的鑰匙對產生算法是"DSA"。假如私有鑰匙是"DSA"類型,缺省簽名算法是"SHA1withDSA",假如私有鑰匙是"RSA"類型,缺省算法是"MD5withRSA".
    當產生一個DSA鑰匙對,鑰匙必須在512-1024位之間.對任何算法的缺省鑰匙大小是1024位.
     
    1.       證書:一個證書是一個實體的數字簽名,指出其他實體的公共鑰匙有明確的值。
    2.       公共鑰匙:是同一個詳細的實體的數字關聯,并有意讓所有想同這個實體發生信任關系的其他實體知道,公共鑰匙用來檢驗簽名;
    3.    數字簽名:假如數據已被簽名,并用身份存儲在一個實體中,一個簽名能夠證明這個實體知道這個數據.這個數據用實體私有鑰匙簽名并遞交;
    4.    身份:知道實體的方法.在一些系統中身份是公共鑰匙,其他系統中可以是從一個X.509名字的郵件地址的Unix UID來的任何東西;
    5.    簽名:一個簽名用實體私有鑰匙來計算某些加密數據;
    6.    私有鑰匙:是一些數字,每一個私有鑰匙只能被特定的擁有該私有鑰匙的實體知道.私有和公共鑰匙存在所有用公共鑰匙加密的系統的鑰匙對中.一個公共鑰匙加密(如DSA),一個私有鑰匙與一個正確的公共鑰匙通信.私有鑰匙用來計算簽名。
    7.    實體:一個實體可以是一個人,一個組織,一個程序,一臺計算機,一個商業,一個銀行,或其他你想信任的東西.
     
    Keytool應用實例:
     
    1.產生一個keystore:
     
    keytool -genkey -alias User(keystore的別名) -keyalg RSA -validity 7 -keystore keystore(指定keystore).
     
    運行這個命令,系統提示:
    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.    檢查一個keystore:
    keytool -list -v -keystore keystore
    Enter keystore password:your password(輸入密碼)
     
    將顯示keystore內容如:
    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
    系統輸出:Enter keystore password:your password(輸入密碼)
    Certificate stored in file < td>
     
    4.輸入證書到一個新的truststore:
    keytool -import -alias dukecert -file testkey -keystore truststore
    Enter keystore password:your new password.(輸入truststore新密碼)
     
     
    5.檢查truststore:
    keytool -list -v -keystore truststore
    系統將顯示truststore的信息.
     
    現在可以用適當的keystore運行你的應用程序.如:
    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 張秀蘭 閱讀(463) 評論(0)  編輯  收藏 所屬分類: 學習園地
     
    Copyright © 張秀蘭 Powered by: 博客園 模板提供:滬江博客
    主站蜘蛛池模板: 男女一边桶一边摸一边脱视频免费| 亚洲videos| 久久精品无码免费不卡| 亚洲国产一区明星换脸| 国产精品福利片免费看| 爱情岛论坛网亚洲品质自拍| 国产精品极品美女自在线观看免费| 亚洲国产av一区二区三区| 人人爽人人爽人人片A免费| 亚洲精品国精品久久99热| 国产免费福利体检区久久| 亚洲国产成人一区二区精品区| 免费网站看av片| 亚洲男人天堂影院| 日本特黄特色aa大片免费| 一级毛片免费全部播放| 亚洲成AV人片天堂网无码| 亚洲毛片在线免费观看| 亚洲熟妇无码AV不卡在线播放| 日美韩电影免费看| h片在线观看免费| 亚洲欧洲在线观看| 美女视频黄的全免费视频| 国产精品亚洲专区在线播放| 在线观看亚洲精品国产| 69视频在线观看高清免费| 亚洲熟妇成人精品一区| 国产日产亚洲系列最新| 亚洲成人免费网站| 国产精品亚洲一区二区三区久久| 中文字幕亚洲一区| 日本高清在线免费| 色一情一乱一伦一视频免费看| 亚洲第一AAAAA片| 日韩特黄特色大片免费视频| 国产做国产爱免费视频| 亚洲人xxx日本人18| 亚洲一区二区精品视频| 黄网站色在线视频免费观看| 免费无码国产在线观国内自拍中文字幕 | 亚洲国产成人久久一区WWW|