首页 > 运营 > 帮助中心 > 正文

http 301跳转到https(ssl)实现方法介绍

2020-07-03 13:03:11
字体:
来源:转载
供稿:网友
这篇文章主要为大家详细介绍了http 301跳转到https(ssl)实现方法介绍,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,有需要的朋友可以收藏方便以后借鉴。

随着全站HTTPS的到来,越来越多的网站使用HTTPS,大家在使用百度、谷歌或淘宝的时候,是不是注意浏览器左上角已经全部出现了一把绿色锁,这把锁表明该网站已经使用了 HTTPS 进行保护。仔细观察,会发现这些网站已经全站使用 HTTPS。但是我们很多站点原来都是http的,如何在假设https后把原来的站点301到 HTTPS 呢?下面361源码就几大情形,分别给大家做个介绍。

http 301跳转到https(ssl)实现方法介绍

linuxt系统 apache环境

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

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

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

<IfModule mod_rewrite.c>RewriteEngine OnRewriteCond %{HTTP:From-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对应修改为您自已的域名</IfModule>

Nginx环境

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

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

Windows系统 II7环境

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

<?xml version="1.0" encoding="UTF-8"?><configuration> <system.webServer>        <rewrite>            <rules>               <rule name="301" stopProcessing="true">                    <match url="^(.*)$" ignoreCase="false" />                    <conditions logicalGrouping="MatchAll">                        <add input="{HTTPS}" pattern="^on$" negate="true" />                    </conditions>                    <action type="Redirect" url="https://www.abc.com/{R:1}" redirectType="Permanent" />      # www.abc.com对应修改为您自已的域名               </rule>            </rules>        </rewrite>    </system.webServer> </configuration>

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

<?xml version="1.0" encoding="UTF-8"?><configuration> <system.webServer>        <rewrite>            <rules>               <rule name="301" stopProcessing="true">                    <match url="^(.*)$" ignoreCase="false" />                    <conditions logicalGrouping="MatchAll">                        <add input="{HTTP_FROM_HTTPS}" pattern="^on$" negate="true" />                    </conditions>                 <action type="Redirect" url="https://www.abc.com/{R:1}" redirectType="Permanent" /> # www.abc.com对应修改为您自已的域名               </rule>            </rules>        </rewrite>    </system.webServer> </configuration>

Windows系统 II6环境

在规则文件httpd.conf 添加以下规则。

RewriteEngine OnRewriteCond %{HTTP:From-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>    <!-- Authorization setting for SSL -->    <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域名,仍在原来站点设置跳转规则。

补充说明:

上面介绍的方法部分可能需要空间符合配置,大家在配置的过程中多做尝试,咨询空间商配合处理。

以上就是http 301跳转到https(ssl)实现方法介绍的全部内容,希望对大家的学习和解决疑问有所帮助,也希望大家多多支持错新网。
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表