位置: 编程技术 - 正文

Apache中rewrite伪静态规则介绍(apache2 rewrite)

编辑:rootadmin

推荐整理分享Apache中rewrite伪静态规则介绍(apache2 rewrite),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:apache rewriterule,apache配置伪静态,apache rewritebase,apache rewriterule,apache rewrite,apache rewrite,apache rewriterule,apache rewriterule,内容如对您有帮助,希望把文章链接给更多的朋友!

Apache中rewrite伪静态规则介绍(apache2 rewrite)

Rewirte主要的功能就是实现URL的跳转,它的正则表达式是基于Perl语言。可基于服务器级的(httpd.conf)和目录级的(.htaccess)两种方式。如果要想用到rewrite模块,必须先安装或加载rewrite模块。方法有两种一种是编译apache的时候就直接安装rewrite模块,别一种是编译apache时以DSO模式安装apache,然后再利用源码和apxs来安装rewrite模块基于服务器级的(httpd.conf)有两种方法,一种是在httpd.conf的全局下直接利用RewriteEngine on来打开rewrite功能;另一种是在局部里利用RewriteEngine on来打开rewrite功能,下面将会举例说明,需要注意的是,必须在每个virtualhost里用RewriteEngine on来打开rewrite功能。否则virtualhost里没有RewriteEngine on它里面的规则也不会生效。 基于目录级的(.htaccess),要注意一点那就是必须打开此目录的FollowSymLinks属性且在.htaccess里要声明RewriteEngine on。 实战 例子: 复制代码代码如下: RewriteEngine on RewriteCond %{HTTP_USER_AGENT} ^MSIE [NC,OR] RewriteCond %{HTTP_USER_AGENT} ^Opera [NC] RewriteRule ^.* - [F,L] 这里”-”表示没有替换,浏览器为IE和Opera的访客将被禁止访问。 例子: 复制代码代码如下: RewriteEngine On RewriteBase /test RewriteCond %{REQUEST_FILENAME}.php -f RewriteRule ([^/]+)$ /test/$1.php #for example: /test/admin => /test/admin.php RewriteRule ([^/]+).html$ /test/$1.php [L] #for example: /test/admin.html => /test/admin.php 使用Apache的URL Rewrite配置多用户虚拟服务器 要实现这个功能,首先要在DNS服务器上打开域名的泛域名解析(自己做或者找域名服务商做)。比如,我就把 *.kiya.us和 *.kiya.cn全部解析到了我的IP地址...上。 然后,看一下我的Apache中关于*.kiya.us的虚拟主机的设定。 复制代码代码如下: ServerAdmin webmaster@kiya.us DocumentRoot /home/www/cn.net ServerName dns.kiya.us ServerAlias dns.kiya.us kiya.us *.kiya.us CustomLog /var/log/httpd/osa/access_log.log” common ErrorLog /var/log/httpd/osa/error_log.log” AllowOverride None Order deny,allow #AddDefaultCharset GB RewriteEngine on RewriteCond %{HTTP_HOST} ^[^.]+.kiya.(cn|us)$ RewriteRule ^(.+) %{HTTP_HOST}$1 [C] RewriteRule ^([^.]+).kiya.(cn|us)(.*)$ /home/www/cn.net/sylvan$3?un=$1&%{QUERY_STRING} [L] 在这段设定中,我把*.kiya.cn和*.kiya.us 的Document Root都设定到了 /home/www/cn.net 限制目录只能显示图片 复制代码代码如下: < IfModule mod_rewrite.c> RewriteEngine on RewriteCond %{REQUEST_FILENAME} !^.*.(gif|jpg|jpeg|png|swf)$ RewriteRule .*$ - [F,L] < /IfModule> RewriteRule规则表达式的说明: . 匹配任何单字符 [chars] 匹配字符串:chars [^chars] 不匹配字符串:chars text1|text2 可选择的字符串:text1或text2 ? 匹配0到1个字符 * 匹配0到多个字符 + 匹配1到多个字符 ^ 字符串开始标志 $ 字符串结束标志 n 转义符标志 反向引用 $N 用于 RewriteRule 中匹配的变量调用(0 <= N <= 9) 反向引用 %N 用于 RewriteCond 中最后一个匹配的变量调用(1 <= N <= 9) RewriteCond适用的标志符 ‘nocase|NC’ (no case)忽略大小 ‘ornext|OR’ (or next condition)逻辑或,可以同时匹配多个RewriteCond条件 RewriteRule适用的标志符 ‘redirect|R [=code]’ (force redirect)强迫重写为基于http开头的外部转向(注意URL的变化) 如:[R=,L] ‘forbidden|F’ (force URL to be forbidden)重写为禁止访问 ‘proxy|P’ (force proxy)重写为通过代理访问的http路径 ‘last|L’ (last rule)最后的重写规则标志,如果匹配,不再执行以后的规则 ‘next|N’ (next round)循环同一个规则,直到不能满足匹配 ‘chain|C’ (chained with next rule)如果匹配该规则,则继续下面的有Chain标志的规则。 ‘type|T=MIME-type’ (force MIME type)指定MIME类型 ‘nosubreq|NS’ (used only if no internal sub-request)如果是内部子请求则跳过 ‘nocase|NC’ (no case)忽略大小 ‘qsappend|QSA’ (query string append)附加查询字符串 ‘noescape|NE’ (no URI escaping of output)禁止URL中的字符自动转义成%[0-9]+的形式。 ‘passthrough|PT’ (pass through to next handler)将重写结果运用于mod_alias ’skip|S=num’ (skip next rule(s))跳过下面几个规则 ‘env|E=VAR:VAL’ (set environment variable)添加环境变量 Apache mod_rewrite规则重写的标志一览 1) R[=code](force redirect) 强制外部重定向 强制在替代字符串加上 HTTP状态码。 2) F(force URL to be forbidden)禁用URL,返回HTTP状态码。 3) G(force URL to be gone) 强制URL为GONE,返回HTTP状态码。 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) 只用于不是内部子请求 ) NC(no case) 不区分大小写 ) QSA(query string append) 追加请求字符串 ) NE(no URI escaping of output) 不在输出转义特殊字符 例如:RewriteRule /foo/(.*) /bar?arg=P1%3d$1 [R,NE] 将能正确的将/foo/zoo转换成/bar?arg=P1=zoo ) PT(pass through to next handler) 传递给下一个处理 例如: RewriteRule ^/abc(.*) /def$1 [PT] # 将会交给/def规则处理 Alias /def /ghi ) S=num(skip next rule(s)) 跳过num条规则 ) E=VAR:VAL(set environment variable) 设置环境变量

