局域网部署时实现基于https的业务系统访问

局域网部署时实现基于https的业务系统访问

最近在做项目集成时,门户的系统因为客户安全要求,启动了https的访问,导致我们的系统无法正常访问。简单测试了一下如何在企业内网,如何将自己的Web应用部署为https的访问。

证书管理

安装mkcert

复制代码
sudo apt install libnss3-tools -y
curl -L https://github.com/FiloSottile/mkcert/releases/download/v1.4.4/mkcert-v1.4.4-linux-amd64 -o mkcert
chmod +x mkcert
sudo mv mkcert /usr/local/bin/

mkcert -install

制作证书

复制代码
mkcert localhost 127.0.0.1 192.168.2.62

演示如下

复制代码
(base) jihui@rz-62-exchange:~$ mkcert localhost 127.0.0.1 192.168.2.62

Created a new certificate valid for the following names 📜
 - "localhost"
 - "127.0.0.1"
 - "192.168.2.62"

The certificate is at "./localhost+2.pem" and the key at "./localhost+2-key.pem" ✅

It will expire on 27 April 2028 🗓

(base) jihui@rz-62-exchange:~$ 

制作好的证书,在当前目录下。

至此,证书准备完成。

网站部署

演示网站的结构如下:

复制代码
(base) jihui@rz-62-exchange:~/deploy$ tree
.
├── conf
│   ├── cert
│   │   ├── localhost+2-key.pem
│   │   └── localhost+2.pem
│   └── nginx
│       └── default.conf
├── data
│   └── web
│       └── index.html
└── docker-compose.yaml

6 directories, 5 files
(base) jihui@rz-62-exchange:~/deploy$ 

配置网站文件

为了演示,网站只有一个文件index.html,内容如下:

复制代码
$ cat index.html 

Hello world.

准备nginx配置文件

  • 使用https,需要监听443端口,server_name使用生成证书时的服务器地址。

  • 需要配置ssl_certificatessl_certificate_key,两个参数的值为上面证书的文件地址。这个地址是容器内容的地址。

    (base) jihui@rz-62-exchange:~/deploy/conf/nginx cat default.conf map http_upgrade $connection_upgrade {
    default upgrade;
    '' close;
    }

    server {
    # listen 80;
    listen 443 ssl;
    server_name localhost 127.0.0.1 192.168.2.62;

    复制代码
      ssl_certificate /etc/nginx/cert/localhost+2.pem;
      ssl_certificate_key /etc/nginx/cert/localhost+2-key.pem;
    
      error_page 500 502 503 504  /50x.html;
    
      location = /50x.html {
          root   /usr/share/nginx/html;
      }
      
      location / {
          root /web;
          index index.html;
          try_files $uri $uri/ =404;
      }

    }
    (base) jihui@rz-62-exchange:~/deploy/conf/nginx$

配置docker-compose.yaml

在这个文件中,需要配置如下:

  • 监听端口为443,这个端口和default.conf中的端口要对应。

  • 需要将宿主机上的证书目录,映射到容器的/etc/nginx/cert/目录。

  • 将宿主机上的网站文件,映射到容器的/web。

    (base) jihui@rz-62-exchange:~/deploy$ cat docker-compose.yaml
    services:

    复制代码
    web:
      image: nginx:1.28
      container_name: web
      restart: unless-stopped
      ports:
        # - 8989:80
        - 8989:443
      volumes:
        - ./conf/nginx/:/etc/nginx/conf.d/
        - ./conf/cert/:/etc/nginx/cert/
        - ./data/web:/web

    (base) jihui@rz-62-exchange:~/deploy$

测试

使用浏览器测试

使用curl命令测试

复制代码
(base) user@rz-61-exchange:~$ curl https://192.168.2.62:8989/
curl: (60) SSL certificate problem: unable to get local issuer certificate
More details here: https://curl.se/docs/sslcerts.html

curl failed to verify the legitimacy of the server and therefore could not
establish a secure connection to it. To learn more about this situation and
how to fix it, please visit the web page mentioned above.
(base) user@rz-61-exchange:~$ 

直接访问会失败。

复制代码
(base) user@rz-61-exchange:~$ curl -k https://192.168.2.62:8989/
Hello world.
(base) user@rz-61-exchange:~$ 

复制代码
(base) user@rz-61-exchange:~$ curl --insecure https://192.168.2.62:8989/
Hello world.
(base) user@rz-61-exchange:~$ 
相关推荐
七夜zippoe2 小时前
WebSocket实时通信系统构建:从握手协议到生产级实战
网络·python·websocket·网络协议·心跳
我送炭你添花2 小时前
树莓派 3B+ 部署 TR-069 ACS(自动配置服务器)GenieACS 实录
运维·服务器·网络协议
码农学院3 小时前
Windows 服务中获取本机的 IP 地址
网络·网络协议·tcp/ip
Selenium-Wang3 小时前
动态HTTP隧道代理IP:从配置到实战的完整指南
网络协议·tcp/ip·http
以太浮标3 小时前
华为eNSP模拟器综合实验之- 通过流策略实现Vlan内二/三层隔离
网络·网络协议·华为
flashier3 小时前
ESP32学习笔记_WiFi(3)——HTTP
网络·笔记·单片机·网络协议·学习·http·esp32
我在人间贩卖青春4 小时前
IP协议及以太网协议
网络·网络协议·tcp/ip
im_AMBER4 小时前
消失的最后一秒:SSE 流式联调中的“时序竞争”
前端·笔记·学习·http·sse
2501_916008894 小时前
iOS 开发助手工具,设备信息查看、运行日志、文件管理等方面
android·ios·小程序·https·uni-app·iphone·webview