一个域名问题

一.写在前面

前天遇到了一个问题就是我用edge和firefox浏览器可以用daxiongx.cn来访问就有ssl证书,但是用google和手机就不行,然后通过我发现是因为我申请的证书没包括daxiongx.cn这个主域名,申请的是www.daxiongx.cn,那为什么edge就可以呢,问了ai,ai说是我以前用edge访问过daxiongx.cn,然后服务做了代理跳转到了www.daxiongx.cn,然后走了缓存才会这样的,这个是测试域名的ssl证书的网站

ssl server test

下面是和ai的对话总结

二.对话

我们刚刚主要排查了 Let's Encrypt 给 daxiongx.cn 主域名补证书 这件事。

1. 你现在的证书情况

你执行了:

bash 复制代码
sudo certbot certificates

看到当前证书名是:

text 复制代码
www.daxiongx.cn

证书里已有域名是:

text 复制代码
www.daxiongx.cn
minio-console.daxiongx.cn
minio.daxiongx.cn
www.ws.daxiongx.cn
xadmin.daxiongx.cn

但是没有主域名:

text 复制代码
daxiongx.cn

所以 https://daxiongx.cn 在 Chrome 里可能会证书不匹配。


2. 为什么 Edge 能访问,Chrome 不行

因为旧证书没有 daxiongx.cn

如果 Edge 实际访问的是:

text 复制代码
http://daxiongx.cn

Nginx 可以先收到 HTTP 请求,然后 301 跳转到:

text 复制代码
https://www.daxiongx.cn

www.daxiongx.cn 在证书里,所以能打开。

但如果 Chrome 直接访问:

text 复制代码
https://daxiongx.cn

浏览器会先做 TLS 握手和证书校验。旧证书里没有 daxiongx.cn,所以证书校验失败。这个时候 HTTP 请求还没到 Nginx,Nginx 的 301 跳转根本没有机会执行。

所以解决办法就是:daxiongx.cn 加进证书里。

之后如果你还想让主域名跳到 www,Nginx 可以这样写:

nginx 复制代码
server {
    listen 443 ssl;
    server_name daxiongx.cn;

    ssl_certificate /etc/nginx/cert/www.daxiongx.cn.pem;
    ssl_certificate_key /etc/nginx/cert/www.daxiongx.cn.key;

    return 301 https://www.daxiongx.cn$request_uri;
}

前提是证书已经包含 daxiongx.cn

相关推荐
dxdz4 小时前
一文搞定 Linux Nginx 从安装、启动到 nginx.conf 全配置详解(新手也能看懂)
nginx
遇见火星4 小时前
Nginx 负载均衡配置模板:轮询、权重、IP哈希、最少连接
tcp/ip·nginx·负载均衡
untE EADO7 小时前
Nginx代理到https地址忽略证书验证配置
运维·nginx·https
Treh UNFO8 小时前
nginx的重定向
大数据·数据库·nginx
理人综艺好会9 小时前
nginx了解
运维·nginx
likeGhee10 小时前
docker创建nginx+keepalived+nacos集群(仅测试环境)
nginx·docker
Harvy_没救了1 天前
【网络部署】 Win11 + VMware CentOS8 + Nginx 文件共享服务 Wiki
运维·网络·nginx
遇见火星1 天前
Nginx限流配置:防止接口被刷,服务器稳如泰山
运维·服务器·nginx
Jinkxs2 天前
LoadBalancer- 主流负载均衡工具盘点:Nginx / Haproxy / Keepalived 基础介绍
运维·nginx·负载均衡