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

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

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

    心無痕的博客

    常用鏈接

    統計

    積分與排名

    JAVA技術文檔

    JAVA精典網站

    開發工具

    數據庫

    最新評論

    Keytool工具介紹

    Sun Java Keytool 基本介紹

    Keytool 是一個JAVA環境下的安全鑰匙與證書的管理工具.它管理一個存儲了私有鑰匙和驗證相應公共鑰匙的與它們相關聯的X.509 證書鏈的keystore(相當一個數據庫,里面可存放多個X.509標準的證書).

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

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

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

    Keystore有兩個不同的入口:

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

    2.信任證書入口:包含一個屬于其他部分的單一公共鑰匙證書.它之所以被稱為"信任證書",是因為keystore信任的證書中的公共鑰匙真正屬于證書所有者的身份識別.

    Keystore的別名:

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

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

    keytool -genkey -alias myssl -keypass mysslpasswd

    其中myssl為別名,mysslpasswd為myssl別名的密碼.這行命令的作用是產生一個新的公共/私有鑰匙對.

    假如你想修改密碼,可以用:

    keytool -keypasswd -alias myssl -keypass mysslpasswd -new newpass

    將舊密碼mysslpasswd改為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的完整性.

    Keystore支持的算法和鑰匙大小:

    keytool允許用戶指定鑰匙對和注冊密碼服務供應者所提供的簽名算法.缺省的鑰匙對產生算法是"DSA".假如私有鑰匙是"DSA"類型,缺省簽名算法是"SHA1withDSA",假如私有鑰匙是"RSA"類型,缺省算法是"MD5withRSA".

    當產生一個DSA鑰匙對,鑰匙必須在512-1024位之間.對任何算法的缺省鑰匙大小是1024位.

    Keytool應用實例:

    1.產生一個keystore:

    keytool -genkey -alias myssl -keyalg RSA -keystore myssl.jks

    運行這個命令,系統提示:

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

    What is your first and last name?(您的名字與姓氏是什么?)
    [Unknown]: www.myssl.cn(輸入申請的證書的域名)

    What is the name of your organizational unit? (您的組織單位名稱是什么?)
    [Unknown]:Fastcom(輸入你所在組織單位的名字)

    What is the name of your organization? (您的組織名稱是什么?)
    [Unknown]:Fastcom (輸入你所在組織的名字)

    What is the name of your City or Locality?(您所在的城市或區域名稱是什么?)
    [Unknown]:Shanghai(輸入所在城市的名字)

    What is the name of your State or Province? (您所在的州或省份名稱是什么?)
    [Unknown]:Shanghai(輸入所在省份名字)

    What is the two-letter country code for this unit?(該單位的兩字母國家代碼是什么?)
    [Unknown]:CN(輸入國家名字,如果是中國,請輸入CN)

    Is CN=www.myssl.cn, OU=fastcom, O=fastcom, L=Shanghai, ST=Shanghai, C=CN correct? [no]:
    yes

    2.檢查一個keystore:

    keytool -list -v -keystore myssl.jks

    Enter keystore password:yourpassword(輸入密碼)

    將顯示keystore內容如下:

    Keystore type: jks
    Keystore provider: SUN
    Your keystore contains 1 entry
    Alias name: myssl
    Creation date: Nov 24 , 2006
    Entry type: keyEntry
    Certificate chain length: 1
    Certificate[1]:
    Owner: CN=www.myssl.cn, OU=fatcom, O=fastcom, L=Shanghai, ST=Shanghai, C=CN
    Issuer: CN=www.myssl.cn, OU=fastcom, O=fastcom, L=Shanghai, ST=Shanghai, C=CN
    Serial number: 3c22adc1
    Valid from: Thu Nov 24 19:34:25 PST 2006 until: Thu Nov 24 19:34:25 PST 2007
    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 myssl -keystore myssl.jks -rfc -file testkey

    系統輸出:

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

    Certificate stored in file

    4.輸入證書到一個新的truststore:

    keytool -import -alias myssl -file testkey -keystore truststore

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

    5.檢查truststore:

    keytool -list -v -keystore truststore

    系統將顯示truststore的信息.

     

    Keytool命令行參數說明:

    參數 說明
    -genkey 在用戶主目錄中創建一個默認文件".keystore",還會產生一個mykey的別名,mykey中包含用戶的公鑰、私鑰和證書
    -alias 別名
    -keystore 指定密鑰庫的名稱(產生的各類信息將不在.keystore文件中
    -keyalg 指定密鑰的算法
    -validity 指定創建的證書有效期多少天
    -keysize 指定密鑰長度
    -storepass 指定密鑰庫的密碼
    -keypass 指定別名條目的密碼
    -dname 指定證書擁有者信息 例如: "CN=sagely,OU=atr,O=szu,L=sz,ST=gd,C=cn"
    -list 顯示密鑰庫中的證書詳細信息
    -export 將別名指定的證書導出到文件 keytool -export -alias caroot -file caroot.crt
    -file 參數指定導出到文件的文件名
    -delete 刪除密鑰庫中某條目
    -keypasswd 修改密鑰庫中指定條目口令 keytool -keypasswd -alias sage -keypass .... -new .... -storepass ... -keystore sage
    -import 將已簽名數字證書導入密鑰庫 keytool -import -alias sage -keystore sagely -file sagely.crt
    導入已簽名數字證書用keytool -list -v 以后可以明顯發現多了認證鏈長度,并且把整個CA鏈全部打印出來

    posted on 2008-03-13 11:02 心無痕 閱讀(3235) 評論(0)  編輯  收藏 所屬分類: JAVA

    主站蜘蛛池模板: 国产视频精品免费| 亚洲AV无码国产在丝袜线观看| 美女黄频视频大全免费的| 亚洲精品国产精品乱码不99| 最近最新高清免费中文字幕| 亚洲av成本人无码网站| 亚洲美女又黄又爽在线观看| 无码国产精品一区二区免费式影视| 国产精品亚洲一区二区三区| 亚洲AV无码国产丝袜在线观看| 最近最新的免费中文字幕| 中文成人久久久久影院免费观看| 亚洲国产av一区二区三区丶| 亚洲精品国产福利一二区| 亚洲视频免费在线看| 一级毛片免费视频网站| 亚洲国产精品专区| 亚洲小说区图片区另类春色| 免费网站看v片在线香蕉| 国产精品网站在线观看免费传媒| 亚洲欧洲免费无码| 久久精品国产亚洲av麻豆色欲| 亚洲成?Ⅴ人在线观看无码| 日本成年免费网站| 99视频在线免费观看| 美国毛片亚洲社区在线观看| 亚洲大香人伊一本线| 精品亚洲一区二区| 免费国产美女爽到喷出水来视频| 麻豆国产精品免费视频| 女同免费毛片在线播放| 成年网站免费入口在线观看| 亚洲偷自精品三十六区| 亚洲AV无码成人专区片在线观看| 又大又粗又爽a级毛片免费看| 91在线品视觉盛宴免费| 无码精品一区二区三区免费视频| 草久免费在线观看网站| 亚洲国产成人久久综合| 亚洲乱码在线视频| 亚洲日本在线播放|