通过https方式访问内网IP

单位要做个用浏览器扫二维码的功能。我先在本地测试一直不成功,后来放到服务器上运行成功了。比较了一下,服务器上是https,但是本地没有证书。我问了一下信安的同事,要求二维码必须在本地扫描,不能上公网。所以只好在本地弄一个允许通过https方式访问IP的服务。从网上查了一下,都是mkcert能实现,所以按照别人的方式试了一下,果然成功了。下面是实验的记录,希望能帮到有相同需求的朋友。

mkcert是一个使用go语言编写的生成本地自签证书的小程序,具有跨平台,使用简单,支持多域名,自动信任CA等一系列方便的特性可供本地开发时快速创建https环境使用。

一、下载

其最新版本地址如下:https://github.com/FiloSottile/mkcert/releases/latest

根据内部服务器的操作系统类型下载对应的windows/Linux/arm版本即可,我这里是x86的。

wget https://github.com/FiloSottile/mkcert/releases/download/v1.4.4/mkcert-v1.4.4-linux-amd64

二、安装

赋予权限

chmod +x mkcert-v1.4.4-linux-amd64

将mkcert文件移动到bin目录下

sudo cp mkcert-v1.4.4-linux-amd64 /usr/local/bin/mkcert

安装证书

mkcert -install

三、生成证书

得到证书的根目录,将该目录下的rootCA.pem文件下载,将生成的证书下载到需要访问该ip的pc机上备用

mkcert -CAROOT

将可信ip写入,并生成对应的ssl证书,执行中可能会要求输入密码,需要记住该密码,后续配置https时会用到

mkcert localhost 127.0.0.1 ::1 192.168.1.99

四、Nginx部署证书

nginx部署需要crt和key文件,因此也需要通过mkcert生成的文件来进行转换

openssl x509 -in localhost+3.pem -out localhost+3.crt

openssl rsa -in localhost+3-key.pem -out localhost+3.key

将生成的这两个文件,复制到nginx的conf目录下,并配置nginx.conf

#在nginx.conf填写证书文件的相对路径或绝对路径

ssl_certificate conf.d/maruifu_cn/ssl/localhost+3.crt;

#请填写私钥文件的相对路径或绝对路径

ssl_certificate_key conf.d/maruifu_cn/ssl/localhost+3.key;

相关推荐
DONSEE广东东信智能读卡器9 小时前
用PowerShell实现Windows 本地 WSS/HTTPS 自签名证书配置方法
windows·网络协议·https·powershell·身份证阅读器
2501_916007479 小时前
iOS开发中抓取HTTPS请求的完整解决方法与步骤详解
android·网络协议·ios·小程序·https·uni-app·iphone
风度前端13 小时前
阿里云宝塔面板部署https证书
linux·后端·https
wu@5555514 小时前
使用acme生成免费https泛域名证书(通配符证书)
网络协议·http·https
KnowSafe2 天前
如何用OpenSSL生成CSR文件?
服务器·https·ssl
00后程序员张2 天前
HTTPS单向认证、双向认证、抓包原理与反抓包策略详解
网络协议·http·ios·小程序·https·uni-app·iphone
明豆4 天前
HTTPS / TLS 1.3 深度解析 — Web 安全传输协议生产实战
前端·安全·https
成空的梦想4 天前
免费 vs 付费国密 SSL 怎么选?
服务器·网络·网络协议·http·https·ssl
深邃-4 天前
【Web安全】-SRC平台介绍:CNVD平台-事件型漏洞-通用型漏洞,教育SRC平台,漏洞盒子,补天漏洞平台,企业SRC平台,企业和公益SRC平台
网络协议·安全·web安全·网络安全·https·src·cnvd
落叶_Jim4 天前
2026年Nginx配置HTTPS全流程-从零到自动续期实战指南
运维·nginx·https