您的位置:海南科技网首页 > 建站经验 > 正文

部署https(ssl)后设置301跳转将http跳转到https

2019-06-05 22:16:36 来源:海南科技网 繁体中文 关闭 收藏 打印 复制

注意,以下教程针对我司虚拟主机或者亚数的云主机香港IP部署SSL后的301跳转(非亚数机房需要注意规则中行替换),把规则中域名替换成自己的

linux系统 apache环境

云服务器:【直接在apache上部署的SSL】在对应站点根目录下新建(通过ftp或登录wdcp管理面板中:站点列表-文管-进入public_html-创建文件)一个文件命名为.htaccess

<IfModulemod_rewrite.c>
RewriteEngineOn
RewriteCond%{HTTP:From-Https}!^on$[NC]
#RewriteCond%{HTTPS}!^on$[NC]#非亚数机房用这一行替换上一行规则
RewriteCond%{HTTP_HOST}^(www.)?abc.com$[NC]#将abc.com和www.abc.com跳转到https://www.abc.com,防止apache子站继承上级目录.htaccess受影响
RewriteRule^(.*)$https://www.abc.com/$1[R=301,L]
</IfModule>

虚拟主机:可以通过ftp或登录后进入到主机管理面板-文件管理,进入wwwroot,新建一个文件命名为.htaccess文件,保存即可。

编辑.htaccess文件写入以下规则:

<IfModulemod_rewrite.c>
RewriteEngineOn
RewriteCond%{HTTP:From-Https}!^on$[NC]
RewriteCond%{HTTP_HOST}^(www.)?abc.com$[NC]#将abc.com和www.abc.com跳转到https://www.abc.com,防止apache子站继承上级目录.htaccess受影响
RewriteRule^(.*)$https://www.abc.com/$1[R=301,L]
</IfModule>

Nginx环境

编辑nginx站点配置文件(登录wdcp管理面板中:站点列表-文管-虚拟主机站点文件nginx-对应站点配置文件),添加以下规则

server
{
listen80;
server_nameabc.com;
rewrite^(.*)https://www.abc.com$1permanent;#abc.com对应修改为您自已的域名
}

亚数机房CDN部署的SSL添加下面代码
if($http_from_https!='on'){
rewrite^(.*)https://www.abc.com$1permanent;#abc.com对应修改为您自已的域名
}

Windows系统 IIS7环境

云服务器:【直接在IIS上部署的SSL】在对应站点根目录下新建(通过ftp或登录后直接进入到D:wwwroot站点ftp命名目录wwwroot创建)一个文件命名为web.config并编辑添加以下规则:

亚洲数据中心机房复制以下规则,注意更改为自己的域名

<?xmlversion="1.0"encoding="UTF-8"?>
<configuration>
<system.webServer>
<rewrite>
<rules>
<rulename="301"stopProcessing="true">
<matchurl="^(.*)$"ignoreCase="false"/>
<conditionslogicalGrouping="MatchAll">
<addinput="{HTTP_FROM_HTTPS}"pattern="^on$"negate="true"/>
</conditions>
<actiontype="Redirect"url="https://www.abc.com/{R:1}"redirectType="Permanent"/>
</rule>
</rules>
</rewrite>
</system.webServer>
</configuration>

非亚数机房复制以下规则,注意替换为自己的域名

<?xmlversion="1.0"encoding="UTF-8"?>
<configuration>
<system.webServer>
<rewrite>
<rules>
<rulename="301"stopProcessing="true">
<matchurl="^(.*)$"ignoreCase="false"/>
<conditionslogicalGrouping="MatchAll">
<addinput="{HTTPS}"pattern="^on$"negate="true"/>
</conditions>
<actiontype="Redirect"url="https://www.abc.com/{R:1}"redirectType="Permanent"/>
</rule>
</rules>
</rewrite>
</system.webServer>
</configuration>

虚拟主机:可以通过ftp或登录后进入到主机管理面板-文件管理,进入wwwroot,新建一个文件命名为web.config并编辑添加以下规则,注意替换为自己的域名。

<?xmlversion="1.0"encoding="UTF-8"?>
<configuration>
<system.webServer>
<rewrite>
<rules>
<rulename="301"stopProcessing="true">
<matchurl="^(.*)$"ignoreCase="false"/>
<conditionslogicalGrouping="MatchAll">
<addinput="{HTTP_FROM_HTTPS}"pattern="^on$"negate="true"/>
</conditions>
<actiontype="Redirect"url="https://www.abc.com/{R:1}"redirectType="Permanent"/>
</rule>
</rules>
</rewrite>
</system.webServer>
</configuration>

Windows系统 IIS6环境

参考http://www.west.cn/faq/list.asp?unid=650配置一个Rewrite,编辑该Rewrite的规则文件httpd.conf添加以下规则。

RewriteEngineOn
RewriteCond%{HTTP:From-Https}!^on$[NC]
#RewriteCond%{HTTPS}!^on$[NC]#非亚数机房用这一行替换上一行规则
RewriteRule^(.*)$https://www.abc.com/$1[R=301,L]#www.abc.com对应修改为您自已的域名
RewriteCond%{HTTP_HOST}!^www.
RewriteRule^(.*)$https://www.abc.com$1[R=301,L]#www.abc.com对应修改为您自已的域名

tomcat环境

在web.xml最后一行</web-app>代码之前添加如下代码即可

<security-constraint>
<!--AuthorizationsettingforSSL-->
<web-resource-collection>
<web-resource-name>SSL</web-resource-name>
<url-pattern>/*</url-pattern>
</web-resource-collection>
<user-data-constraint>
<transport-guarantee>CONFIDENTIAL</transport-guarantee>
</user-data-constraint>
</security-constraint>

注: 1、discuz使用301方式强制将http跳转到https后会导致后台uc通信失败。

2、通过该方式设置跳转后,如无法正常跳转访问,请单独建立站点绑定https域名,仍在原来站点设置跳转规则。

  (来源:海南科技网)

版权声明:
1.本站登载此文仅出于传递更多信息,并不意味着赞同其观点或证实其描述,不承担侵权行为的连带责任。
2.如本网信息涉及版权等问题,请于发布起15个工作日内发送邮件与本网联系,我们将及时删除处理。

相关资讯: