Apache服务器中的.htaccess文件的配置

如何在windows下创建.htaccess文件

首先, 暂且别管.htaccess是什么, 有什么作用, 让我们暂且解决首要问题:如何在windows下创建.htaccess文件。 在windows中不允许重命名时.的前面没有字符, 认为这是不合法的文件名,这就造成我们无法通过重命名”新建文本文档.txt”为”.htaccess”来创建此访问控制文件

  1. 使用DOS命令,在DOS下有三种方法可供选择

    1. 使用屏幕编辑命令copy con .htaccess后回车,输入内容,最后按下ctrl+z结束编辑,就成功生成了.htaccess;
    2. 使用重命名命令ren 1.txt .htaccess ,这是最常规的方法了,在windows窗口下不能执行的命令,在cmd下却如履平地;
    3. 使用重定向命令 echo. >.htaccess,这里将一个回车符输入到.htaccess,同样能创建成功;

      三种方法一并截图如下:
      这里写图片描述

  2. 用winrar的文件管理器,先新建一文本文档,然后打开winrar主界面,定位到该文件,可以直接重命名,这是我在解压一国外开源项目时,其自带的.htaccess居然能正确解压出来时,所得到的启发,当然你使用7zip之类的管理器也是可以的
    这里写图片描述

  3. 直接通过文本编辑工具保存,例如记事本,ultraEdit等等,不过保存的时候选择所有文件就可以了
    这里写图片描述

  4. 使用php中的文件创建方法,fopen,file_put_contents文件名直接取.htaccess就成

apache httpd.conf常用指令

  1. < IfDefine > 指令
    说明: 封装一组只有在启动时当测试结果为真时才生效的指令
    语法 < IfDefine [!]parameter-name > …
    作用域 server config, virtual host, directory, .htaccess

  2. < IFModule mod_rewrite.c > < /IFModule >
    说明: 封装指令并根据指定的模块是否启用为条件而决定是否进行处理
    语法: < IfModule [!]module-file|module-identifier > … < /IfModule >
    作用域 server config, virtual host, directory, .htaccess 覆盖项 All
    如:

<IFModule mod_rewrite.c>
RewriteRule ^(.*)$ index.php \/$1 [L]  #L:立即停止重写操作,并不再应用其他重写规则
<IFModule>
  1. < Files * > < /Files>
<Files ~ "^.*\.([Ll][Oo][Gg])|([eE][xX][eE])">   # ~ 波浪线表示启用正则表达式 
#Order命令:通过Allow,Deny参数,Apache首先找到并应用Allow命令,然后应用Deny命令,以阻止所有访问,也可以使用Deny,Allow
order allow, deny  
Deny from all
</Files>

下面正式开八.htaccess

.htaccess是什么

  • .htaccess文件(或者”分布式配置文件”)提供了针对目录改变配置的方法, 即,在一个特定的文档目录中放置一个包含一个或多个指令的文件, 以作用于此目录及其所有子目录。作为用户,所能使用的命令受到限制。管理员可以通过Apache的AllowOverride指令来设置。
  • 概述来说,htaccess文件是Apache服务器中的一个配置文件,它负责相关目录下的网页配置。通过htaccess文件,可以帮我们实现:网页301重定向、自定义404错误页面、改变文件扩展名、允许/阻止特定的用户或者目录的访问、禁止目录列表、配置默认文档等功能。
  • 启用.htaccess,需要修改httpd.conf,启用AllowOverride,并可以用AllowOverride限制特定命令的使用。如果需要使用.htaccess以外的其他文件名,可以用AccessFileName指令来改变。例如,需要使用.config ,则可以在服务器配置文件中按以下方法配置:AccessFileName .config 。
  • 笼统地说,.htaccess可以帮我们实现包括:文件夹密码保护、用户自动重定向、自定义错误页面、改变你的文件扩展名、封禁特定IP地址的用户、只允许特定IP地址的用户、禁止目录列表,以及使用其他文件作为index文件等一些功能。
  • .htaccess文件可以在网站目录树的任何一个目录中,只对该文件所在目录中的文件和子目录有效。

  • 注意:

    1. 子目录中的指令会笼盖更高级目录或者主器配置中的指令。
      如果 .htaccess 文件保存在 /apache/home/www/Gunjit/ 目录,那么它会向该目录中的所有文件和子目录提供命令,但如果该目录包含一个名为 /Gunjit/images/ 子目录,且该子目录中也有一个 .htaccess 文件,那么这个子目录中的命令会覆盖父目录中 .htaccess 文件(或者目录层次结构中更上层的文件)提供的命令。

      .htaccess文件中的配置指令作用于.htaccess文件所在的目录及其所有子目录,但是很重要的、需要注意的是,其上级目录也可能会有.htaccess文件,而指令是按查找顺序依次生效的,所以一个特定目录下的.htaccess文件中的指令可能会覆盖其上级目录中的.htaccess文件中的指令,即子目录中的指令会覆盖父目录或者主配置文件中的指令。

    2. .htaccess必需以ASCII模式上传,最好将其权限设置为644。
    3. 使用.htaccess文件,会降低httpd服务器的一点性能

