`

java key tool 生成ca证书

    博客分类:
  • java
 
阅读更多

keytool生成证书

验证是否已创建过同名的证书
keytool -list -v -alias tomcat -keystore "%JAVA_HOME%/JRE/LIB/SECURITY/CACERTS" -storepass changeit
删除已创建的证书
keytool -delete -alias tomcat -keystore "%JAVA_HOME%/JRE/LIB/SECURITY/CACERTS" -storepass changeit

创建证书
1.服务器中生成证书:(注:生成证书时,CN要和服务器的域名相同,如果在本地测试,则使用localhost)
keytool -genkey -alias tomcat -keyalg RSA -keystore d:\mykeystore -dname "CN=localhost, OU=localhost, O=localhost, L=SH, ST=SH, C=CN" -keypass changeit -

storepass changeit
2.导出证书,由客户端安装:
keytool -export -alias tomcat -keystore d:\mykeystore -file d:\mycerts.cer -storepass changeit
3.客户端配置:为客户端的JVM导入密钥(将服务器下发的证书导入到JVM中)
keytool -import -trustcacerts -alias tomcat -keystore "%JAVA_HOME%/JRE/LIB/SECURITY/CACERTS" -file d:\mycerts.cer -storepass changeit

常出现的异常:“未找到可信任的证书”--主要原因为在客户端未将服务器下发的证书导入到JVM中,可以用
keytool -list -alias tomcat -keystore "%JAVA_HOME%/JRE/LIB/SECURITY/CACERTS" -storepass changeit
来查看证书是否真的导入到JVM中。

Keytool是一个Java数据证书的管理工具。 

keystore 
Keytool将密钥(key)和证书(certificates)存在一个称为keystore的文件中 
在keystore里,包含两种数据: 
密钥实体(Key entity)——密钥(secret key)又或者是私钥和配对公钥(采用非对称加密) 
可信任的证书实体(trusted certificate entries)——只包含公钥 

Alias(别名) 
每个keystore都关联这一个独一无二的alias,这个alias通常不区分大小写 

keystore的存储位置 
在没有制定生成位置的情况下,keystore会存在与用户的系统默认目录, 
如:对于window xp系统,会生成在系统的C:\Documents and Settings\UserName\ 
文件名为“.keystore” 

keystore的生成

引用

keytool -genkey -alias tomcat -keyalg RSA   -keystore d:\mykeystore -dname "CN=localhost, OU=localhost, O=localhost, L=SH, ST=SH, C=CN" -keypass changeit -storepass -validity 180

参数说明: 
-genkey表示要创建一个新的密钥 
-dname表示密钥的Distinguished Names, 
CN=commonName 
OU=organizationUnit 
O=organizationName 
L=localityName 
S=stateName 
C=country 
Distinguished Names表明了密钥的发行者身份 
-keyalg使用加密的算法,这里是RSA 
-alias密钥的别名 
-keypass私有密钥的密码,这里设置为changeit
-keystore 密钥保存在D:盘目录下的mykeystore文件中 
-storepass 存取密码,这里设置为changeit,这个密码提供系统从mykeystore文件中将信息取出 
-validity该密钥的有效期为 180天 (默认为90天)

cacerts证书文件(The cacerts Certificates File) 
改证书文件存在于java.home\lib\security目录下,是Java系统的CA证书仓库 

创建证书
1.服务器中生成证书:(注:生成证书时,CN要和服务器的域名相同,如果在本地测试,则使用localhost)
keytool -genkey -alias tomcat -keyalg RSA -keystore d:\mykeystore -dname "CN=localhost, OU=localhost, O=localhost, L=SH, ST=SH, C=CN" -keypass changeit -storepass changeit
2.导出证书,由客户端安装:
keytool -export -alias tomcat -keystore d:\mykeystore -file d:\mycerts.cer -storepass changeit
3.客户端配置:为客户端的JVM导入密钥(将服务器下发的证书导入到JVM中)
keytool -import -trustcacerts -alias tomcat -keystore "%JAVA_HOME%/JRE/LIB/SECURITY/CACERTS" -file d:\mycerts.cer -storepass changeit
生成的证书可以交付客户端用户使用,用以进行SSL通讯,或者伴随电子签名的jar包进行发布者的身份认证。

https站点密码验证使用弱口令:

现象:在Windows Vista上浏览一个被配置成使用弱密码(40位/56位加密)的HTTPS站点时,显示一个错误页面。

原因:在Windows Vista中,默认已经关闭了弱密码,仅开启强密码。

在生成证书选择加密方式 RSA

解决办法:对于访问者没有办法解决,只能等待https站点管理员修改验证使用的弱口令。

keytool生成根证书时出现如下错误:

keytool错误:java.io.IOException:keystore was tampered with,or password was incorrect

原因是在你的home目录下是否还有.keystore存在。如果存在那么把他删除掉,后再执行

或者删除"%JAVA_HOME%/JRE/LIB/SECURITY/CACERTS 再执行

分享到:
评论

相关推荐

    KeyTool.GUI.1.6 证书密钥查看生成工具

    KeyTool.GUI.1.6 是一个用于管理和操作Java keystore的图形用户界面工具,它使得证书和密钥的查看、生成以及管理变得更加直观和便捷。在IT领域,尤其是在网络安全和服务器配置中,证书和密钥扮演着至关重要的角色。...

    基于java的开发源码-密钥管理工具 Keytool-IUI.zip

    Keytool的全名是“Java Key Tool”,它被集成在Java Development Kit (JDK) 中,提供了生成、存储和管理密钥对、证书请求以及导入和导出证书的功能。在Java应用程序中实现安全的HTTPS连接、SSL/TLS协议或数字签名时...

    KeyTool_GUI

    2. **密钥库**:KeyTool管理的密钥和证书存储在称为密钥库的文件中,常见的格式有JKS(Java Key Store)和PKCS12。 3. **证书请求**:KeyTool可以创建证书请求(CSR,Certificate Signing Request),然后发送给...

    基于java的keytool GUI 图形工具

    如果证书是由知名的证书颁发机构(CA)签发,通常不会有此问题。 4. **更新与维护**:定期检查Keystore中的证书有效期,及时更新或替换即将过期的证书。 总的来说,基于Java的Keytool GUI工具为处理数字证书和密钥...

    Keystore Tool v0.1

    综上所述,Java Keystore工具,特别是"Keystore Tool v0.1",是Java开发者和系统管理员进行安全配置不可或缺的工具,它简化了证书管理,促进了网络服务的安全实施。理解并熟练运用Keystore工具对于维护安全的网络...

    Portal SSL 配置(支持PKI SSO登录,中文)

    该配置主要利用WebSphere Application Server (WAS)与WebSphere Portal的LTPA(Lightweight Third-Party Authentication)机制,结合SSL和CA证书实现用户认证。SSL确保了网络通信的加密,而PKI SSO则允许用户只需一...

    Certificates

    在Java开发中,证书的管理是通过Java Cryptography Extension (JCE) 和 Java Key Tool (keytool) 实现的。Java应用可能会需要自己的自签名证书或者从受信任的证书颁发机构(CA)获取证书来实现服务器的身份验证。Java...

    android bks

    `keytool`是Java SDK自带的工具,可以用于管理KeyStore,包括生成新的KeyPair、导入已有的证书等操作。在Android环境下,`keytool`可以生成BKS类型的KeyStore文件,例如: ```bash keytool -importkeystore -...

    安装weblogic设置ssl归纳.pdf

    接着,生成证书签名请求(CSR)文件,提交给证书颁发机构(CA)以获取数字证书。例如: ``` keytool -certreq -keyalg RSA -alias myserver -file certreq.csr -keystore keystore.jks ``` 5.3 拷贝密钥库和私密文件到...

    CSRTool-开源

    3. **证书整合**:CSRTool还允许用户将生成的密钥对与已签发的数字证书结合,创建各种安全的便携式容器,如PKCS12、JKS(Java Key Store)和JCEKS(Java Cryptography Extension Key Store)。这些容器便于密钥和...

Global site tag (gtag.js) - Google Analytics