openssl 制作 信用库与服务证书

文章目录

  • 前言
    • [openssl 制作 信用库与服务证书](#openssl 制作 信用库与服务证书)
      • [1. CA 证书](#1. CA 证书)
      • [2. 服务器证书/秘钥库](#2. 服务器证书/秘钥库)
      • [3. 创建信用库](#3. 创建信用库)
      • [4. 注意事项](#4. 注意事项)

前言

如果您觉得有用的话,记得给博主点个赞,评论,收藏一键三连啊,写作不易啊^ _ ^。

而且听说点赞的人每天的运气都不会太差,实在白嫖的话,那欢迎常来啊!!!


openssl 制作 信用库与服务证书

1. CA 证书

1、生成CA私钥

bash 复制代码
openssl genrsa -out ca.key 4096

2、生成自签名CA证书

bash 复制代码
openssl req -new -x509 -key ca.key -out ca.crt -days 10000 -subj "/CN=root/OU=yzy/O=yzy/L=Beijing/ST=Beijing/C=CN"

2. 服务器证书/秘钥库

生成服务器私钥

bash 复制代码
openssl genrsa -out yzy.key 2048

生成证书csr

bash 复制代码
openssl req -new -key yzy.key -out yzy.csr -subj "/CN=www.yzy.com/OU=yzy/O=yzy/L=Beijing/ST=Beijing/C=CN"

使用CA证书进行签发

bash 复制代码
openssl x509 -req -in yzy.csr -CA ca.crt -CAkey ca.key -CAcreateserial -out yzy.crt -days 8000
bash 复制代码
* -req:表示输入的是一个证书签名请求(CSR)。
* -in yzy.csr:指定输入的 CSR 文件。
* -CA ca.crt:指定用于签名的 CA 证书。
* -CAkey ca.key:指定用于签名的 CA 私钥。
* -CAcreateserial:如果没有现成的序列号文件,创建一个新的序列号文件。
* -out yzy.crt:指定输出的已签名证书文件。
* -days 8000:指定证书的有效期为 8000 天。

生成服务端的P12证书

bash 复制代码
openssl pkcs12 -export -in yzy.crt -inkey yzy.key -out yzy.p12 -name "yzy_service" -certfile ca.crt

密码:yzy

bash 复制代码
keytool -list -v -keystore yzy.p12 -storetype pkcs12 -storepass yzy

3. 创建信用库

自定义信用库应该仅包含CA证书,用于验证客户端或其他服务器的证书

bash 复制代码
keytool -import -alias rootCa -file ca.crt -keystore root.jks -storepass  changeit
keytool -importkeystore -srckeystore root.jks -destkeystore root.p12 -deststoretype PKCS12 -srcstorepass changeit -deststorepass changeit

4. 注意事项

注意的是jdk与openssl的版本,要不然的话,会有兼容的问题,我的是
jdk 8 与 OpenSSL 1.1.1d

相关推荐
Predestination王瀞潞17 小时前
5.4.2 通信->WWW万维网内容访问标准(W3C):WWW(World Wide Web) 核心技术规范
网络·网络协议·https·www
理人综艺好会1 天前
http和https的了解
网络协议·http·https
灰子学技术1 天前
自定义 Host 头访问 HTTPS 服务时的网关处理逻辑
网络·网络协议·http·https
甘露s1 天前
从明文到加密:HTTP 与 HTTPS 的本质区别与建立全解析
网络协议·http·https
成空的梦想2 天前
ZLibrary反爬机制实战分析的技术文章大纲
网络协议·https·ssl
2501_915909062 天前
不用越狱就看不到 iOS App 内部文件?使用 Keymob 查看和导出应用数据目录
android·ios·小程序·https·uni-app·iphone·webview
小庄梦蝶2 天前
Mixed Content: The page at ‘https://域名/‘ was loaded over HTTPS
网络协议·http·https
2501_916007473 天前
HTTPS 抓包的流程,代理抓包、设备数据线直连抓包、TCP 数据分析
网络协议·tcp/ip·ios·小程序·https·uni-app·iphone
2501_915918413 天前
iOS mobileprovision 描述文件管理,新建、下载和内容查看
android·ios·小程序·https·uni-app·iphone·webview
00后程序员张3 天前
iOS 应用程序使用历史记录和耗能记录怎么查?
android·ios·小程序·https·uni-app·iphone·webview