找回密码
 注-册

QQ登录

只需一步,快速开始

查看: 1899|回复: 1

[其他] Nginx下Discuz!的Rewrite

[复制链接]
Leya 发表于 2009-6-1 21:04:38 | 显示全部楼层 |阅读模式
转自:http://www.ccvita.com/348.html


在上篇《Nginx的Rewrite配置》之后,有不少朋友搜索过来询问相关的设置,于是整理了下,发出来给大家共享。
突然间发现自己写的几篇日志都是关于Nginx
Rewrite配置,感兴趣的同学可以查看下。
Discuz!在Nginx下的Rewrite
需要说明的是,下网上以前一直流传的Rewrite都是有误的。
下面的Rewrite中百分号前面多了个转移字符“\”,这在Apache中是需要的,而在Nginx中则是不需要的。
rewrite ^/thread-([0-9]+)-([0-9]+)-([0-9]+)\.html$ /viewthread.php?tid=$1&extra=page\%3D$3&page=$2 last;
正确的应该是
rewrite ^/thread-([0-9]+)-([0-9]+)-([0-9]+)\.html$ /viewthread.php?tid=$1&extra=page%3D$3&page=$2 last;
这个错误在基本上目前所有使用Nginx作为服务器,并且开启了Rewrite的网站上存在。包括Discuz!官方,目前已经给cnteacher反馈了。


Nginx实例代码

  1. server {
  2. listen 80;
  3. server_name www.ccvita.com ccvita.com;
  4. location / {
  5. index index.html index.htm index.php;
  6. root /www/www.ccvita.com;
  7. rewrite ^(.*)/archiver/((fid|tid)-[\w\-]+\.html)$ $1/archiver/index.php?$2 last;
  8. rewrite ^(.*)/forum-([0-9]+)-([0-9]+)\.html$ $1/forumdisplay.php?fid=$2&page=$3 last;
  9. rewrite ^(.*)/thread-([0-9]+)-([0-9]+)-([0-9]+)\.html$ $1/viewthread.php?tid=$2&extra=page%3D$4&page=$3 last;
  10. rewrite ^(.*)/profile-(username|uid)-(.+)\.html$ $1/viewpro.php?$2=$3 last;
  11. rewrite ^(.*)/space-(username|uid)-(.+)\.html$ $1/space.php?$2=$3 last;
  12. rewrite ^(.*)/tag-(.+)\.html$ $1/tag.php?name=$2 last;
  13. }
  14. location ~ \.php$ {
  15. include fastcgi_params;
  16. fastcgi_index index.php;
  17. fastcgi_pass 127.0.0.1:8694;
  18. fastcgi_param SCRIPT_FILENAME /www/www.ccvita.com$fastcgi_script_name;
  19. }
  20. location /www.ccvita.com-status {
  21. stub_status on;
  22. access_log off;
  23. }
  24. }
复制代码
回复

使用道具 举报

 楼主| Leya 发表于 2009-6-1 21:13:20 | 显示全部楼层

Nginx的防盗链配置

有个客户的站点负载过高,于是我们可爱的愤青系统工程师将其的Apache换成Nginx,效果很明显。现在记录一些Apache转换过程中的小细节,留下备忘。
Nginx的防盗链
一般的防盗链如下:
  1. location ~* \.(gif|jpg|png|swf|flv)$ {
  2. valid_referers none blocked www.ccvita.com www.phpq.net;
  3. if ($invalid_referer) {
  4. rewrite ^/ http://www.ccvita.com/403.html;
  5. #return 404;
  6. }
  7. }
复制代码
第一行:gif|jpg|png|swf|flv
表示对gif、jpg、png、swf、flv后缀的文件实行防盗链
第二行:www.ccvita.com www.phpq.net
表示对www.ccvita.com www.phpq.net这2个来路进行判断
if{}里面内容的意思是,如果来路不是指定来路就跳转到错误页面,当然直接返回404也是可以的。
NginxHttpAccessKeyModule实现防盗链
如果不怕麻烦,有条件实现的话,推荐使用NginxHttpAccessKeyModule这个东西。
他的运行方式是:如我的download 目录下有一个 file.zip 的文件。对应的URI 是http://www.ccvita.com/download/file.zip
使用ngx_http_accesskey_module 模块后http://www.ccvita.com/download/file.zip?key=09093abeac094. 只有给定的key值正确了,才能够下载download目录下的file.zip。而且 key 值是根据用户的IP有关的,这样就可以避免被盗链了。
据说NginxHttpAccessKeyModule现在连迅雷都可以防了,可以尝试一下。
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注-册

本版积分规则

Archiver|手机版|小黑屋|DoDVip ( 桂ICP备14000730号 )

GMT+8, 2024-5-4 23:45 , Processed in 0.048794 second(s), 20 queries .

Powered by Discuz! X3.5

Copyright © 2001-2024 Tencent Cloud.

快速回复 返回顶部 返回列表