您现在的位置: 365建站网 > 365学习 > Rewrite规则伪静态的配置和常见正则表达式

Rewrite规则伪静态的配置和常见正则表达式

文章来源:365jz.com     点击数:324    更新时间:2018-07-30 08:53   参与评论

Windows server 2008R2 IIS7.5 Rewrite伪静态规则
使用说明:
1. 将 Rewrite 拷贝到G:\Rewrite
2. 在IIS的Isapi上添加这个筛选器, 筛选器名称Rewrite,可执行文件选择 Rewrite.dll
3. 重新启动IIS
4. httpd.ini 是配置文件,如果您了解Rewrite 规则,可以直接对其进行编辑
5. 规则适用于: DZ6.0/DZ6.1/DZ7.0/DZ7.2

图解:

点击左边IIS站点

 

打开Isapi筛选器

 

增加Rewrite规则

 


nginx rewrite 规则

rewrite主要的功能就是实现URL的重写,Nginx的Rewrite规则采用perl兼容正则表达式的语法规则匹配

需要Nginx的Rewrite功能,在编译Nginx之前,需要编译安装PCRE库。

通过Rewrite规则,可以实现规范的URL、根据变量来做URL转向及选择配置。例如:单一入口,伪静态,URL跳转等。

指定

指令包括:   if、rewrite、set、return、break等

if指令

作用域:server,location

对给定的条件判断。如果为真,大括号内的rewrite指令将被执行。

if条件:

变量名,错误的值包括:空字符串或者以0开始的字符串;
= ,!= 变量比较
~ 区分大小写字母匹配
~* 不区分大小写字母匹配
!~ 区分大小写字母不匹配
!~* 不区分大小写字母不匹配
-f,!-f 检查一个文件是否存在
-d,!-d 检查一个目录是否存在
-e ,!-e 检查一个文件、目录、符号链接是否存在
x ,!-x 检查一个文件是否可执行

return

停止处理并返回指定状态码(code)给客户端。

if ($host !~ "^((.*\.)?(xxx\.(com|com\.cn|cn)|\d{1,3}(\.\d{1,3}){3})(:\d+)?$") { 
   return 403;
}

rewrite

如果一个URI匹配指定的正则表达式regex,URI就按照replacement重写。

rewrite按配置文件中出现的顺序执行。flags标志可以停止继续处理。

flags标志:

last 重写后,马上发起一个新的请求,再次进入server块,重试location匹配,超过10次匹配不到报500错误break 直接使用当前资源,不再执行location里余下的语句,完成本次请求
redirect 返回302临时重定向,地址栏显示重定向后的url
permant 返回301永久重定向

set指令

定义一个变量并赋值,值可以是文本,变量或者文本变量混合体。

set $varname 'hello';

uninitialized_variable_warn

开启或关闭记录未初始化变量的警告信息,默认开启

Rewrite常用的全局变量

  • $args:变量中存放了URL中的指令。

  • $content_length:保存了请求报文头部中的content-lenght字段。

  • $content_type:保存了请求头部中的content-type字段。

  • $document_root:保存了针对当前资源的请求的系统根目录。

  • $document_uri:保存了当前请求中不包含指令的URI,主注意是不包含请求的指令。

  • $host:存放了请求的服务器名称。

  • $http_user_agent:客户端浏览器的详细信息。

  • $http_cookie:客户端的cookie信息。

  • $limit_rate:如果nginx服务器使用limit_rate配置了显示网络速率,则会显示,如果没有设置, 则显示0。

  • $remote_addr:存放了客户端的地址,注意是客户端的公网IP,也就是一家人访问一个网站,则会显示为路由器的公网IP。

  • $remote_port:客户端请求Nginx服务器时随机打开的端口,这是每个客户端自己的端口。

  • $remote_user:已经经过Auth Basic Module验证的用户名。

  • $request_body_file:做反向代理时发给后端服务器的本地资源的名称。

  • $request_method:请求资源的方式,GET/PUT/DELETE等。

  • $request_filename:当前请求的资源文件的路径名称,由root或alias指令与URI请求生成。

  • $request_uri:包含请求参数的原始URI,不包含主机名。

  • $squery_string:保存了URL请求的指令,与 $args相同。

  • $scheme:请求的协议,如ftp,https,http等。

  • $server_protocpl:保存了客户端请求资源使用的协议的版本,如HTTP/1.0,HTTP/1.1,HTTP/2.0等。

  • $server_addr:保存了服务器的IP地址。

  • $server_name:服务器的主机名。

  • $server_port:服务器的端口号。

  • $uri:与$document_uri相同,是一个不包含指令的uri地址。

