RABBITMQ的本地测试证书生成脚本

由于小程序要求必须访问wss的接口,因此需要将测试环境也切换到https,看了下官方的文档

RabbitMQ Web STOMP Plugin | RabbitMQ 里面有这个信息

然后敲打GPT一阵子,把要求输入几个来回,得到这样一个脚本:

generate_cert.sh

#!/bin/bash

# 检查是否提供了IP地址
if [ "$#" -ne 1 ]; then
    echo "Usage: $0 <IP_ADDRESS>"
    exit 1
fi

IP_ADDRESS=$1
PASSWORD="changeme"

# 创建必要的目录
mkdir -p certs

# 生成 CA 密钥
openssl genrsa -des3 -passout pass:$PASSWORD -out certs/ca.key 2048

# 生成 CA 证书
openssl req -x509 -new -nodes -key certs/ca.key -sha256 -days 1024 -passin pass:$PASSWORD -out certs/ca_certificate.pem -subj "/CN=${IP_ADDRESS}"

# 生成服务器密钥
openssl genrsa -des3 -passout pass:$PASSWORD -out certs/server.key 2048

# 生成服务器证书签名请求(CSR)
openssl req -new -key certs/server.key -passin pass:$PASSWORD -out certs/server.csr -subj "/CN=${IP_ADDRESS}"

# 创建一个配置文件用于扩展
cat <<EOF > certs/openssl.cnf
[ v3_ca ]
basicConstraints = CA:TRUE

[ v3_req ]
basicConstraints = CA:FALSE
subjectAltName = @alt_names

[ alt_names ]
IP.1 = ${IP_ADDRESS}
EOF

# 使用 CA 证书签署服务器证书
openssl x509 -req -in certs/server.csr -CA certs/ca_certificate.pem -CAkey certs/ca.key -CAcreateserial -out certs/server_certificate.pem -days 500 -sha256 -passin pass:$PASSWORD -extfile certs/openssl.cnf -extensions v3_req

# 转换服务器密钥为 PEM 格式
openssl rsa -in certs/server.key -out certs/server_key.pem -passin pass:$PASSWORD -passout pass:$PASSWORD

# 打印完成信息
echo "Certificates and keys generated successfully in the 'certs' directory."
echo "CA Certificate: certs/ca_certificate.pem"
echo "Server Certificate: certs/server_certificate.pem"
echo "Server Key: certs/server_key.pem"

在WSL的ubuntu里使用
generate_cert.sh <测试IP> 来生成

然后在RabbitMQ服务器的log/db同级目录下建立rabbitmq.conf

第一个张图片内容贴进去,然后重启rabbitMQ服务,再看管理界面,https的端口15673成功起来了
 

---------------------------- [ 2024/08/27的分割线 ] ----------------------------

这种方式生成的证书,在开发PC上连接内网IP是没问题。但是用手机浏览器走wss协议去连会出现一直连接不了的问题,究其原因,因为手机的安全限制,需要对证书进行可信验证才可以连接。除了一部一部手机导入证书的繁琐方法,也可以采用内网认证域名的方式一劳永逸,解决方案如下:

1)随便买一个1元域名,例如ABC.COM只要能用的就行

2)去域名控制台设置一个推送的二级域名,例如PUSH.ABC.COM

3)去JOYSSL网站(ssl.inhitech.cn)申请一个PUSH.ABC.COM的免费证书,采用CNAME模式验证

4)去内网路由器建立一个劫持域名(建议支持OPENWRT的路由,普通路由器没这个功能 ),指向内网rabbitmq服务器,例如192.168.1.99。建立完ping一下,看看是不是去到192.168.1.99了。

5)把JOYSSL网站下载的证书压缩包打开,对应的是这几个文件名,我没有改文件名直接配置指向过去了,如下:

web_stomp.ssl.cacertfile = C:\Users\Administrator\AppData\Roaming\RabbitMQ\certs\push.aibuy.site.ca-bundle
web_stomp.ssl.certfile   = C:\Users\Administrator\AppData\Roaming\RabbitMQ\certs\push.aibuy.site.pem
web_stomp.ssl.keyfile    = C:\Users\Administrator\AppData\Roaming\RabbitMQ\certs\push.aibuy.site.key
web_stomp.ssl.password   = XXXXXXXX

password是证书压缩包里password.txt内的数据

6)然后手机就可以用wss://PUSH.ABC.COM/ws去正常连接内网的rabbitmq 加密TLS服务了

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

FoxMale007

文章非V全文可读,觉得好请打赏

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值