quanshiyinian 发表于 2020-10-10 15:38:00

部署https(ssl)后设置301跳转将http跳转到https的解决方法

1、云主机apache环境【直接在apache上部署的SSL】在对应站点根目录下新建一个文件命名为.htaccess。<IfModule mod_rewrite.c>
RewriteEngine On
RewriteCond%{HTTPS} !^on$                            
RewriteCond %{HTTP_HOST} ^(www.)?abc.com$                 # 将abc.com和www.abc.com跳转到https://www.abc.com,防止apache子站继承上级目录.htaccess受影响
RewriteRule ^(.*)$ https://www.abc.com/$1
</IfModule>云主机apache环境(香港亚洲数据中心机房):<IfModule mod_rewrite.c>
RewriteEngine On
RewriteCond %{HTTP:From-Https} !^on$                                     
RewriteCond %{HTTP_HOST} ^(www.)?abc.com$                 # 将abc.com和www.abc.com跳转到https://www.abc.com,防止apache子站继承上级目录.htaccess受影响
RewriteRule ^(.*)$ https://www.abc.com/$1
</IfModule>2、虚拟主机linux系统可以通过ftp或登录后进入到主机管理面板-文件管理,进入wwwroot,新建一个文件命名为.htaccess文件,保存即可。
编辑.htaccess文件写入以下规则:<IfModule mod_rewrite.c>
RewriteEngine On
RewriteCond %{HTTP:From-Https} !^on$
RewriteCond %{HTTP_HOST} ^(www.)?abc.com$                 # 将abc.com和www.abc.com跳转到https://www.abc.com,防止apache子站继承上级目录.htaccess受影响
RewriteRule ^(.*)$ https://www.abc.com/$1
</IfModule>3、云主机Nginx环境
编辑nginx站点配置文件(登录wdcp管理面板中:站点列表-文管-虚拟主机站点文件nginx-对应站点配置文件),添加以下规则。server
{
listen 80;
server_name abc.com;
rewrite ^(.*) https://www.abc.com$1 permanent;         #abc.com对应修改为您自已的域名   
}server
{
listen 80;
server_name abc.com;   
}

亚数机房CDN部署的SSL在自身网站server配置节中添加下面代码
if ( $http_from_https != 'on' ){
   rewrite ^(.*) https://www.abc.com$1 permanent;         #abc.com对应修改为您自已的域名
}4、云主机Windows系统 IIS7环境云服务器:【直接在IIS上部署的SSL】在对应站点根目录下新建(通过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" />
               </rule>
            </rules>
      </rewrite>
    </system.webServer>
</configuration>云主机Windows系统 IIS7环境(香港亚洲数据中心机房和管理助手部署的服务器)注意更改为自己的域名<?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" />
               </rule>
            </rules>
      </rewrite>
    </system.webServer>
</configuration>5、虚拟主机windows系统可以通过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" />
               </rule>
            </rules>
      </rewrite>
    </system.webServer>
</configuration>6、云主机Windows系统 IIS6环境参考http://www.west.cn/faq/list.asp?unid=650 配置一个Rewrite,编辑该Rewrite的规则文件httpd.conf 添加以下规则。RewriteEngine On
RewriteCond%{HTTPS} !^on$                                                       
RewriteRule ^(.*)$ https://www.abc.com/$1        # www.abc.com对应修改为您自已的域名
RewriteCond %{HTTP_HOST} !^www\.
RewriteRule ^(.*)$ https://www.abc.com$1       # www.abc.com对应修改为您自已的域名云主机Windows系统 IIS6环境(香港亚洲数据中心机房)RewriteEngine On
RewriteCond %{HTTP:From-Https} !^on$                               
RewriteRule ^(.*)$ https://www.abc.com/$1        # www.abc.com对应修改为您自已的域名
RewriteCond %{HTTP_HOST} !^www\.
RewriteRule ^(.*)$ https://www.abc.com$1       # 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域名,仍在原来站点设置跳转规则。这样就可以了
页: [1]
查看完整版本: 部署https(ssl)后设置301跳转将http跳转到https的解决方法