OpenSSL 生成CA证书及终端用户证书

迈不过友情╰ 2022-11-29 12:54 451阅读 0赞

一、环境

  • OpenSSL 1.0.2k
  • FireFox 60.0 64位
  • Chrome 66.0.3359.181 (正式版本)(32位)
  • Internet Explorer 11.2248.14393.0
  • Websocketd 0.3.0
  • Nginx 1.12.2

二、生成CA根证书

1、准备ca配置文件,得到ca.conf

  1. $ vim ca.conf

内容如下:

  1. [ req ]
  2. default_bits = 4096
  3. distinguished_name = req_distinguished_name
  4. [ req_distinguished_name ]
  5. countryName = Country Name (2 letter code)
  6. countryName_default = CN
  7. stateOrProvinceName = State or Province Name (full name)
  8. stateOrProvinceName_default = JiangSu
  9. localityName = Locality Name (eg, city)
  10. localityName_default = NanJing
  11. organizationName = Organization Name (eg, company)
  12. organizationName_default = Sheld
  13. commonName = Common Name (e.g. server FQDN or YOUR name)
  14. commonName_max = 64
  15. commonName_default = Ted CA Test

2、生成ca秘钥,得到ca.key

  1. $ openssl genrsa -out ca.key 4096

3、生成ca证书签发请求,得到ca.csr

  1. $ openssl req -new -sha256 -out ca.csr -key ca.key -config ca.conf

配置文件中已经有默认值了,shell交互时一路回车就行。

4、生成ca根证书,得到ca.crt

  1. $ openssl x509 -req -days 3650 -in ca.csr -signkey ca.key -out ca.crt

三、生成服务端证书

1、配置文件

准备配置文件,得到server.conf,内容如下:

  1. [ req ]
  2. default_bits = 2048
  3. distinguished_name = req_distinguished_name
  4. req_extensions = req_ext
  5. [ req_distinguished_name ]
  6. countryName = Country Name (2 letter code)
  7. countryName_default = CN
  8. stateOrProvinceName = State or Province Name (full name)
  9. stateOrProvinceName_default = JiangSu
  10. localityName = Locality Name (eg, city)
  11. localityName_default = NanJing
  12. organizationName = Organization Name (eg, company)
  13. organizationName_default = Sheld
  14. commonName = Common Name (e.g. server FQDN or YOUR name)
  15. commonName_max = 64
  16. commonName_default = www.ted2018.com
  17. [ req_ext ]
  18. subjectAltName = @alt_names
  19. [alt_names]
  20. DNS.1 = www.ted-go.com
  21. DNS.2 = www.ted2018.com
  22. IP = 192.168.93.145

Chrome 58以后不再使用CN校验地址(就是就是浏览器地址栏URL中的那个地址host)了,而是使用SAN,注意配置里写对,IE 11还是使用CN

2、服务端密钥

生成秘钥,得到server.key,命令如下:

  1. $ openssl genrsa -out server.key 2048

3、服务端CSR

  1. $ openssl req -new -sha256 -out server.csr -key server.key -config server.conf

配置文件中已经有默认值了,shell交互时一路回车就行。

4、服务端证书

用CA证书生成终端用户证书,得到server.crt

  1. $ openssl x509 -req -days 3650 -CA ca.crt -CAkey ca.key -CAcreateserial -in server.csr -out server.crt -extensions req_ext -extfile server.conf

四、验证

1、配置web服务器

Web服务器选用nginx,关键配置如下:

  1. server {
  2. listen 443 ssl;
  3. server_name localhost;
  4. root D:\websocketd-0.3.0-windows_amd64;
  5. ssl_certificate server.crt;
  6. ssl_certificate_key server.key;
  7. ssl_session_cache shared:SSL:1m;
  8. ssl_session_timeout 5m;
  9. ssl_ciphers HIGH:!aNULL:!MD5;
  10. ssl_prefer_server_ciphers on;
  11. location / {
  12. index index.html index.htm;
  13. }
  14. }

把生成好的server.crt和server.key文件放在与 nginx.conf 同级目录下,然后启动nginx。

2、改hosts

在 /etc/hosts 文件中添加以下内容:

  1. 127.0.0.1 www.ted2018.com

3、添加CA根证书

浏览器右键 ca.crt 安装,安装到“受信任的根证书颁发机构”(不然server.crt还是不受信任的)

4、Google浏览器验证

Chrome浏览器访问https://www.ted2018.com

watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzE5NzM0NTk3_size_16_color_FFFFFF_t_70

watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzE5NzM0NTk3_size_16_color_FFFFFF_t_70 1

20200821104423527.png

Google 浏览器无警告,访问成功。

5、FireFox配置

火狐浏览器—选项—隐私与安全—证书—查看证书—证书颁发机构—导入,把CA根证书ca.crt导入进来,选中该证书,编辑信任,勾选“此证书可以标识网站”。

watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzE5NzM0NTk3_size_16_color_FFFFFF_t_70 2

FireFox 浏览器访问https://www.ted2018.com

watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzE5NzM0NTk3_size_16_color_FFFFFF_t_70 3

FireFox 浏览器无警告,访问成功。

6、IE11配置

IE11访问https://www.ted2018.com

watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzE5NzM0NTk3_size_16_color_FFFFFF_t_70 4

IE11 浏览器无警告,访问成功。

到此 OpenSSL 生成CA证书及终端用户证书介绍完成。

发表评论

表情:
评论列表 (有 0 条评论,451人围观)

还没有评论,来说两句吧...

相关阅读