SSL证书--手动生成自签名IP证书

原文网址:SSL证书--手动生成自签名IP证书-CSDN博客

简介

本文介绍手动生成自签名SSL证书的方法。

目标:用服务器的IP生成一个SSL证书,将证书时间设置的长一些,比如:十年。

本文使用openssl生成一个10年的SSL证书。openssl一般Ubuntu或Centos都会自带,如果没自带,自行安装即可。

这样,别人直接用https://ip的形式即可访问

1.新建证书配置文件

新建openssl.cfg,内容如下:

复制代码
[req]
distinguished_name = req_distinguished_name
req_extensions = v3_req

[req_distinguished_name]
countryName = Country Name (2 letter code)
countryName_default = CN
stateOrProvinceName = State or Province Name (full name)
stateOrProvinceName_default = GD
localityName = Locality Name (eg, city)
localityName_default = ShenZhen
organizationalUnitName  = Organizational Unit Name (eg, section)
organizationalUnitName_default  = organizationalUnitName
commonName = Internet Widgits Ltd
commonName_max  = 64

[ v3_req ]
# Extensions to add to a certificate request
basicConstraints = CA:FALSE
keyUsage = nonRepudiation, digitalSignature, keyEncipherment
subjectAltName = @alt_names

[alt_names]

# 这里可以指定域名,本处不要写域名,只写下边的ip即可!
#DNS.1 = kb.example.com
#DNS.2 = helpdesk.example.org
#DNS.3 = systems.example.net

# 改成自己的ip
IP.1 = 172.16.24.143
IP.2 = 172.16.24.85

2.生成私钥

本处生成名为test.key的私钥:

复制代码
openssl genrsa -out test.key 2048

执行完之后,会在当前目录下生成test.key文件

3.生成创建CSR文件

本处生成名为test.csr的文件:

复制代码
openssl req -new -out test.csr -key test.key -config openssl.cfg

执行后,系统会提示输入组织等信息,可以直接回车,使用默认值。也可以按提示输入,比如:

上边命令提示里有XXX ,这是默认配置,在"1.新建证书配置文件"里的openssl.cfg文件可配置。

测试CSR文件是否生成成功,可以使用下面的命令检测是否成功:

复制代码
openssl req -text -noout -in test.csr

执行后会输出下边这样的结果:

复制代码
Certificate Request:
    Data:
        Version: 1 (0x0)
        Subject: C = CN, ST = ZJ, L = HangZhou, OU = IT\C3\A9\C2\9B\C2\86\C3\A5\C2\9B\C2\A2, CN = IT
        Subject Public Key Info:
            Public Key Algorithm: rsaEncryption
                RSA Public-Key: (2048 bit)
                Modulus:
                    00:eb:41:7d:05:ec:a8:5a:e3:a6:d3:fd:88:f6:e2:
                    ff:5e:52:bf:0b:f5:a4:7b:73:3f:88:24:79:a7:6b:

4.自签名并创建证书

复制代码
openssl x509 -req -days 3650 -in test.csr -signkey test.key -out test.crt -extensions v3_req -extfile openssl.cfg

执行完之后会在当前目录生成test.crt文件。

上边生成的test.key和test.crt文件都是nginx里要使用的文件。

相关推荐
byte轻骑兵10 小时前
【HID】规范精讲[20]: 蓝牙HID低功耗黑科技——Sniff Subrating如何让设备续航翻倍?
网络·科技·人机交互·hid·蓝牙键盘
liana874410 小时前
私有化视频会议:把会议室“搬”进自己的网络
网络
Cat_Rocky11 小时前
Linux-ansible之Playbook简单应用
linux·网络·ansible
汤愈韬11 小时前
IPSec工作原理——TK
网络·网络协议·网络安全·security
ElevenS_it18811 小时前
连锁门店IT运维监控实战:200+门店网络设备+POS统一纳管+按区域分组告警路由完整配置(Zabbix Proxy架构)
运维·网络·架构·zabbix
白狐_79811 小时前
【踩坑实录】VMware中OpenKylin虚拟机网络失联的深度分析与排查全过程
网络·麒麟
Yupureki12 小时前
《MySQL数据库基础》9.索引原理
linux·运维·服务器·网络·数据库·mysql
treesforest12 小时前
机房IP是什么?有什么危害?如何识别?
网络·数据库·python·网络协议·tcp/ip·网络安全
Yupureki13 小时前
《MySQL数据库基础》8.复合查询
linux·运维·服务器·网络·数据库·mysql
方芯半导体13 小时前
ST系列MCU EtherCAT协议栈框架结构详解
服务器·网络·数据库·网络协议·机器人·自动化·工业以太网