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

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

文章来源:365jz.com     点击数:1219    更新时间: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条件:

</>code

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

return

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

</>code

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

rewrite

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

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

flags标志:

</>code

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

set指令

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

</>code

  1. 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地址。

示例:

</>code

  1.     if ($request_method = POST) {
  2.         return 405;
  3.     } 
  4.     location ~* /\.(sql|bakup|old|tpl|)$ {
  5.         deny all;
  6.     }
  7.     if (!-f $request_filename){ 
  8.         break;
  9.         proxy_pass  http://127.0.0.1; 
  10.     } 
  11.     location ~* \.(gif|jpg|png|swf|flv)$ {
  12.         valid_referers none blocked  *.xxx.com; 
  13.         if ($invalid_referer) {
  14.             return 404;
  15.         }
  16.     }
  17.     location = / {
  18.         proxy_pass http://new.test.com/index
  19.     }
  20.     location / {
  21.         rewrite  ^/  http://www.baidu.com;
  22.     } 
  23.     location ^~ /static/ {
  24.         root /webroot/static/;
  25.     }
  26.     location ~* \.(gif|jpg|jpeg|png|css|js|ico)$ {
  27.         root /webroot/static/res/;
  28.     }

虚拟主机

</>code

  1. server {
  2.     listen       80;
  3.     server_name  www.test.com;
  4.     root        /usr/share/nginx/html;
  5.     access_log  /var/log/nginx/log/host.access.log  main;
  6.     error_log   /var/log/nginx/log/host.error.log;
  7.     location ~* ^.+\.(jpg|jpeg|gif|png|bmp|css|js|swf|txt)$ {
  8.         access_log off; 
  9.         break;  
  10.     }
  11.     location / { 
  12.         try_files $uri $uri/ /index.php?$query_string;
  13.         index index.php index.html index.htm;
  14.     } 
  15.     error_page  404              /404.html;
  16.     error_page   500 502 503 504  /50x.html;
  17.     location = /50x.html {
  18.         root   /usr/share/nginx/html;
  19.     }
  20.     location ~ \.php$ {
  21.         fastcgi_pass   127.0.0.1:9000;
  22.         fastcgi_index  index.php;
  23.         fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name;
  24.         #fastcgi_pass unix:/var/run/php5-fpm.sock;
  25.         include        fastcgi_params;
  26.     }
  27.     
  28.     location ~* /\. {
  29.         deny all;
  30.     }
  31.     
  32.     
  33. }

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

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



Rewrite规则常见正则表达式


</>code

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


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

发表评论 (1219人查看0条评论)
请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
昵称:
最新评论
------分隔线----------------------------

快速入口

· 365软件
· 杰创官网
· 建站工具
· 网站大全

其它栏目

· 建站教程
· 365学习

业务咨询

· 技术支持
· 服务时间:9:00-18:00
365建站网二维码

Powered by 365建站网 RSS地图 HTML地图

copyright © 2013-2024 版权所有 鄂ICP备17013400号