您当前的位置:首页 > 电脑百科 > 安全防护 > 服务器/网站

Apache中将HTTP重定向至HTTPS

时间:2020-01-07 14:24:20  来源:  作者:

Apache HTTP服务器是世界上流行的Web服务器之一。这是一种开源跨平台HTTP服务器,为互联网上很大一部分的网站提供支持。Apache提供了许多强大的功能,可通过额外的模块加以扩展。

如果你是一名网站所有者或系统管理员,很可能常与Apache打交道。你可能执行的最常见任务之一是将HTTP流量重定向至你网站的安全(HTTPS)版本。

不像HTTP以明文格式发送和返回请求和响应,HTTPS使用TLS/SSL来加密客户端和服务器之间的通信内容。

使用HTTPS而不是HTTP有许多优点,比如:

  • 所有数据都是双向加密的。因而,敏感信息即使遭拦截也无法被读取。
  • 谷歌Chrome浏览器和所有其他流行的浏览器会将你的网站标为安全网站。
  • HTTPS让你可以使用HTTP/2协议,从而大大改善网站性能。
  • 谷歌偏爱HTTPS网站。如果网站内容通过HTTPS来提供,你网站的排名会更高。

本文介绍了如何在Apache中将HTTP流量重定向至HTTPS。

在Apache中,有几种方法可以重定向至HTTPS。如果你拥有访问Apache在其中运行的linux服务器的root权限,首选方法是在域名的虚拟主机配置文件中设置重定向。否则,可以在域名的.htaccess文件中设置重定向。

一些控制面板(比如cPanel)让你可以通过点击几下鼠标强制进行HTTPS重定向。

使用虚拟主机将HTTP重定向至HTTPS

Apache虚拟主机定义了服务器上托管的一个或多个域名的设置。在虚拟主机指令中,你可以指定网站文档root(包含网站文件的那个目录)、为每个网站创建单独的安全策略、使用不同的SSL证书、配置重定向等等。

将SSL证书安装到域名上时,通常会有针对该域名的两个虚拟主机指令。第一个面向端口80的网站的HTTP版本,另一个面向端口443的HTTPS版本。

在基于Red Hat的发行版(比如centos和Fedora)中,虚拟主机文件存储在/etc/httpd/conf.d中。在Debian及其衍生版本(比如Ubuntu)上时,文件存储在/etc/apache2/sites-available目录中。

要将网站重定向至HTTPS,使用Redirect指令,如下例所示:

  1. <VirtualHost *:80>
  2.  ServerName example.com
  3.  ServerAlias www.example.com
  4.  Redirect permanent / https://example.com/
  5. </VirtualHost>
  6. <VirtualHost *:443>
  7.  ServerName example.com
  8.  ServerAlias www.example.com
  9.  Protocols h2 http:/1.1
  10.  # SSL Configuration
  11.  # Other Apache Configuration
  12. </VirtualHost>

不妨解释一下代码。我们使用两个虚拟主机指令,一个用于HTTP版本的网站,一个用于HTTPS版本的网站。

  • VirtualHost *:80—Apache服务器在端口80(HTTP)上侦听指定域名的入站连接。
  • VirtualHost *:443—Apache服务器在端口443(HTTPS)上侦听指定域名的入站连接。

ServerName和ServerAlias指令指定虚拟主机的域名。 确保将其换成你的域名。

HTTP虚拟主机中高亮的一行:Redirect permanent / https://example.com/将流量重定向至网站的HTTPS版本。

通常,你还希望将网站的HTTPS www版本重定向至非www,反之亦然。这是一个示例配置:

  1. <VirtualHost *:80>
  2.  ServerName example.com
  3.  ServerAlias www.example.com
  4.  Redirect permanent / https://example.com/
  5. </VirtualHost>
  6. <VirtualHost *:443>
  7.  ServerName example.com
  8.  ServerAlias www.example.com
  9.  Protocols h2 http:/1.1
  10.  <If "%{HTTP_HOST} == 'www.example.com'">
  11.  Redirect permanent / https://example.com/
  12.  </If>
  13.  # SSL Configuration
  14.  # Other Apache Configuration
  15. </VirtualHost>

HTTPS虚拟主机内的代码(高亮的那一行)检查请求报头是否含有www域名、重定向至非www版本。

每当你更改配置文件,都需要重新启动或重新加载Apache服务,以使更改生效:

Debian和Ubuntu:

  1. sudo systemctl reload apache2
  2. CentOS和Fedora:
  3. sudo systemctl reload httpd

使用.htaccess将HTTP重定向至HTTPS

.htaccess是Apache Web服务器基于目录的配置文件。该文件可用于定义Apache如何从文件所在的目录中提供文件以及启用/禁用其他功能。

.htaccess文件通常位于域名根目录中,但你可以将其他.htaccess文件放在子目录中。

该方法要求将mod_rewrite模块加载到Apache服务器上。默认情况下,该模块加载到大多数服务器上。可能的话,最好在虚拟主机中创建重定向,因为这更简单更安全。

要将所有HTTP流量重定向至HTTPS,请打开root .htaccess文件,为它添加以下代码:

  1. RewriteEngine On
  2. RewriteCond %{HTTPS} off
  3. RewriteRule ^(.*)$ https://example.com/$1 [L,R=301]

