基于ip地址通过openssl生成自签名证书

最近在配置geo的时候,客户说自己使用的是自签证书,然后是通过ip地址和端口的方式访问gitlab,比较好奇这块,因此对证书的生成和使用做了一些整理,对此网上关于这部分资料也很多,不过作为记录,也算是自己的部分实践。

文章目录

    • 说明
    • 方法一
      • [step1: 首先生成私钥文件](#step1: 首先生成私钥文件)
      • [step2: 根据私钥文件成自签名的证书文件](#step2: 根据私钥文件成自签名的证书文件)
    • 方法二
      • [step1: 通过openssl生成私钥](#step1: 通过openssl生成私钥)
      • [step2: 根据私钥生成证书申请文件csr](#step2: 根据私钥生成证书申请文件csr)
      • [step3: 使用私钥对证书申请进行签名从而生成证书](#step3: 使用私钥对证书申请进行签名从而生成证书)
    • 使用

说明

通过openssl genrsa 命令可以用来生成 RSA 私有秘钥,但是并不会生成公钥,因为公钥提取自私钥。生成时是可以指定私钥长度和密码保护。

方法一

step1: 首先生成私钥文件

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

参数说明

  • -out filename:将生成的私钥保存至filename文件,若未指定输出文件,则为标准输出。
  • -numbits:指定要生成的私钥的长度(单位 bit),默认为1024。该项必须为命令行的最后一项参数

step2: 根据私钥文件成自签名的证书文件

bash 复制代码
openssl req -new -x509 -days 3650 -key server.key -out server.crt -subj "/C=CN/ST=BeiJing/L=BeiJing/O=BJ/OU=BJ/CN=192.168.31.40/emailAddress=wkx323@163.com"

参数说明

  • -new:说明生成证书请求文件。
  • -x509:说明生成自签名证书。
  • -days:指定自签名证书的有效期限,默认为30天。
  • -key:指定使用已有的秘钥文件生成秘钥请求,只与生成证书请求选项-new配合。
  • -newkey:-newkey是与-key互斥的,-newkey是指在生成证书请求或者自签名证书的时候自动生成密钥,然后生成的密钥名称由-keyout参数指定。当指定newkey选项时,后面指定rsa:bits说明产生rsa密钥,位数由bits指定。 如果没有指定选项-key和-newkey,默认自动生成秘钥。
  • -out :指定生成的证书请求或者自签名证书名称。
  • -subj:指定用户的信息。

方法二

step1: 通过openssl生成私钥

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

step2: 根据私钥生成证书申请文件csr

bash 复制代码
openssl req -new -key server.key -out server.csr

根据命令行向导来进行信息输入:

step3: 使用私钥对证书申请进行签名从而生成证书

bash 复制代码
openssl x509 -req -in server.csr -out server.crt -signkey server.key -days 3650

使用

将生成的server.keyserver.crt拷贝到服务器的证书位置即可。如gitlab的配置:

复制代码
...
...
external_url 'https://192.168.31.40:19090'
letsencrypt['enable'] = false
nginx['ssl_certificate'] = "/etc/gitlab/ssl/server.crt"
nginx['ssl_certificate_key'] = "/etc/gitlab/ssl/server.key"
...
...
相关推荐
ftpeak3 天前
从零开始使用 axum-server 构建 HTTP/HTTPS 服务
网络·http·https·rust·web·web app
00后程序员张3 天前
详细解析苹果iOS应用上架到App Store的完整步骤与指南
android·ios·小程序·https·uni-app·iphone·webview
weixin_456904273 天前
使用HTTPS 服务在浏览器端使用摄像头的方式解析
网络协议·http·https
不会叫的狼3 天前
HTTPS + 域名 + 双向证书认证(下)
https
DoWhatUWant4 天前
域格YM310 X09移芯CAT1模组HTTPS连接服务器
服务器·网络协议·https
Whisper_Yu4 天前
计算机网络(一)基础概念
计算机网络·http·https·信息与通信
娅娅梨4 天前
HarmonyOS-ArkUI Web控件基础铺垫7-HTTP SSL认证图解 及 Charles抓包原理 及您为什么配置对了也抓不到数据
http·华为·ssl·harmonyos
m0_749299955 天前
HTTP与HTTPS
网络协议·http·https
影子24015 天前
java jdbc连接sqlserver2008R2版本数据库报错,驱动程序无法通过使用安全套接字层(SSL)加密与 SQL Server 建立安全连接
java·数据库·ssl
土星碎冰机5 天前
数据库开启ssl
数据库·网络协议·ssl