为什么要使用.htaccess

很多网站都是租用服务器和虚拟主机的,其服务器的配置我们并不能改。当我们有特殊要求时,比如定义最简单的404(页面未找到)的错误页面,我们就只能通过apache配置的扩展配置(或者说是子配置)来更改扩展原服务器的配置。这个配置就是.htaccess文件,他是apache下的http.conf文件的延续。

如何启用.htaccess

要在服务器上使用.htaccess文件配置,必须要求服务器开通对于的支持。两个条件:1.mod_rewrite模块开启;2. AllowOverride All, 如何配置:
1. 启用AllowOverride。打开httpd.conf, 将工作目录下的AllowOverride None 改为AllowOverride All。

<VirtualHost *:80>
    ServerName www.nhs.com
    ServerAlias nhs.com
    DocumentRoot D:/projects/htdocs/nhs/nfs_cms
    <Directory  "D:/projects/htdocs/nhs/nfs_cms/">
        Options +Indexes +Includes +FollowSymLinks +MultiViews
        AllowOverride All
        Require local
    </Directory>
</VirtualHost>

2.. 开启.mod_rewrite模块。将#LoadModule rewrite_module modules/mod_rewrite.so前的#去掉即可。
3. 重启apache

一般情况下,不应该使用.htaccess文件

一般情况下,不应该使用.htaccess文件,除非你对主配置文件没有访问权限。建议把用户认证写在主配置文件中,而且是一种很好的方法。

.htaccess文件应该被用在内容提供者需要针对特定目录改变服务器的配置而又没有root权限的情况下。如果服务器管理员不愿意频繁修改配置,则可以允许用户通过.htaccess文件自己修改配置,尤其是ISP在同一个机器上运行了多个用户站点,而又希望用户可以自己改变配置的情况下。

虽然如此,一般都应该尽可能地避免使用.htaccess文件。任何希望放在.htaccess文件中的配置,都可以放在主配置文件的段中,而且更高效。

  • 避免使用.htaccess文件有两个主要原因

    1. 首先是性能。
      如果AllowOverride启用了.htaccess文件,则Apache需要在每个目录中查找.htaccess文件,因此,无论是否真正用到,启用.htaccess都会导致性能的下降。另外,对每一个请求,都需要读取一次.htaccess文件。还有,Apache必须在所有上级的目录中查找.htaccess文件,以使所有有效的指令都起作用,
      所以,如果请求/ctusky/ctu/sky中的页面,Apache必须查找以下文件:

      /.htaccess
      /ctusky/.htaccess
      /ctusky/ctu/.htaccess
      /ctusky/ctu/sky/.htaccess  一共就要访问4个额外的文件,就算这些文件都不存在,这也是本文开始说会影响服务器的一点性能的原因

    2. 其次是安全。这样会允许用户自己修改服务器的配置,这可能会导致某些意想不到的修改,所以请认真考虑是否应当给予用户这样的特权。

注意,在/www/htdocs/example目录下的.htaccess文件中放置指令,与在主配置文件中<Directory /www/htdocs/example>段中放置相同指令,是完全等效的。

/www/htdocs/example目录下的.htaccess文件的内容:
AddType text/example .exm
httpd.conf文件中摘录的内容:   
<Directory /www/htdocs/example>   
AddType text/example .exm   
</Directory>
   
但是,把配置放在主配置文件中更加高效,因为只需要在Apache启动时读取一次,而不是在每次文件被请求时都读取。 将AllowOverride设置为none可以完全禁止使用.htaccess文件:   
AllowOverride None

.htaccess实现各种功能的配置写法

<Directory "D:/wamp/www/testphp/">*****</Directory> 这个是最重要的一步了,这里也是填本项目的路径,然后所有的rewrite规则都是在里面完成。所以这个是很重要的。
Options Indexes FollowSymLinks 这是来设置 是否来显示文件根目录的目录列表的
Options Indexes FollowSymLinks 就表示:我访问www.nhs.com,如果文件根目录里有 index.html(index.php),浏览器就会显示 index.html的内容,如果没有 index.html,浏览器就会显示这文件根目录的目录列表,目录列表包括文件根目录下的文件和子目录。

  • 自定义错误页面
    用法:ErrorDocument 错误代码 空格 /目录名/文件名.扩展名
如:
ErrorDocument 401 /err/401.php    #配置错误页面
ErrorDocument 403 /err/403.php
ErrorDocument 404 /404.html
ErrorDocument 500 /help/errors/internalerror.html
  • 页面或网址重定向
    写法1: Redirect permanent [old directory or file name] [new directory or file name]
    其中permanent(永久)是为了告诉搜索引擎,老的链接已经移到新链接了。
    写法2:Redirect /旧页面地址 新页面的地址
