`
desert3
  • 浏览: 2139568 次
  • 性别: Icon_minigender_1
  • 来自: 合肥
社区版块
存档分类
最新评论

keytool、keystore、jarsigner、生成自签名证书

 
阅读更多
Keytool是Java的密钥和数字证书管理工具,位于JDK_HOME\Bin目录下。它使用户能够管理自己的密钥对及相应证书,允许用户以证书形式发布他们的公钥信息给通信用户。发布的证书用以保护用户数据的完整性和真实性,完整性的意思是数据没有被修改或损坏过,真实性的意思是数据的确是来自声称创建了该数据和对它进行了签名的实体。

Keytool创建的证书是以别名的形式存放在证书库(keystore)中,证书库中的一条证书包含私钥,公钥和相应的主体信息。证书库中的一条证书可以导出为数字证书文件,导出的数字证书文件只包括主体信息和对应的公钥

常用操作:
  • 生成自签名证书:keytool -genkey -alias casdemo -keyalg RSA -keysize 1024 -storepass P@ssw0rd -keypass P@ssw0rd -validity 365 -keystore E:\WorkRecords\CAS\casdemo.keystore
  • 查看证书库证书:缺省情况下,-list 命令打印证书的 MD5 指纹。而如果指定了-v 选项,将以可读格式打印证书,如果指定了-rfc 选项,将以可打印的编码格式输出证书。
  • keytool -list -keystore E:\WorkRecords\CAS\casdemo.keystore -storepass P@ssw0rd

    keytool -list -v -keystore E:\WorkRecords\CAS\casdemo.keystore -storepass P@ssw0rd

    keytool -list -rfc -keystore E:\WorkRecords\CAS\casdemo.keystore -storepass P@ssw0rd
  • 删除证书库证书:keytool -delete -alias casdemo -keystore E:\WorkRecords\CAS\casdemo.keystore -storepass P@ssw0rd
  • 导出证书库证书:keytool -export -alias casdemo -keystore E:\WorkRecords\CAS\casdemo.keystore -file E:\WorkRecords\CAS\casdemo.crt -storepass P@ssw0rd
  • 查看导出的证书信息:keytool -printcert -file E:\WorkRecords\CAS\casdemo.crt
  • 修改证书库访问密码:keytool -storepasswd -keystore E:\WorkRecords\CAS\casdemo.keystore -storepass sP@ssw0rd -new P@ssw0rd
  • 修改证书库指定证书的密码(私钥):keytool -keypasswd -alias casdemo -keystore E:\WorkRecords\CAS\casdemo.keystore -storepass P@ssw0rd -keypass kP@ssw0rd -new P@ssw0rd
  • 导入证书:keytool -import -alias casdemo -keystore %JAVA_HOME%\jre\lib\security\cacerts -file E:\WorkRecords\CAS\casdemo.crt
  • %JAVA_HOME%/jre/lib/security/cacerts为java自带的证书库,默认密码为changeit


常用参数:
  • -alias 别名,证书库中的每条证书以别名来区分,这个alias通常不区分大小写。
  • -keystore 证书库文件路径和名字
  • -keyalg 指定生成密钥对的算法(如RSA DSA,默认值为:DSA)
  • -keysize 指定密钥长度 (默认 1024)
  • -validity 指定创建的证书有效期多少天(默认 90)
  • -storepass 指定证书库的访问密码
  • -keypass 指定证书库中指定条目证书的私钥密码
  • -dname 表示证书的Distinguished Names发行者信息。其中"CN=commonName证书名(一般是网站的域名),OU=organizationUnit组织单位名称,O=organizationName组织名称,L=localityName城市或区域名,S=stateName州或省份名称,C=country两位的母国家代码"
  • -file 导出的证书位置(包含公钥和主题信息的证书)
  • -v 显示证书库中的证书详细信息
  • -rfc 以可打印的编码格式输出证书详细信息

相关参数默认值:
  • -alias "mykey"
  • -keyalg "DSA"
  • -keysize 1024
  • -validity 90
  • -keystore the file named .keystore in the user's home directory
  • -file stdin if reading, stdout if writing
  • The signature algorithm (-sigalg option) is derived from the algorithm of the underlying private key: If the underlying private key is of type "DSA", the -sigalg option defaults to "SHA1withDSA", and if the underlying private key is of type "RSA", -sigalg defaults to "MD5withRSA".

Keystore在java中的实现:
Keytool类位于java.security包下,提供一个非常好的接口去取得和修改一个keystore中的信息. 目前有两个命令行:keytool和jarsinger,一个GUI工具Policy 可以实现keystore.由于keystore是公开的,用户可以用它写一些额外的安全应用程序.
Keystore还有一个sun公司提供的內在实现.它把keystore作为一个文件来实现.利用了一个keystore类型(格式)"JKS".它用单独的密码保护每一个私有钥匙.也用可能不同的密码保护整个keystore的完整性.

Keystore证书库中有两种不同类型的项:
  密钥项 - 每项存放极为敏感的加密密钥信息,这种信息以一种受保护的格式储存以防止未授权的访问。通常,储存在这类项中的密钥是机密密钥,或是伴有用于认证相应公钥用的证书“链”的私钥。keytool 和 jarsigner 工具只处理后一类型的项,即私钥及其关联的证书链。
   可信任的证书项 - 每项包含一个属于另一团体的公钥证书。它之所以叫做“可信任的证书”,是因为密钥仓库的拥有者相信证书中的公钥确实属于证书“主体”(拥有者)识别的身份。证书签发人通过对证书签名来保证这点。

证书:(也叫公钥证书)是来自某个实体(签发人)的经数字签名的声明,它声明另一实体(主体)的公钥(及其它信息)具有某一特定的值。
  • 公钥: 是与特定实体相关联的数字。所有需要与该实体进行信任交互的人都应知道该数字。公钥用于校验签名。
  • 数字签名: 如果某些数据经数字签名,说明它们已与某一实体的“身份”存储在一起,而且证明该实体的签名知道这些数据。通过用该实体的私钥进行绘制,这些数据就是不可伪造的了。
  • 签名: 用实体私有钥匙加密某些消息,从而得到加密数据;
  • 私钥: 是一些数字,私有和公共钥匙存在所有用公共钥匙加密的系统的钥匙对中.公共钥匙用来加密数据,私有钥匙用来计算签名.公钥加密的消息只能用私钥解密,私钥签名的消息只能用公钥检验签名。
  • 实体: 一个实体可以是一个人,一个组织,一个程序,一台计算机,一个商业,一个银行,或其他你想信任的东西.


jarsigner 工具利用证书库中的信息来产生或校验 Java 存档 (JAR) 文件的数字签名 (JAR 文件将类文件、图象、声音和/或其它数字化数据打包在一个文件中)。jarsigner 用 JAR 文件所附带的证书(包含于 JAR 文件的签名块文件中)来校验 JAR 文件的数字签名,然后检查该证书的公钥是否“可信任”,即是否包括在指定的证书库中。

keytool 和 jarsigner 工具完全取代了 JDK 1.1 中提供的 javakey 工具。这些新工具所提供的功能比 javakey 提供的多,包括能够用口令来保护证书库和私钥,以及除了能够生成签名外还可以校验它们。新的证书库体系结构取代了 javakey 所创建和管理的身份数据库。可以利用 -identitydb keytool 命令将信息从身份数据库导入证书库。

参考:
java keytool证书工具使用小结
Java keytool命令说明
keytool密钥和证书管理工具-使用详解(整理)
jdk1.4.2 keytool
jdk1.6 keytool
jdk1.7 keytool
  • 大小: 8.2 KB
  • 大小: 4.4 KB
  • 大小: 9.7 KB
  • 大小: 16.7 KB
  • 大小: 2.7 KB
  • 大小: 6.2 KB
  • 大小: 8.7 KB
分享到:
评论

相关推荐

    keystore-explorer:KeyStore Explorer是Java命令行实用程序keytool和jarsigner的免费GUI替代品

    生成具有自签名X.509证书的RSA,ECC和DSA密钥对 将X.509证书扩展名应用于生成的密钥对和证书签名请求(CSR) 查看X.509证书,CRL和CRL条目X.509 V3扩展 以多种格式导入和导出密钥和证书:PKCS#12,PKCS#8,PKCS#...

    kse-543.dmg keystore-explorer: 5.4.3

    KeyStore Explorer是Java命令行实用程序keytool和jarsigner的开源GUI替代。 KeyStore Explorer通过直观的图形用户界面展示其功能以及更多功能。 安全Java的简化开发软件开发人员应该能够专注于眼前的问题,而不必为...

    Android签名工具(keytool)

    下载该文件后利用JDK中jarsigner工具生成签名文件 将位置定位在jdk的bin文件中,输入以下命名行: keytool -genkey -alias ChangeBackgroundWid get.keystore -keyalg RSA -validity 20000 -eystore ...

    android反编译工具

    2、可以自作自己的证书【用于自作的证书签名专属自己的apk】,自己生成的证书请放在 keystore文件夹下(名字:asaiAndroid.keystore) 3、可以修改渠道号(提供DOMForXMLParser源码,需要知道原渠道号写入位置,自己...

    Windows KeyStore Explorer

    KeyStore Explorer is an open source GUI replacement for the Java command-line utilities keytool and jarsigner. KeyStore Explorer presents their functionality, and more, via an intuitive graphical user...

    android应用签名详细步骤

    1、准备工作apk的签名工作可以通过两种方式来完成: 1)通过ADT提供的图形化界面完成apk签名;右键项目——》 Android Tools ——》Export...1)keytool:生成数字证书,即密钥,也就是上面说到的扩展名为.keystore的那

    kse-552-setup.exe免费下载

    KeyStore Explorer is an open source GUI replacement for the Java command-line utilities keytool and jarsigner. KeyStore Explorer presents their functionality, and more, via an intuitive graphical user...

    kse-543-setup.exe

    .KeyStore Explorer是Java命令行工具(Keytool和jarsigner)的开源图形用户界面(GUI)替代品。 它通过直观的图形用户界面展示了它们的功能以及更多功能,一句话概括 提供查看管理证书与公私钥的工具

    applet数字签名

    7、// 签名:verbose输出详细信息,certs表示验证此jar包时输出证书信息。 jarsigner -verbose -certs jxl.jar tlx(别名) // 输入密钥库的口令短语:测试密码为:19860315 // 输入 tlx 的密钥口令:测试密码为:...

    js 动态调用 applet 内的方法示例程序

    步骤四:数字验证:jarsigner -keystore yourkey asbAttachmentUploadApplet.jar 对 asbAttachmentUploadApplet.jar 进行数字验证; 步骤五:将通过数字签名的 asbAttachmentUploadApplet.jar 拷贝至你项目自定义...

    ionic混合开发APP

    3.1.4.1 生成签名文件 keytool -genkey -v -keystore testapp.keystore -alias testapp.keystore -keyalg RSA -validity 20000 3.1.4.2 apk签名 jarsigner -verbose -keystore testapp.keystore -signedjar...

    fdorid-repo:我自己的 fdroid 仓库

    #####创建一个keystore keytool -genkey -alias alias-name -keystore keystore-name #####Sign jar jarsigner -keystore keystore-name -storepass keystore-password -keypass key-password index.jar alias-name

    apk工具包附带反编译apk完整步骤

    工具清单: apktool_2.3.3.jar 打包/解包APK程序 smali.xml Notepad++ smali语言模板 ...jarsigner -verbose -sigalg SHA1withRSA -digestalg SHA1 -keystore "xxx.jks" -signedjar abc_signed.apk ".\abc.apk" "xxx

    Java 2平台安全技术-结构,API设计和实现

    7.3.9 java.security.KeyStore 130 7.4 随机性和种子产生器 131 7.5 代码实例 132 7.5.1 实例1:计算消息摘要 132 7.5.2 实例2:产生公钥/私钥对 133 7.5.3 实例3:产生并且验证签名 134 7.5.4 实例4:读取包含证书的...

    JAVA 2平台安全技术-结构,API设计和实现

    7.3.9 java.security.KeyStore 130 7.4 随机性和种子产生器 131 7.5 代码实例 132 7.5.1 实例1:计算消息摘要 132 7.5.2 实例2:产生公钥/私钥对 133 7.5.3 实例3:产生并且验证签名 134 7.5.4 实例4:读取包含证书的...

    BBCloud-frontend

    genkey -v -keystore my-release-key.jks- keyalg RSA -keysize 2048 -validity 10000 -alias my-alias jarsigner -verbose -sigalg SHA1withRSA -digestalg SHA1 -keystore my-release-key.jks app-release-...

    marketplace-phonegap

    需要配置的环境变量 ...keytool -genkey -v -keystore .keystore -alias -keyalg RSA -keysize 2048 -validity 科尔多瓦构建--发布android jarsigner -verbose -sigalg SHA1withRSA -digestalg SHA1 -

    app-cms-tornese-comunidade

    离子科尔多瓦资源 -passo 0-Quandonãotem a chave香ar keytool -genkey -v -keystore debug.keystore -storepass cmsappapp -alias androiddebugkey -keypass cmsapp -keyalg RSA -keysize 2048 -validity 10000 -...

Global site tag (gtag.js) - Google Analytics