gpt4 book ai didi

详解百度https认证提示"请将您的http站点301重定向到https站点"的解决办法

转载 作者:qq735679552 更新时间:2022-09-29 22:32:09 27 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章详解百度https认证提示"请将您的http站点301重定向到https站点"的解决办法由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

最近想把一个网站改造成https访问,但是一些都做好了,去百度站长平台认证https,结果怎么提交都是出现“请将您的http站点301重定向到https站点”,在百度站长社区提问也没有人回答,最后只能自己摸索。后面找到了原因:原来百度的https认证是严格遵守301重定向的,我用的是iis6,之前的代码为:

?
1
2
3
4
5
RewriteEngine On
 
RewriteCond %{SERVER_PORT} !^443$
 
RewriteRule (.*) https://%{SERVER_NAME}/$1 [R]

这种写法虽然能够实现将http全部跳转到https,但是在百度站长平台是通不过的。最后将代码修改为以下后便通过了 。

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

下面我搜集整理了各种网站环境的部署https(ssl)后设置301跳转的代码,希望能够对大家有所帮助.

linuxt系统 apache环境 。

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

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

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

?
1
2
3
4
5
6
7
< 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-对应站点配置文件),添加以下规则 。

?
1
2
3
4
5
6
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并编辑添加以下规则:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
<? 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并编辑添加以下规则:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
<? 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 添加以下规则.

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

tomcat环境 。

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

?
1
2
3
4
5
6
7
8
9
10
< 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域名,仍在原来站点设置跳转规则.

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我.

最后此篇关于详解百度https认证提示"请将您的http站点301重定向到https站点"的解决办法的文章就讲到这里了,如果你想了解更多关于详解百度https认证提示"请将您的http站点301重定向到https站点"的解决办法的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com