Apache中伪静态Rewrite的使用方法和URL重写规则表达式讲解

本站所有内容来自互联网收集,仅供学习和交流,请勿用于商业用途。如有侵权、不妥之处,请第一时间联系我们删除!Q群:迪思分享

免费资源网 – https://freexyz.cn/
目录一、安装rewrite模块二、配置文件httpd.conf中启用Rewrite三、在服务器中找到配置文件vhosts.conf,启用.htaccess四、在要启用伪静态的项目根目录下建立 .htaccess 文件五、重启Apache服务器,就OK了六、参数补充说明

apache中的mod_rewrite模块提供了一个基于正则表达式分析器的重写引擎来实时重写URL请求,主要的功能就是实现URL的跳转,它的正则表达式是基于Perl语言。可基于服务器级的(httpd.conf)和目录级的(.htaccess)两种方式,允许通过它来改变Apache Web服务器的配置。它支持每个完整规则可以拥有不限数量的子规则以及附加条件规则的灵活而且强大的URL操作机制。此URL操作可以依赖于各种测试,比如服务器变量、环境变量、HTTP头、时间标记,甚至各种格式的用于匹配URL组成部分的查找数据库。

而配置伪静态的方法,需要根据web服务器的不同来做不同的配置,一般常用的有Apache服务器和Nginx服务器,本篇只介绍在Apache服务器上开启和通过.htaccess文件来配置伪静态的方法。

一、安装rewrite模块

如果要想用到rewrite模块,必须确保在已安装或加载rewrite模块。一般在编译apache的时候就安装了rewrite模块。

二、配置文件httpd.conf中启用Rewrite

打开Apache配置文件httpd.conf,找到代码:

#LoadModule rewrite_module modules/mod_rewrite.so

把前面#去掉。没有则添加,但必须独占一行,使apache支持 mod_rewrite 模块。

三、在服务器中找到配置文件vhosts.conf,启用.htaccess

打开虚拟机配置文件vhosts.conf,找到代码:

AllowOverride None 修改为: AllowOverride All

使Apache支持 .htaccess 文件

四、在要启用伪静态的项目根目录下建立 .htaccess 文件

在.htaccess 文件中输入内容,示例如下

< IfModule mod_rewrite.c> Options +FollowSymlinks -Multiviews RewriteEngine On RewriteCond %{REQUEST_FILENAME} !-d RewriteCond %{REQUEST_FILENAME} !-f #RewriteRule RewriteRule index.html$ index.php #RewriteRule ^(.*?).html$ index.php?$1.html [QSA,PT,L] #RewriteRule ^/index([0-9]*).html$ /index.php?id=$1 #更多伪静态规则 < /IfModule>

// RewriteEngine on 为 启动rewrite引擎

// RewriteRule 部分为自己的伪静态规则

五、重启Apache服务器,就OK了

六、参数补充说明

1、RewriteEngine 为重写引擎开关,on为开启,off为关闭。

2、RewriteRule 是路由转向规则,之前路径为浏览器中要输入路径,这里可以用正则表达式表达。+空格 后路径为后台实际转向路径。

3、转向后台实际路径时可以传参数,$1 代表浏览器路径中输入的第一个正则表达式的值,以此类推,$2代表第二个正则表达式的值。

4、RewriteRule 路由转向规则里正则表达式用括号 () 括起来。

5、在RewriteRule写法中,^表示语句开始,$ 表示语句的结束,L 表明当前规则是最后一条规则,停止分析以后重写,NC表示不区分大小写,QSA表示追加请求的字符串。

RewriteRule规则表达式的说明: . 匹配任何单字符 [chars] 匹配字符串:chars [^chars] 不匹配字符串:chars text1|text2 可选择的字符串:text1或text2 ? 匹配0到1个字符 * 匹配0到多个字符 + 匹配1到多个字符 ^ 字符串开始标志 $ 字符串结束标志 n 转义符标志

6、补充Apache mod_rewrite规则重写的标志说明:

1) R[=code](force redirect) 强制外部重定向 强制在替代字符串加上http://thishost[:thisport]/前缀重定向到外部的URL.如果code不指定,将用缺省的302 HTTP状态码。 2) F(force URL to be forbidden)禁用URL,返回403HTTP状态码。 3) G(force URL to be gone) 强制URL为GONE,返回410HTTP状态码。 4) P(force proxy) 强制使用代理转发。 5) L(last rule) 表明当前规则是最后一条规则,停止分析以后规则的重写。 6) N(next round) 重新从第一条规则开始运行重写过程。 7) C(chained with next rule) 与下一条规则关联 如果规则匹配则正常处理,该标志无效,如果不匹配,那么下面所有关联的规则都跳过。 8) T=MIME-type(force MIME type) 强制MIME类型 9) NS (used only if no internal sub-request) 只用于不是内部子请求 10) NC(no case) 不区分大小写 11) QSA(query string append) 追加请求字符串 12) NE(no URI escaping of output) 不在输出转义特殊字符
免费资源网 – https://freexyz.cn/


© 版权声明
THE END
★喜欢这篇文章吗?喜欢的话,麻烦动动手指支持一下!★
点赞5 分享
评论 抢沙发

请登录后发表评论

    暂无评论内容