一直在用腾讯云做https访问,因为腾讯云HTTPS设置中有“强制跳转HTTPS: ”之前一直可以过百度的HTTPS认证,但最近改了,必须要强行301转向认证,各种方式尝试,无法通过,经过自行研究,找到如下可以确实可行的方法,顺利通过HTTPS认证!

站长平台为,IIS7.0 Windows2012操作系统下,打开我们的网站目录,下面有个web.config文件,打开,另存一份备份,把下面的代码复制进入,即可解决!
<?xml version=”1.0″ encoding=”UTF-8″?>
<configuration>
  <system.webServer>
    <rewrite>
      <rules>
            <rule name=”wordpress” patternSyntax=”Wildcard”>
                <match url=”*” />
                    <conditions>
                        <add input=”{REQUEST_FILENAME}” matchType=”IsFile” negate=”true” />
                        <add input=”{REQUEST_FILENAME}” matchType=”IsDirectory” negate=”true” />
                    </conditions>
                <action type=”Rewrite” url=”index.php” />
            </rule>
                    <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.zdfans.com.cn/{R:1}” redirectType=”Permanent” />
               </rule></rules>
    </rewrite>
  </system.webServer>
</configuration>

测试是否已经301生效地址:http://tool.chinaz.com/pagestatus/?url=zdfans.com.cn


以下是其他各种网站环境的部署https(ssl)后设置301跳转的代码,希望能对其他平台环境的朋友有所帮助。

linuxt系统 apache环境

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

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

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

<IfModule mod_rewrite.c>
RewriteEngine On
RewriteCond %{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.zdfans.com.cn/{R:1}” redirectType=”Permanent” />      # www.zdfans.com.cn修改为您的域名
</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环境

配置一个Rewrite,编辑该Rewrite的规则文件httpd.conf或者.htaccess 添加以下规则。

RewriteEngine On
RewriteCond %{SERVER_PORT} !^443$
RewriteRule ^.*$ https://%{SERVER_NAME}%{REQUEST_URI} [L,R=301]

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域名,仍在原来站点设置跳转规则。

评论反馈