linux指令介绍 cmp命令细说 功能说明:比较两个文件是否有差异。语法:cmp[-clsv][-i字符数目][--help][第一个文件][第二个文件]补充说明:当相互比较的两个文件完全一样时,则该指

Linux常用命令大全 Linux常用命令全集 Linux常用命令全集

linux下批量并行telnet对端端口的实现方法 以下是以telnet对端端口为例station:~/shell/telnet_port#pwd/root/shell/telnet_portstation:~/shell/telnet_port#cattelnet_port.sh#!/bin/bashrmtelnet_result.txt/dev/nullPORT_=foriin$(

标签: apache2 rewrite

本文链接地址:https://www.jiuchutong.com/biancheng/362083.html 转载请保留说明!

上一篇:Linux下查看文件权限、修改文件权限的方法(linux 文件查看)

下一篇:linux指令介绍 cmp命令细说(linux指令系统)

  • 企业增值税是什么科目
  • 社保未统一征收
  • 企业购车发票怎么查询
  • 由商场代收营业费怎么算
  • 个税抵扣未及时填报
  • 云信付款如何贴现
  • 甲方也要跟项目走的吧
  • 个税系统如何升级到最新版本
  • 中兴通技术维护费
  • 待摊费用按照入账金额还是合同金额摊销?
  • 出租车行业怎么银行贷款
  • 三证合一后章要换吗
  • 建筑业差额征税的账务处理
  • 用友t3修改帐套怎样修改企业会计准则
  • 增值税发票选择确认平台证书密码是多少
  • 销售折扣计入增值税销售额的
  • 外贸企业出口退税计算公式
  • 在天猫店铺后台中的提现怎么做会计分录?
  • 无法支付的其他应付款可以用现金核销吗
  • 银行承兑汇票开票流程图
  • 税收滞纳金可以税前扣除吗
  • 收入未实现成本怎么进
  • 小规模企业记账流程
  • 小规模纳税人收到专票后如何处理
  • 超市开票收回的钱怎么算
  • bios设置教程视频
  • w10怎么找蓝牙
  • php字符串定义
  • 政府性基金收入是政府非税收入吗
  • php数组函数 菜鸟
  • PHP:pg_fetch_all_columns()的用法_PostgreSQL函数
  • PHP:pg_escape_identifier()的用法_PostgreSQL函数
  • bios 和 uefi
  • 供水公司与用户合作协议
  • 在申报季度企业所得税时,残疾人工资可以加计扣除吗
  • 税务变更登记需要带的资料有哪些
  • 其他应付款清账
  • 体验了一回
  • javascriptz
  • opencvcuda
  • openeuler基于
  • 集团公司对子公司的内部审计
  • 银行罚息是财务收入吗
  • phpcms 用的是什么模板引擎
  • 表单上传文件
  • 如何解决安装包解析错误
  • python 列表sum
  • 个人重组债务怎么交税
  • 清算汇缴报表填写范本
  • 个体户跨季领取发票流程
  • 如何确定固定资产的原始成本
  • 小企业会计准则适用于哪些企业
  • 个体定期定额怎么征税
  • 增值税及附加税计算公式
  • 增值税专用发票的税率是多少啊
  • 利息发票如何做会计分录
  • 电力行业规定
  • 投资收益在什么科目
  • 月末应付职工薪酬为负数怎么办
  • 外购材料的核算方法有
  • 本期已认证且不抵扣怎么申报
  • 电梯在固定资产里属于什么设备类别
  • 听妈妈讲那过去的事情讲课
  • centos内存占用进程
  • webinstall.exe - webinstall是什么进程
  • linux yum安装软件命令
  • linux查看nginx配置文件
  • linux中的shell编程
  • 环境配置怎么配置
  • linux流量监测工具
  • jquery给元素添加属性值
  • node.js操作mssql
  • bootstraptable方法
  • Python字符串数组
  • 个税完税证明在哪里开具
  • 社保当月减员当月还可以增加上吗
  • ca锁使用
  • 农产品电子发票可以抵扣吗
  • 四川税控
  • 委托贷款的手续费
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设