以下是代码的含义:

  • RewriteEngine On—启用重写功能。
  • RewriteCond %{HTTPS} off—检查HTTP连接,如果条件满足,就执行下一行。
  • RewriteRule ^(.*)$ https://example.com/$1 [L,R=301]—将HTTP重定向至HTTPS,状态代码为301(永久移动)。确保更改了域名。

下面这个例子有一个额外的条件,检查请求是否以www开始。用它迫使所有访客使用网站的HTTPS非www版本:

  1. RewriteCond %{HTTPS} off [OR]
  2. RewriteCond %{HTTP_HOST} ^www.example.com [NC]
  3. RewriteRule ^(.*)$ https://example.com/$1 [L,R=301]

编辑.htaccess文件时,你不需要重启服务器,因为Apache在每次请求时读取文件。

结束语

在Apache中,将HTTP重定向至HTTPS的首选方法是在域名的虚拟主机中配置301 redirect。

原文标题:Redirect HTTP to HTTPS in Apache



Tags:Apache HTTP   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,如有任何标注错误或版权侵犯请与我们联系(Email:2595517585@qq.com),我们将及时更正、删除,谢谢。
▌相关推荐
Apache HTTP服务器是世界上流行的Web服务器之一。这是一种开源跨平台HTTP服务器,为互联网上很大一部分的网站提供支持。Apache提供了许多强大的功能,可通过额外的模块加以扩展...【详细内容】
2020-01-07  Tags: Apache HTTP  点击:(158)  评论:(0)  加入收藏
▌简易百科推荐
在最近的一波攻击中,黑客利用多个插件中未修补的漏洞攻击了 160 万个 WordPress 网站。 易受攻击的插件对 WordPress 网站产生了的巨大攻击数据。 Wordfence 最近发现 WordPr...【详细内容】
2021-12-16  蚁安    Tags:WordPress   点击:(9)  评论:(0)  加入收藏
事件起因从安全分析系统里面发现一条带有病毒的下载,然后针对这条记录展开了一系列的分析分析过程1.登录到被感染服务器,查看系统状况,hadoop 这个用户在 2020/6/18 20:32 从这...【详细内容】
2021-11-23  Z2990Lig    Tags:SSH   点击:(32)  评论:(0)  加入收藏
1、除了服务器需要用的一些正规软件,其它都不要安装。2、在用户中把administrator改名,这样做的目的是即使对方暴破了我们的密码用户名也不容易猜住,相当于又加了一道关卡。...【详细内容】
2021-11-01  IT小哥吧    Tags:服务器   点击:(37)  评论:(0)  加入收藏
账户安全(1)更名administrator本地用户并禁用guest账户步骤:点击“开始”,找到“管理工具”,点击里面的“计算机管理”,找到“本地用户和组” (2)设定账户锁定策略尝试5次失败...【详细内容】
2021-10-12  Kali与编程  今日头条  Tags:Windows主机   点击:(62)  评论:(0)  加入收藏
本文主要介绍以Microsoft的Windows Server 2019 ,版本:Datacenter(Domain Controller)安全加固保护.企业随着规模不断扩大,业务增多,信息安全建设是企业里一条只有重点没有终点...【详细内容】
2021-09-17  Vireshark    Tags:服务器安全   点击:(64)  评论:(0)  加入收藏
目录常见共享命令IPC$IPC$的利用条件1:开启了139、445端口2:目标主机开启了IPC$共享3:IPC连接报错IPC空连接空连接可以做什么?(毫无作用)IPC$非空连接IPC$非空连接可以做什么?di...【详细内容】
2021-09-16  网络说安全    Tags:系统安全   点击:(86)  评论:(0)  加入收藏
昨天一个老哥找到我,说他的服务器这几天一直被CC攻击,问我这边有没有什么解决的方法? 近年来,网络攻击事件越来越频繁,最常见的就是CC攻击和DDOS攻击,主要的区别就是针对的对象不...【详细内容】
2021-09-10  小蚁GDRAGON    Tags:cc攻击   点击:(58)  评论:(0)  加入收藏
网站页面上的登录操作,通常都是输入帐号密码,传输至网站后台验证。在网站页面、数据传输中,通过技术手段,都可以得到用户输入的信息,并可以修改,从而发起网络攻击。典型的如:使用自...【详细内容】
2021-08-30  修丹道的程序猿    Tags:登录方式   点击:(62)  评论:(0)  加入收藏
网络安全研究人员披露了一类影响主要 DNS 即服务 (DNSaaS) 提供商的新漏洞,这些漏洞可能允许攻击者从企业网络中窃取敏感信息。基础设施安全公司 Wiz 的研究人员 Shir Tamar...【详细内容】
2021-08-12  零日时代    Tags:漏洞   点击:(66)  评论:(0)  加入收藏
001暴力破解1. 指定用户名爆破密码传统型爆破思路,用户名可以通过猜测或者信息收集获得。猜测:admin、网站域名等信息收集:新闻发布人、whoami等2. 指定密码爆破用户名如果是后...【详细内容】
2021-07-23  KaliMa  今日头条  Tags:登陆框   点击:(85)  评论:(0)  加入收藏
最新更新
栏目热门
栏目头条