Discuz!X3.4 X3.3 X3.2部署https(ssl)后设置301跳转将http跳转到https
注意,以下教程针对Discuz!X3.4 X3.3 X3.2站长转https,把规则中域名替换成自己的
linuxt系统 apache环境 云服务器:【直接在apache上部署的SSL】在对应站点根目录下新建(通过ftp或登录wdcp管理面板中:站点列表-文管-进入public_html-创建文件)一个文件命名为.htaccess。 - <IfModule mod_rewrite.c>
- RewriteEngine On
- 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文件写入以下规则: - <IfModule mod_rewrite.c>
- RewriteEngine On
- 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
- {
- listen 80;
- server_name abc.com;
- rewrite ^(.*) https://www.abc.com$1 permanent; # abc.com对应修改为您自已的域名
- }
复制代码
Windows系统 II7环境 云服务器:【直接在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="^(.*)[ DISCUZ_CODE_3 ]quot; ignoreCase="false" />
- <conditions logicalGrouping="MatchAll">
- <add input="{HTTP_FROM_HTTPS}" pattern="^on[ DISCUZ_CODE_3 ]quot; negate="true" />
- <!-- <add input="{HTTPS}" pattern="^on[ DISCUZ_CODE_3 ]quot; 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="^(.*)[ DISCUZ_CODE_4 ]quot; ignoreCase="false" />
- <conditions logicalGrouping="MatchAll">
- <add input="{HTTP_FROM_HTTPS}" pattern="^on[ DISCUZ_CODE_4 ]quot; 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环境 参考http://www.west.cn/faq/list.asp?unid=650 配置一个Rewrite,编辑该Rewrite的规则文件httpd.conf 添加以下规则。 - RewriteEngine On
- 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>
- <!-- 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 x3.2使用301方式强制将http跳转到https后会导致后台uc通信失败。 2、通过该方式设置跳转后,如无法正常跳转访问,请单独建立站点绑定https域名,仍在原来站点设置跳转规则。
请根据操作系统、站点部署数量选择以下相应参考文档,文档仅供参考,如果对技术不熟悉,建议提交草根吧有问必答,由草根吧技术帮您配置(无费用产生)。
A、windows2008+iis7环境SSL部署https单/多站点 B、linux系统SSL部署https单/多站点 C、windows2003系统SSL单站点部署https 以上内容来源于网络,仅供参考。 |