
网站上了 https ,并且 nginx 配置了把所有 http 请求都 301 重定向到 https ,
但发现,如果在浏览器上访问的是 http ,仍然会被劫持。
看了劫持页面的源码,还是老套路 iframe ,src="http://xxx",所以从 iframe 出去的请求还是 http 的,服务器响应了 301 重定向到 https ,内容也可以正常显示出来。
不知道是服务端没配置好,还是一定要上 hsts 呢?
PS. 网站在 SSL Labs 评分为 A;
PPS. 是江苏电信劫持的(不得不说江苏电信真的是什么站都劫持,一天不到 10 IP 的小站都劫持,简直疯了)
1 lhbc 2016 年 11 月 18 日 楼主标题党…… |
3 ovear 2016 年 11 月 18 日 只要你访问过 80 且是 HTTP 就会被劫持, HSTS 也无解。 HSTS 解决的是,正常的访问打到 HTTPS 上,然后下次通过 HTTP 访问的时候,浏览器会自动强制重定向到 HTTPS |
4 xycool 2016 年 11 月 18 日 https :我的锅,都怪我。 |
6 ovear 2016 年 11 月 18 日 @abelyao 是,因为在首次通讯( HSTS 头还没被浏览器接收到)的时候,浏览器会使用 HTTP 协议去请求远端服务器,这个过程是明文的,在链路过程中就会遭到劫持 唯一的解决方法,就是去申请进入浏览器内置的 HSTS 列表,缺点就是。。以后这个域名以及子域名都要 HTTPS 了 |
8 abelyao OP |
9 Felldeadbird 2016 年 11 月 18 日 淡定,未来浏览器访问非 SSL 的网站将会出现警告的了。 |