网站http自动跳转https方法教程
有小伙伴要问:为什么要部署http跳转https呢?首先 因为https是加密传输协议,比http更加安全,所以很多部署了https证书的网站,都会设置http自动跳转到https。最主要的据说百度和谷歌更倾向于部署了ssl的网站 ,你懂得。下面就是不同的服务器如何部署https跳转的方法:
Apache服务器:
如果需要整站跳转,则在网站的配置文件的标签内,键入以下内容:
RewriteEngine on
RewriteCond %{SERVER_PORT} !^443$
RewriteRule ^(.*)?$ https://%{SERVER_NAME}/$1 [L,R]
如果对某个目录做https强制跳转,则复制以下代码:
RewriteEngine on
RewriteBase /yourfolder
RewriteCond %{SERVER_PORT} !^443$
RewriteRule ^(.*)?$ https://%{SERVER_NAME}/$1 [L,R]
RewriteRule ^.*$ https://%{SERVER_NAME}%{REQUEST_URI} [L,R]
如果只需要对某个网页进行https跳转,可以使用redirect 301来做跳转!redirect 301 /你的网页 https://你的主机+网页
Nginx服务器:
在配置80端口的文件里面,写入以下内容即可。server {
listen 80;
server_name localhost;
rewrite ^(.*)$ https://$host$1 permanent;
location / {
root html;
index index.html index.htm;
}
IIS服务器:
IIS中实现Http自动转换到Https方法介绍 (403跳转对SEO有一定影响),可以采用302重定向方法;
1、根据IIS版本备份以下文件:
IIS6.0 路径:C:\WINDOWS\Help\iisHelp\common\403-4.htm
IIS7.0以上 路径:C:\inetpub\custerr\zh-CN\403.htm
2、把以下内容全部拷贝替换(403-4或403)里面所有内容,保存即可(修改之前先备份下403文件)该页必须通过安全通道查看
var url = window.location.href;
if (url.indexOf(https) < 0) {
url = url.replace(http:, https:);
window.location.replace(url);
}
2、把以下内容全部拷贝替换(403-4或403)里面所有内容,保存即可
3、勾选网站要求SSL通道访问:IIS6中,站点属性-》目录安全性-》编辑中把要求安全通道(SSL)勾选。IIS7、8中,SSL设置勾选要求SSL即可。(备注:如果IIS上面有多个站点,恢复以上操作,然后使用下面的单页面跳转通用代码)
TOMCAT服务器:
1、在conf目录下的server.xml文件中找到以下配置,修改redirectPort参数值为443″,默认是8443.
2、在conf目录下的web.xml文件内容……中增加以下配置。
………
SSL
/*
CONFIDENTIAL
单独页面通用代码段:
以下方法较适合指定某一个子页单独https,如果网页定义了top或者boot文件,可以在这个文件里面加入;
在需要强制为https的页面上加入以下代码进行处理http–>https