一个域名问题

一.写在前面

前天遇到了一个问题就是我用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

相关推荐
Peace6 小时前
【Nginx】
linux·运维·nginx
爱吃土豆的马铃薯ㅤㅤㅤㅤㅤㅤㅤㅤㅤ9 小时前
【无标题】
nginx
Aipollo12 小时前
从Nginx到AI网关:网关技术的演进之路
运维·人工智能·nginx
薛定谔的猫喵喵16 小时前
【从 HTTP 到 HTTPS】Flask 多项目迁移到 Nginx 子路径完整实战
python·nginx·http·https·flask·ssl
cvcode_study17 小时前
Nginx 基础
运维·nginx
福大大架构师每日一题17 小时前
nginx 1.31.1 发布:一次安全修复驱动的主线升级,涉及 Rewrite、HTTP/2、Mail、MP4 与工作流修正
nginx·安全·http
Shawn Dev18 小时前
使用 Certbot 为 Nginx 自动申请 HTTPS 证书并配置自动续签
运维·nginx·https
爱吃土豆的马铃薯ㅤㅤㅤㅤㅤㅤㅤㅤㅤ18 小时前
docker重新加载docer-compose.yml文件(nginx配置)
nginx·docker·eureka
Yana.nice18 小时前
nginx+tomcat环境下,nginx对后端Tomcat实例的健康检查机制
运维·nginx·tomcat
難釋懷18 小时前
Nginx动静分离
运维·nginx·firefox