【问题解决】http强制跳转https并提示不安全信息:你与该网站的连接不是私密连接

问题描述

博主添加了一个二级域名想用来部署其它web服务,二级域名是没有ssl证书的,而一级域名是已经配置好ssl。

配置好Nginx后,在地址栏输入http://二级域名却跳转到https://二级域名,并且会提示不安全信息如“你与该网站的连接不是私密连接”。

点击继续访问,结果发现虽然地址是二级域名,但内容根本不是我二级域名配置的web服务,而是一级域名的web服务,并且地址上https标识有红色划线很难看。

问题原因

因为博主的ssl证书不是单域名证书不是通配符证书,在Nginx配置中没有考虑多级域名情况,而偷懒把ssl配置在了http块

问题解决

将ssl配置移到server中,如下所示

# 一级域名
server { 
        listen 80;
        listen [::]:80;
        server_name xxx.com www.xxx.com;
        rewrite ^(.*)$ https://$host$1 permanent;
}

server {
        listen 443 ssl;
        listen [::]:443 ssl;

        ssl_certificate xxx.pem;
        ssl_certificate_key xxx.key;
        ssl_session_timeout 5m;
        ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4;
        ssl_protocols TLSv1 TLSv1.1 TLSv1.2; # Dropping SSLv3, ref: POODLE
        ssl_prefer_server_ciphers on;
		
		# 。。。。。。
}

# 其它多级域名
server { 
        listen 80;
        listen [::]:80;
        server_name yy.xxx.com;
        
        # 。。。。。。
}


  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当您尝试使用Charles(一款网络调试代理工具)并且遇到“您的连接不是私密连接”的错误提示时,这意味着Charles正在试图拦截或修改您浏览器或其他应用的网络流量,但系统检测到这个请求不支持透明代理设置,可能是出于安全原因,如HTTPS加密连接。 通常这种情况下,是因为Charles期望您访问的是HTTP加密页面,或者是HTTPS页面并且没有正确配置 Charles 来处理SSL证书。解决方法包括: 1. **禁用SSL中间人**:对于HTTPS连接,您可能需要在 Charles 的设置中启用"Trust All Certificates"(信任所有证书),但这可能会降低网络安全性,只建议在测试环境中使用。 2. **Man-in-the-Middle模式**:切换到“Capture HTTP traffic only”模式,这将只抓取明文HTTP流量,不截获HTTPS连接。 3. **代理服务器设置**:确保您的应用程序设置了正确的代理服务器地址和端口为 Charles 使用。 4. **HTTPS重定向**:如果您的目标网站设置了自动跳转HTTPS,可以在 Charles 中手动接受 SSL 证书。 5. **检查防火墙和安全组规则**:确认没有其他防火墙或安全设置阻止了 Charles 对网络的访问。 如果你是在开发环境中使用,可以根据具体需求调整 Charles 配置;如果是生产环境,请咨询 IT 或者网络管理员,因为随意修改代理设置可能会对实际用户数据造成潜在风险。如有更多疑问,可询问:
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值