Android网络请求之OkHtttp专题

如何创建私有 CA 并签发证书

2018-09-07  本文已影响297人  我是柯南

为什么需要自己的 CA?

基本概念

创建私有 CA 并签发证书

操作环境

Ubuntu 16.04.4 LTS (GNU/Linux 4.15.0-30-generic x86_64)
OpenSSL 1.0.2g  1 Mar 2016
  1. 将openssl.cnf 配置文件拷贝到当前目录下并创建以下在配置文件中指定的子文件夹,index.txt 为空,serial 必须写入内容,且为字符串格式的数字(比如1000)
# 准备好目录和环境
mkdir cert
cd cert
mkdir demoCA
cd demoCA
mkdir srl certs newcerts
touch index.txt serial
echo 1000 > serial
cd ..
cp /usr/lib/ssl/openssl.cnf .
  1. 生成根证书
mkdir ca
# 生成根证书私钥(key文件)
openssl genrsa -out ca/ca.key 2048
# 生成根证书签发申请文件(csr文件)
openssl req -new -key ca/ca.key -out ca/ca.csr -config ./openssl.cnf
# 自签发根证书(crt文件)
openssl x509 -req -days 3650 -sha1 -extensions v3_ca -signkey ca/ca.key -in ca/ca.csr -out ca/ca.crt
  1. 用根证书签发server端证书
mkdir server
# 生成根证书私钥(key文件)
openssl genrsa -out server/server.key 2048
# 生成根证书签发申请文件(csr文件)
openssl req -new -key server/server.key -out server/server.csr -config ./openssl.cnf
# 使用根证书签发服务端证书
openssl ca -in server/server.csr -out server/server.crt -cert ca/ca.crt -keyfile ca/ca.key -config ./openssl.cnf
# 将密钥和证书合并成一个文件
cp server/server.key server/server.pem
cat server/server.crt >> server/server.pem
  1. 创建客户端证书
mkdir client 
openssl genrsa -aes256 -out client/client.key 2048
openssl req -new -key client/client.key -out client/client.csr -config ./openssl.cnf
openssl ca -in client/client.csr -out client/client.crt -cert ca/ca.crt -keyfile ca/ca.key -config ./openssl.cnf
cp client/client.key client/client.pem
cat client/client.crt >> client/client.pem
上一篇下一篇

猜你喜欢

热点阅读