示例:

    if ($request_method = POST) {
        return 405;
    } 

    location ~* /\.(SQL|bakup|old|tpl|)$ {
        deny all;
    }

    if (!-f $request_filename){ 
        break;
        proxy_pass  http://127.0.0.1; 
    } 


    location ~* \.(gif|jpg|png|swf|flv)$ {
        valid_referers none blocked  *.xxx.com; 
        if ($invalid_referer) {
            return 404;
        }
    }

    location = / {
        proxy_pass http://new.test.com/index
    }

    location / {
        rewrite  ^/  http://www.baidu.com;
    } 

    location ^~ /static/ {
        root /webroot/static/;
    }

    location ~* \.(gif|jpg|jpeg|png|CSS|js|ico)$ {
        root /webroot/static/res/;
    }

虚拟主机

server {
    listen       80;
    server_name  www.test.com;
    root        /usr/share/nginx/HTML;

    access_log  /var/log/nginx/log/host.access.log  main;
    error_log   /var/log/nginx/log/host.error.log;

    location ~* ^.+\.(jpg|jpeg|gif|png|bmp|css|js|swf|txt)$ {
        access_log off; 
        break;  
    }

    location / { 
        try_files $uri $uri/ /index.PHP?$query_string;
        index index.php index.html index.htm;
    } 

    error_page  404              /404.html;
    error_page   500 502 503 504  /50x.html;
    location = /50x.html {
        root   /usr/share/nginx/html;
    }

    location ~ \.php$ {
        fastcgi_pass   127.0.0.1:9000;
        fastcgi_index  index.php;
        fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name;
        #fastcgi_pass unix:/var/run/php5-fpm.sock;
        include        fastcgi_params;
    }
    
    location ~* /\. {
        deny all;
    }
    
    
}

应该在 php.ini 文件中设置cgi.fix_pathinfo=0, 能避免掉很多不必要的 stat() 系统调用。

当运行一个 HTTPS 服务器时,需要添加 fastcgi_param HTTPS on;这样才能正确地判断连接是否安全。



Rewrite规则常见正则表达式


~      为区分大小写的匹配。
~*     不区分大小写的匹配(匹配firefox的正则同时匹配FireFox)。
!~     不匹配的
!~*    不匹配的
.     匹配除换行符以外的任意字符
\w     匹配字母或数字或下划线或汉字
\s     匹配任意的空白符
\d     匹配数字
\b     匹配单词的开始或结束
^     匹配字符串的开始
$     匹配字符串的结束
*     重复零次或更多次
+     重复一次或更多次
?     重复零次或一次
{n}     重复n次
{n,}     重复n次或更多次
{n,m}     重复n到m次
*?     重复任意次,但尽可能少重复
+?     重复1次或更多次,但尽可能少重复
??     重复0次或1次,但尽可能少重复
{n,m}?     重复n到m次,但尽可能少重复
{n,}?     重复n次以上,但尽可能少重复
\W     匹配任意不是字母,数字,下划线,汉字的字符
\S     匹配任意不是空白符的字符
\D     匹配任意非数字的字符
\B     匹配不是单词开头或结束的位置
[^x]     匹配除了x以外的任意字符
[^aeiou]     匹配除了aeiou这几个字母以外的任意字符
捕获     (exp)     匹配exp,并捕获文本到自动命名的组里
(?<name>exp)     匹配exp,并捕获文本到名称为name的组里,也可以写成(?'name'exp)
(?:exp)     匹配exp,不捕获匹配的文本,也不给此分组分配组号
零宽断言     (?=exp)     匹配exp前面的位置
(?<=exp)     匹配exp后面的位置
(?!exp)     匹配后面跟的不是exp的位置
(?<!exp)     匹配前面不是exp的位置
注释     (?#comment)     这种类型的分组不对正则表达式的处理产生任何影响,用于提供注释让人阅读


如对本文有疑问,请提交到交流论坛,广大热心网友会为你解答!! 点击进入论坛


发表评论 (324人查看0条评论)
请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
用户名: 验证码: 点击我更换图片
最新评论
------分隔线----------------------------