网站上了 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 12:46:32 +08:00
楼主标题党……
|
3
ovear 2016-11-18 12:48:56 +08:00
只要你访问过 80 且是 HTTP 就会被劫持, HSTS 也无解。
HSTS 解决的是,正常的访问打到 HTTPS 上,然后下次通过 HTTP 访问的时候,浏览器会自动强制重定向到 HTTPS |
4
xycool 2016-11-18 12:49:03 +08:00
https :我的锅,都怪我。
|
6
ovear 2016-11-18 12:50:32 +08:00
@abelyao 是,因为在首次通讯( HSTS 头还没被浏览器接收到)的时候,浏览器会使用 HTTP 协议去请求远端服务器,这个过程是明文的,在链路过程中就会遭到劫持
唯一的解决方法,就是去申请进入浏览器内置的 HSTS 列表,缺点就是。。以后这个域名以及子域名都要 HTTPS 了 |
8
abelyao OP |
9
Felldeadbird 2016-11-18 13:38:07 +08:00
淡定,未来浏览器访问非 SSL 的网站将会出现警告的了。
|