Redirect permanent /oldhtmlfile.htm http://your-domain.com/newhtmlfile.htm

这可以帮助我们将用户引导到我们想让其看到的页面,也可以用作域名的重定向

  • 改变缺省的首页
    多个文件名之间可以用空格隔开,这样就会按顺序将所有列出的文件列为可能的索引文件, 记住,每一个入口只能写在一行.
#定义索引文件, 服务器会从左至右进行寻找,检查哪个文档在真实的目录中存在。如果一个也找不到,它将会把目录列表显示出来(除非你已经关闭了显示目录文件列表)
DirectoryIndex index.php index.php3 index.html index.htm   
DirectoryIndex homapage.html somepage.html myindexpage.html anything.html
  • 安全配置

    • 防止网页图片被盗连
      很多服务器供应商都是限流量和限cpu的。特别是流量,每个月超过了限制的流量就需要支付额外的大洋,而自己网站的图片被盗链这就相当于别人耗了你的流量却并没有给你带来流量。那是相当郁闷的。自然要防止被盗连。同时有些隐私比如用户的相册如果被盗连了可能泄露隐私,这也是不好的。你可以看到百度空间,sina博客,qq空间均作了防盗链的处理。

      
      #写法:
      
      RewriteEngine on
      RewriteCond %{HTTP_REFERER} !^$
      RewriteCond %{HTTP_REFERER} !^http://(www\.)?your-domain.com/.*$ [NC]
      RewriteRule .(gif|jpg)$ - [F]
      
      
      #或者用图片代替之,这样别人盗链的图片就会显示你所要提示的图片。
      
      RewriteEngine on
      RewriteCond % !^$
      RewriteCond % !^http://(www/.)?域名.com/.*$ [NC]
      RewriteRule /.(gif|jpg)$ http://www.域名.com/替代图片文件名 [R,L]
    • 防黑客

      
      #辅导辅导
      
      RewriteEngine On
      
      
      #proc/self/environ? 没门!  
      
      RewriteCond %{QUERY_STRING} proc/self/environ [OR]  
      
      
      # 阻止脚本企图通过URL修改mosConfig值  
      
      RewriteCond %{QUERY_STRING} mosConfig_[a-zA-Z_]{1,21}(=|%3D) [OR]  
      
      
      # 阻止脚本通过URL传递的base64_encode垃圾信息  
      
      RewriteCond %{QUERY_STRING} base64_encode.*(.*) [OR]  
      
      
      # 阻止在URL含有<script>标记的脚本  
      
      RewriteCond %{QUERY_STRING} (<|%3C).*script.*(>|%3E) [NC,OR]  
      
      
      # 阻止企图通过URL设置PHP的GLOBALS变量的脚本  
      
      RewriteCond %{QUERY_STRING} GLOBALS(=|[|%[0-9A-Z]{0,2}) [OR]  
      
      
      # 阻止企图通过URL设置PHP的_REQUEST变量的脚本  
      
      RewriteCond %{QUERY_STRING} _REQUEST(=|[|%[0-9A-Z]{0,2})  
      
      
      # 把所有被阻止的请求转向到403禁止提示页面!  
      
      RewriteRule ^(.*)$ index.php [F,L]
    • 禁止/允许显示目录列表

      Options -Indexes  #禁止目录被浏览 
      Options +Indexes  #允许目录被浏览
      
      #如果你的目录里没有index文件,当有人在浏览器地址栏键入了该目录的路径,该目录下所有的文件都会显示出来如果你的目录里没有index文件,当有人在浏览器地址栏键入了该目录的路径,该目录下所有的文件都会显示出来,为避免这种情况,可以在.htaccess文档中键入以下命令,用以阻止目录列表的显示
      
    • 阻止/允许特定的IP地址

      deny from 192.168.0.188   #封禁单个ip
      deny from 210.10.56.0210.10.56.255   #封禁ip段
      deny from all #阻止所有人访问该目录
    • 阻止别人访问你的.htaccess文件

      <Files .htaccess>
      order allow.deny
      deny from all
      </Files>
    • 阻止访问多种文件类型

      <FilesMatch ".(htaccess|htpasswd|ini|phps|fla|psd|log|sh)$">  
       Order Allow,Deny  
      Deny from all  
      </FilesMatch>[/code]
    • 禁止脚本执行,加强你的目录安全

      AddHandler cgi-script .php .pl .py .jsp .asp .htm .shtml .sh .cgi  
      Options -ExecCGI
  • 设置时区
SetEnv TZ Australia/Melbourne
  • 搜索引擎友好的301永久转向方法
Redirect 301 http://www.nhs.com/home http://www.nhs.com/
  • 屏蔽下载对话框
AddType application/octet-stream .pdf  
AddType application/octet-stream .zip  
AddType application/octet-stream .mov
  • 省去www前缀
RewriteBase /  
RewriteCond %{HTTP_HOST} ^www.aqee.net [NC]  
RewriteRule ^(.*)$ http://aqee.net/$1 [L,R=301]
  • 压缩文件, 通过压缩你的文件体积来优化网站的访问速度
# 压缩 text, html, javascript, css, xml:  
AddOutputFilterByType DEFLATE text/plain  
AddOutputFilterByType DEFLATE text/html  
AddOutputFilterByType DEFLATE text/xml  
AddOutputFilterByType DEFLATE text/css  
AddOutputFilterByType DEFLATE application/xml  
AddOutputFilterByType DEFLATE application/xhtml+xml  
AddOutputFilterByType DEFLATE application/rss+xml  
AddOutputFilterByType DEFLATE application/javascript  
AddOutputFilterByType DEFLATE application/x-javascript
  • 缓存文件, 缓存文件是另外一个提高你的网站访问速度的好方法
<FilesMatch ".(flv|gif|jpg|jpeg|png|ico|swf|js|css|pdf)$">  
Header set Cache-Controlmax-age=2592000</FilesMatch>
  • 对某些文件类型禁止使用缓存
<FilesMatch “.(pl|php|cgi|spl|scgi|fcgi)$”>  
Header unset Cache-Control  
</FilesMatch>

rewrite重点:RewriteEngine, RewriteCond, RewriteRule

表示指令定义和匹配一个规则条件,让RewriteRule来重写。说的简单点,RewriteCond就像我们程序中的if语句一样,表示如果符合某个或某几个条件则执行RewriteCond下面紧邻的RewriteRule语句,这就是RewriteCond最原始、基础的功能。

RewriteEngine

RewriteEngine on    #打开rewrite功能

RewriteCond

RewriteCond 和 RewriteRule 是上下对应的关系。可以有1个或者好几个RewriteCond来匹配一个RewriteRule.
RewriteCond一般是这样使用的: RewriteCond %{XXXXXXX} + 正则匹配条件

#那么RewriteCond可以匹配什么样的数据请求呢? 它的使用方式是:
RewriteCond %{NAME_OF_VARIABLE} REGX FLAG


#最常见的3中使用http头连接与请求匹配
RewriteCond %{HTTP_REFERER} (www.test.cn)
RewriteCond %{HTTP_USER_AGENT}  ^Mozilla//5/.0.*
RewriteCond %{REQUEST_FILENAME} !-f
  • HTTP_REFERER 当我们需要判断或者限制访问的来源的时候,就可以用它
    • 当访问的上一个页面的主机地址是www.test.cn,则无论当前访问的是哪个页面,都会跳转到test.php
RewriteCond %{HTTP_REFERER} (www.test.cn)
RewriteRule (.*)$ test.php
RewriteCond %{HTTP_REFERER} !^$ [NC]    #必须要有域名。NC nocase的意思,忽略大小写。
RewriteCond %{HTTP_REFERER} !ww.iyangyi.com [NC] #看域名如果不是 www.iyangyi.com 
RewriteRule \.(jpg|gif) http://image.baidu.com/ [R,NC,L]  

看个例子:
这两句RewriteCond的意思是如果请求的文件或路径是不存在的, 则返回已存在的文件

RewriteCond %{REQUEST_FILENAME} !-f   #-f 是否是一个文件. 判断是否不是一个文件可以这样: !-f
RewriteCond %{REQUEST_FILENAME} !-d   #-d 是否是一个目录. 判断是否不是一个目录可以这样: !-d 
RewriteRule ^room/video/(\d+)\.html web/index\.php?c=room&a=video&r=$1 [QSA,NC,L]         #$1 表示匹配到的第一个参数。
  • REQUEST_URI

%{REQUEST_URI}表示访问的相对地址,就是相对根目录的地址,就是域名/后面的成分,格式上包括最前面的“/”,

#!表示非, 这句语句表示访问的地址不以/blog/开头,只是开头^,没有结尾$
RewriteCond %{REQUEST_URI} !^/blog/ 

RewriteRule

RewriteRule的写法:

RewriteRule Pattern Substitution [flags]

Pattern是一个正则匹配。Substitution是匹配的替换 [flags]是一些参数限制;

#以 room开头的 room/video/123.html 这样子,变成 web/index.php?c=room&a=video&r=123
RewriteRule ^room/video/(\d+)\.html web/index\.php?c=room&a=video&r=$1 [QSA,NC,L]
#以为是访问.jpg或者gif的文件,都会调整到 http://image.baidu.com
RewriteRule \.(jpg|gif) http://image.baidu.com/ [R,NC,L]

常用[flags]举例
多个flag以逗号“,”分隔
- [QSA] qsappend(追加查询字符串)的意思,次标记强制重写引擎在已有的替换字符串中追加一个查询字符串,而不是简单的替换。如果需要通过重写规则在请求串中增加信息,就可以使用这个标记。上面那个room的例子,就必须用它。
- [NC] nocase(忽略大小写)的意思,它使Pattern忽略大小写,也就是在Pattern与当前URL匹配时,”A-Z”和”a-z”没有区别。这个一般也会加上,因为我们的url本身就不区分大小写的。
- [R] redirect(强制重定向)的意思,适合匹配Patter后,Substitution是一个http地址url的情况,就调整出去了。上面那个调整到image.baidu.com的例子,就必须也用它。
- [L] last(结尾规则)的意思,就是已经匹配到了,就立即停止,不再匹配下面的Rule了,类似于编程语言中的break语法,跳出去了。
- [F] 禁用URL,返回HTTP 403 错误

RewriteRule、 RewriteCond参数详解

RewriteCond指令格式

  • 语法: RewriteCond TestString CondPattern [flags]
  • 生效域: server config, virtual host, directory, .htaccess
  • RewriteCond指令定义一条规则条件。在一条RewriteRule指令前面可能会有一条或多条RewriteCond指令,只有当自身的模板(pattern)匹配成功且这些条件也满足时规则才被应用于当前URL处理。
  • TestString是一个纯文本的字符串,除了包含普通的字符外,还可以包括下列的可扩展结构:
    • NRewriteRule(0<=N<=9) N引用紧跟在RewriteCond后面的RewriteRule中模板中的括号中的模板在当前URL中匹配的数据。
    • %N:RewriteCond后向引用,其中(0 <= N <= 9) 。%N引用最后一个RewriteCond的模板中的括号中的模板在当前URL中匹配的数据。
    • ${mapname:key|default}:RewriteMap扩展。
  • CondPattern是条件pattern,即一个应用于当前实例TestString的正则表达式,即TestString将会被计算然后与CondPattern匹配。作为一个标准的扩展正则式,CondPattern有以下补充:

    • 可以在模板串前增加一个!前缀,以用表示不匹配模板。但并不是所有的test都可以加!前缀。
      CondPattern中可以使用以下特殊变量:
      • CondPattern(大于) 将condPattern当作一个普通字符串,将它和TestString进行比较,当TestString 的字符大于CondPattern为真。
      • =CondPattern(等于) 将condPattern当作一个普通字符串,将它和TestString进行比较,当TestString 与CondPattern完全相同时为真.如果CondPattern只是”“(两个引号紧挨在一起) 此时需TestString 为空字符串方为真。
      • -d(是否为目录) 将testString当作一个目录名,检查它是否存在以及是否是一个目录。
      • -f (是否是regular file) 将testString当作一个文件名,检查它是否存在以及是否是一个regular文件。
      • -s (是否为长度不为0的regular文件) 将testString当作一个文件名,检查它是否存在以及是否是一个长度大于0的regular文件。
      • -l (是否为symbolic link) 将testString当作一个文件名,检查它是否存在以及是否是一个 symbolic link。
      • -F(通过subrequest来检查某文件是否可访问) 检查TestString是否是一个合法的文件,而且通过服务器范围内的当前设置的访问控制进行访问。这个检查是通过一个内部subrequest完成的, 因此需要小心使用这个功能以降低服务器的性能。
      • -U (通过subrequest来检查某个URL是否存在) 检查TestString是否是一个合法的URL,而且通过服务器范围内的当前设置的访问控制进行访问。这个检查是通过一个内部subrequest完成的, 因此需要小心使用这个功能以降低服务器的性能。
  • [flags]是第三个参数,多个标志之间用逗号分隔。

    • nocase|NC (不区分大小写) 在扩展后的TestString和CondPattern中,比较时不区分文本的大小写。注意,这个标志对文件系统和subrequest检查没有影响。
    • ornext|OR(建立与下一个条件的或的关系) 默认的情况下,二个条件之间是AND的关系,用这个标志将关系改为OR。例如:

      RewriteCond %{REMOTE_HOST} ^host1.* [OR] 
      RewriteCond %{REMOTE_HOST} ^host2.* [OR]  
      RewriteCond %{REMOTE_HOST} ^host3.* 
      RewriteRule

      如果没有[OR]标志,需要写三个条件/规则。

RewriteRule 指令

  • 语法: RewriteRule Pattern Substitution [flags]
  • Pattern是一个作用于当前URL的兼容perl的正则表达式. 这里的“当前”是指该规则生效时的URL的值。
  • Substitution是,当原始URL与Pattern相匹配时,用以替代(或替换)的字符串此外,Substitution还可以追加特殊标记[flags] 作为RewriteRule指令的第三个参数。
  • Flags是一个包含以逗号分隔的下列标记

    • forbidden|F (强制URL为被禁止的 forbidden) 强制当前URL为被禁止的,即,立即反馈一个HTTP响应代码403(被禁止的)。使用这个标记,可以链接若干RewriteConds以有条件地阻塞某些URL。
    • gone|G(强制URL为已废弃的 gone) 强制当前URL为已废弃的,即,立即反馈一个HTTP响应代码410(已废弃的)。使用这个标记,可以标明页面已经被废弃而不存在了.
    • proxy|P (强制为代理 proxy) 此标记使替换成分被内部地强制为代理请求,并立即(重写规则处理立即中断)把处理移交给代理模块。你必须确保此替换串是一个有效的(比如常见的以 http://hostname开头的)能够为Apache代理模块所处理的URI。使用这个标记,可以把某些远程成分映射到本地服务器名称空间,从而增强了ProxyPass指令的功能。(注意: 要使用这个功能,代理模块必须编译在Apache服务器中。如果你不能确定,可以检查“httpd -l”的输出中是否有mod_proxy.c。如果有,则mod_rewrite可以使用这个功能;如果没有,则必须启用mod_proxy并重新编译“httpd”程序。)
    • last|L(最后一个规则 last) 立即停止重写操作,并不再应用其他重写规则。它对应于Perl中的last命令或C语言中的break命令。这个标记可以阻止当前已被重写的URL为其后继的规则所重写。例如,使用它可以重写根路径的URL(’/’)为实际存在的URL, 比如, ‘/e/www/’。

    • next|N (重新执行 next round) 重新执行重写操作(从第一个规则重新开始). 这时再次进行处理的URL已经不是原始的URL了,而是经最后一个重写规则处理的URL。它对应于Perl中的next命令或C语言中的continue命令。 此标记可以重新开始重写操作,即, 立即回到循环的头部。但是要小心,不要制造死循环!

    • chain|C (与下一个规则相链接 chained) 此标记使当前规则与下一个(其本身又可以与其后继规则相链接的, 并可以如此反复的)规则相链接。 它产生这样一个效果: 如果一个规则被匹配,通常会继续处理其后继规则, 即,这个标记不起作用;如果规则不能被匹配,则其后继的链接的规则会被忽略。比如,在执行一个外部重定向时, 对一个目录级规则集,你可能需要删除“.www” (此处不应该出现“.www”的)。

    • type|T=MIME-type(强制MIME类型type) 强制目标文件的MIME类型为MIME-type 比如,它可以用于模拟mod_alias中的ScriptAlias指令,以内部地强制被映射目录中的所有文件的MIME类型为“application/x-httpd-cgi”。
    • nosubreq|NS (仅用于不对内部子请求进行处理 no internal sub-request) 在当前请求是一个内部子请求时,此标记强制重写引擎跳过该重写规则。比如,在mod_include试图搜索可能的目录默认文件(index.xxx)时, Apache会内部地产生子请求。对子请求,它不一定有用的,而且如果整个规则集都起作用,它甚至可能会引发错误。所以,可以用这个标记来排除某些规则。根据你的需要遵循以下原则: 如果你使用了有CGI脚本的URL前缀,以强制它们由CGI脚本处理,而对子请求处理的出错率(或者开销)很高,在这种情况下,可以使用这个标记。
    • nocase|NC (忽略大小写 no case) 它使Pattern忽略大小写,即, 在Pattern与当前URL匹配时,’A-Z’ 和’a-z’没有区别。
    • qsappend|QSA (追加请求串 query string append) 此标记强制重写引擎在已有的替换串中追加一个请求串,而不是简单的替换。如果需要通过重写规则在请求串中增加信息,就可以使用这个标记。
    • noescape|NE (在输出中不对URI作转义 no URI escaping) 此标记阻止mod_rewrite对重写结果应用常规的URI转义规则。 一般情况下,特殊字符(如’%’, ‘$’, ‘;’等)会被转义为等值的十六进制编码。 此标记可以阻止这样的转义,以允许百分号等符号出现在输出中,如:

      RewriteRule /foo/(.*) /bar?arg=P1\=$1 [R,NE]
      可以使’/foo/zed’转向到一个安全的请求’/bar?arg=P1=zed’
    • passthrough|PT (移交给下一个处理器 pass through) 此标记强制重写引擎将内部结构request_rec中的uri字段设置为 filename字段的值,它只是一个小修改,使之能对来自其他URI到文件名翻译器的 Alias,ScriptAlias, Redirect 等指令的输出进行后续处理。举一个能说明其含义的例子:如果要通过mod_rewrite的重写引擎重写/abc为/def,然后通过mod_alias使/def转变为/ghi,可以这样:

      RewriteRule ^/abc(.*) /def$1 [PT]
      Alias /def /ghi
      如果省略了PT标记,虽然mod_rewrite运作正常,即作为一个使用API的URI到文件名翻译器,它可以重写uri=/abc/…为filename=/def/…,但是,后续的mod_alias在试图作URI到文件名的翻译时,则会失效。
      
    • skip|S=num (跳过后继的规则 skip) 此标记强制重写引擎跳过当前匹配规则后继的num个规则。 它可以实现一个伪if-then-else的构造: 最后一个规则是then从句,而被跳过的skip=N个规则是else从句. (它和’chain|C’标记是不同的!)

    • env|E=VAR:VAL (设置环境变量 environment variable) 此标记使环境变量VAR的值为VAL, VAL可以包含可扩展的反向引用的正则表达式 N ENV{’VAR’})中, 也可以在后继的RewriteCond指令的pattern中通过%{ENV:VAR}作引用。使用它可以从URL中剥离并记住一些信息。

    • cookie|CO=NAME:VAL:domain[:lifetime[:path]] (设置cookie)它在客户端浏览器上设置一个cookie。cookie的名称是NAME,其值是VAL。domain字段是该cookie的域,比如’.apache.org’, 可选的lifetime是cookie生命期的分钟数,可选的path是cookie的路径。

    此外,rewrite规则中如果遇到中文,相当有可能会出现乱码问题,因为apache在rewrite时会做一次url解码,这时jk进行请求转发时,就不会再是编码后的字符串了。此种情况,可以在一开始就进行两次编码(encode),或者在接收请求时先用ISO-8859-1取字节流,再使用UFT-8来new String。

下面附上简单的语法规则和flags 【先放着, 晚些时候整理】

【RewriteCond语法】

RewriteCond TestString CondPattern [flags]

rewritecond的其他用法:

  1. “-d”(目录)
    将TestString视为一个路径名并测试它是否为一个存在的目录。
  2. “-f”(常规文件)
    将TestString视为一个路径名并测试它是否为一个存在的常规文件。
  3. “-s”(非空的常规文件)
    将TestString视为一个路径名并测试它是否为一个存在的、尺寸大于0的常规文件。
  4. “-l”(符号连接)
    将TestString视为一个路径名并测试它是否为一个存在的符号连接。
  5. “-x”(可执行)
    将TestString视为一个路径名并测试它是否为一个存在的、具有可执行权限的文件。该权限由操作系统检测。
  6. “-F”(对子请求存在的文件)
    检查TestString是否为一个有效的文件,而且可以在服务器当前的访问控制配置下被访问。它使用一个内部子请求来做检查,由于会降低服务器的性能,所以请谨慎使用!
  7. “-U”(对子请求存在的URL)
    检查TestString是否为一个有效的URL,而且可以在服务器当前的访问控制配置下被访问。它使用一个内部子请求来做检查,由于会降低服务器的性能,所以请谨慎使用!

【RewriteRule语法:】

RewriteRule Pattern Substitution [flags]

【flags】

  1. “chain|C”(链接下一规则)
    此标记使当前规则与下一个规则相链接。它产生这样的效果:如果一个规则被匹配,则继续处理其后继规则,也就是这个标记不起作用;如果该规则不被匹配,则其后继规则将被跳过。比如,在一个目录级规则中执行一个外部重定向时,你可能需要删除”.www”(此处不应该出现”.www”)。

  2. “cookie|CO=NAME:VAL:domain[:lifetime[:path]]”(设置cookie)
    在客户端设置一个cookie。cookie的名称是NAME,值是VAL。domain是该cookie的域,比如”.apache.org”,可选的lifetime是cookie的有效期(分钟),可选的path是cookie的路径。

  3. “env|E=VAR:VAL”(设置环境变量)
    此标记将环境变量VAR的值为VAL,VAL可以包含可扩展的正则表达式反向引用( N ENV{“VAR”})中,也可以在后继的RewriteCond指令的CondPattern参数中通过%{ENV:VAR}引用。使用它可以记住从URL中剥离的信息。

  4. “forbidden|F”(强制禁止URL)
    强制禁止当前URL,也就是立即反馈一个HTTP响应码403(被禁止的)。使用这个标记,可以链接若干个RewriteConds来有条件地阻塞某些URL。

  5. “gone|G”(强制废弃URL)
    强制当前URL为已废弃,也就是立即反馈一个HTTP响应码410(已废弃的)。使用这个标记,可以标明页面已经被废弃而不存在了。

  6. “handler|H=Content-handler”(强制指定内容处理器)
    强自制定目标文件的内容处理器为Content-handler。例如,用来模拟mod_alias模块的ScriptAlias指令,以强制映射文件夹内的所有文件都由”cgi-script”处理器处理。

  7. “last|L”(结尾规则)
    立即停止重写操作,并不再应用其他重写规则。它对应于Perl中的last命令或C语言中的break命令。这个标记用于阻止当前已被重写的URL被后继规则再次重写。例如,使用它可以重写根路径的URL(“/”)为实际存在的URL(比如:”/e/www/”)。

  8. “next|N”(从头再来)
    重新执行重写操作(从第一个规则重新开始)。此时再次进行处理的URL已经不是原始的URL了,而是经最后一个重写规则处理过的URL。它对应于Perl中的next命令或C语言中的continue命令。此标记可以重新开始重写操作(立即回到循环的开头)。但是要小心,不要制造死循环!

  9. “nocase|NC”(忽略大小写)
    它使Pattern忽略大小写,也就是在Pattern与当前URL匹配时,”A-Z”和”a-z”没有区别。

  10. “noescape|NE”(在输出中不对URI进行转义)
    此标记阻止mod_rewrite对重写结果应用常规的URI转义规则。 一般情况下,特殊字符(“%”, “ ,;)(RewriteRule/foo/(.)/bar?arg=P1%3d 1 [R,NE]
    可以使”/foo/zed转向到一个安全的请求”/bar?arg=P1=zed”。

  11. “nosubreq|NS”(不对内部子请求进行处理)
    在当前请求是一个内部子请求时,此标记强制重写引擎跳过该重写规则。比如,在mod_include试图搜索目录默认文件(index.xxx)时,Apache会在内部产生子请求。对于子请求,重写规则不一定有用,而且如果整个规则集都起作用,它甚至可能会引发错误。所以,可以用这个标记来排除某些规则。
    使用原则:如果你为URL添加了CGI脚本前缀,以强制它们由CGI脚本处理,但对子请求处理的出错率(或者资源开销)很高,在这种情况下,可以使用这个标记。

  12. “proxy|P”(强制为代理)
    此标记使替换成分被内部地强制作为代理请求发送,并立即中断重写处理,然后把处理移交给mod_proxy模块。你必须确保此替换串是一个能够被mod_proxy处理的有效URI(比如以http://hostname开头),否则将得到一个代理模块返回的错误。使用这个标记,可以把某些远程成分映射到本地服务器域名空间,从而增强了ProxyPass指令的功能。
    注意:要使用这个功能,必须已经启用了mod_proxy模块。

  13. “passthrough|PT”(移交给下一个处理器)
    此标记强制重写引擎将内部request_rec结构中的uri字段设置为filename字段的值,这个小小的修改使得RewriteRule指令的输出能够被(从URI转换到文件名的)Alias, ScriptAlias, Redirect等指令进行后续处理[原文:This flag is just a hack to enable post-processing of the output of RewriteRule directives, using Alias, ScriptAlias, Redirect, and other directives from various URI-to-filename translators.]。举一个能说明其含义的例子: 如果要将/abc重写为/def, 然后再使用mod_alias将/def转换为/ghi,可以这样:
    RewriteRule ^/abc(.*) /def$1 [PT]
    Alias /def /ghi
    如果省略了PT标记,虽然将uri=/abc/…重写为filename=/def/…的部分运作正常,但是后续的mod_alias在试图将URI转换到文件名时会遭遇失效。
    注意:如果需要混合使用多个将URI转换到文件名的模块时,就必须使用这个标记。。此处混合使用mod_alias和mod_rewrite就是个典型的例子。

  14. “qsappend|QSA”(追加查询字符串)
    此标记强制重写引擎在已有的替换字符串中追加一个查询字符串,而不是简单的替换。如果需要通过重写规则在请求串中增加信息,就可以使用这个标记。

  15. “redirect|R [=code]”(强制重定向)
    若Substitution以http://thishost[:thisport]/(使新的URL成为一个URI)开头,可以强制性执行一个外部重定向。如果没有指定code,则产生一个HTTP响应码302(临时性移动)。如果需要使用在300-400范围内的其他响应代码,只需在此指定即可(或使用下列符号名称之一:temp(默认), permanent, seeother)。使用它可以把规范化的URL反馈给客户端,如将”/~”重写为”/u/”,或始终对/u/user加上斜杠,等等。
    注意:在使用这个标记时,必须确保该替换字段是一个有效的URL。否则,它会指向一个无效的位置!并且要记住,此标记本身只是对URL加上http://thishost[:thisport]/前缀,重写操作仍然会继续进行。通常,你还会希望停止重写操作而立即重定向,那么就还需要使用”L’标记。

  16. “skip|S=num”(跳过后继规则)
    此标记强制重写引擎跳过当前匹配规则之后的num个规则。它可以模拟if-then-else结构:最后一个规则是then从句,而被跳过的skip=N个规则是else从句。注意:它和”chain|C”标记是不同的!

  17. “type|T=MIME-type”(强制MIME类型)
    强制目标文件的MIME类型为MIME-type,可以用来基于某些特定条件强制设置内容类型。比如,下面的指令可以让.php文件在以.phps扩展名调用的情况下由mod_php按照PHP源代码的MIME类型(application/x-httpd-php-source)显示:
    RewriteRule ^(.+.php)s <script type="math/tex" id="MathJax-Element-130"> </script>1 [T=application/x-httpd-php-source]

  • 5
    点赞
  • 29
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值