建站经验 experience
当前位置:首页 > 网站建设专题 > 建站经验
如何使用php日志调试rewrite规则(不受apache和iis限制)
发布日期:2012-02-29 阅读次数:851 字体大小:

需要在IIS和apache同时调试好静态重写的规则,发现调试rewrite规则真是个神一样的工作,你根本就不知道它到底怎么翻译的,解析到哪里去了。

在网上搜了一下,发现一个朋友在apache下开启了配置文件中的一下两个选项

RewriteLog "/myfolder/mylogfile.log"

RewriteLogLevel 9

这样apache可以自动生成一个重写日志,看着日志调试就方便了

Rewriteloglevel 0 代表关闭,9代表开启最大debug输出,调为9可以看到最详细的重写匹配信息

可是IIS环境呢,这个有点麻烦,于是我用网上搜的一个log类来做日志

大致原理是这样的,在网站的index.php这里写一段

$log = new log("/logs/sys.log");

$log->logThis($_SERVER"REQUEST_URI");

//$_SERVER"REQUEST_URI" 是重写的实际执行页面

///logs/sys.log也可以写成别的地址,比如你网站根目录的一个地址,这样你可以通过浏览器来查看日志了

这样的日志结果会是这样的效果

2012-02-28 16:27:04 115.174.56.7 /index.php?action=list&catid=4&pageid=3

2012-02-28 16:27:06 115.174.56.7 /index.php?action=list&catid=7&pageid=6

2012-02-28 16:27:08 115.174.56.7 /index.php?action=list&catid=13&pageid=2

有了日志调试,规则就不再是问题了。