Apache服务Rwrite功能使用

Rewrite也称为规则重写,主要功能是实现浏览器访问时,URL的跳转。其正则表达式是基于Perl语言。要使用rewrite功能,Apache服务器需要添加rewrite模块。如果使用源码编译安装,--enable-rewrite。有了rewrite模块后,需要在apache配置文件httpd.conf中全局配置段开启rewrite功能,或者在虚拟机主机配置段来设置也是可以的。开启指令:RewriteEngine on

要使用apache rewrite,先要理解什么是rewrite结尾标识符,以前一些常用表达式及apache rewrite变量。

1、几个结尾标识符:

R[=code](force redirect) #强制外部重定向

G(force URL to be gone) #强制URL为GONE,返回410HTTP状态码

P(force proxy) #强制使用代理转发

L(last rule) #匹配当前规则为最后一条匹配规则,停止匹配后续规则

N(next round) #重新从第一条规则开始匹配

NC(no case) #不区分大小写

2、几个常用表达式

. #匹配任何单字符 ,? #匹配0到1个字符 ,* 匹配0到多个字符 ,+ 匹配1到多个字符

^ 字符串开始标志

3、Rewrite变量,用于匹配HTTP请求头信息,浏览器主机机,URL等。如下几个常用变量

HTTP headers ,HTTP_HOST,HTTP_ACCEPT,HTTP_USER_AGENT

使用举例:

将www.a.com跳转到www.b.com

首先在httpd配置文件启用rewrite功能模块

然后在虚拟主机中开启rewrite功能,并添加rewrite规则

go 复制代码
<VirtualHost *:80>
    ServerAdmin 77932692@qq.com
    DocumentRoot "/usr/local/apache2/htdocs/www.a.com"
    ServerName www.a.com
    #ServerAlias www.dummy-host.example.com
    ErrorLog "logs/www.a.com-error_log"
    CustomLog "logs/www.a.com-access_log" common
    RewriteEngine on
    RewriteCond %{HTTP_HOST}  ^www.a.com [NC]
    RewriteRule ^/(.*)$ http://www.b.com/$1 [L]
</VirtualHost>

<VirtualHost *:80>
    ServerAdmin 77932692@qq.com
    DocumentRoot "/usr/local/apache2/htdocs/www.b.com"
    ServerName www.b.com
    ErrorLog "logs/www.b.com-error_log"
    CustomLog "logs/www.b.com-access_log" common
</VirtualHost>

最后重启apache服务,浏览器测试,地址输入www.a.com时自动跳转到www.b.com

Rewrite用法非常多,以上只是简单介绍其用法。

相关推荐
ZHOU_WUYI1 天前
Apache Spark 集群部署与使用指南
大数据·spark·apache
有一个好名字1 天前
万字 Apache ShardingSphere 完全指南:从分库分表到分布式数据库生态
数据库·分布式·apache
羑悻的小杀马特1 天前
下一代时序数据库标杆:Apache IoTDB架构演进与AIoT时代的数据战略
apache·时序数据库·iotdb
cesske2 天前
uniapp 编译支付宝小程序canvas 合成图片实例,支付宝小程序 canvas 渲染图片 可以换成自己的图片即可
小程序·uni-app·apache
、花无将3 天前
PHP:下载、安装、配置,与apache搭建
android·php·apache
wei_shuo4 天前
Apache IoTDB 架构特性与 Prometheus+Grafana 监控体系部署实践
架构·apache·iotdb
熊文豪4 天前
Windows安装Apache Kafka保姆级教程(图文详解+可视化管理工具)
windows·kafka·apache
左师佑图6 天前
Apache POI SXSSFWorkbook 报错“没有那个文件或目录”问题排查与解决方案
java·apache·excel
华阙之梦6 天前
【在 Windows 上运行 Apache Hadoop 或 Spark/GeoTrellis 涉及 HDFS 】
hadoop·windows·apache
SelectDB技术团队6 天前
Apache Doris 与 ClickHouse:运维与开源闭源对比
运维·clickhouse·apache