局域网部署时实现基于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:~$ 
相关推荐
LCMICRO-1331084774611 小时前
长芯微LD9689完全P2P替代AD9689,是一款双通道、14位、2.0 GSPS/2.6 GSPS模数转换器(ADC)
网络·单片机·嵌入式硬件·网络协议·fpga开发·硬件工程·高速adc
皙然20 小时前
深入理解TCP流量控制
网络·网络协议·tcp/ip
长安11081 天前
web后端----HTTP协议与浏览器F12
前端·网络协议·http
茶杯梦轩1 天前
面试常问:DNS,CDN,Cookie,Session和Token详解及实战避坑指南
后端·网络协议·面试
Java成神之路-1 天前
HTTP 协议进化史:从 1.0 到 3.0
网络·网络协议·http
2501_916007471 天前
HTTPS 抓包的流程,代理抓包、设备数据线直连抓包、TCP 数据分析
网络协议·tcp/ip·ios·小程序·https·uni-app·iphone
IpdataCloud1 天前
资源受限设备上轻量级IP查询模块的部署方法
网络·数据库·网络协议·tcp/ip
eleven40961 天前
穿透内容审查与阻断:基于 DNS TXT 记录的动态服务发现与客户端安全加固实践
网络协议·ios·app
2501_915918411 天前
iOS mobileprovision 描述文件管理,新建、下载和内容查看
android·ios·小程序·https·uni-app·iphone·webview
00后程序员张1 天前
iOS 应用程序使用历史记录和耗能记录怎么查?
android·ios·小程序·https·uni-app·iphone·webview