使用文件时找不到MediaWiki文件:example.jpg使用短网址时

时间:2016-04-05 15:43:58

标签: nginx mediawiki

我正在尝试使用Nginx建立一个wiki。

当我使用/wiki/File:image.jpg Nginx返回404时 当我使用/index.php?title=File:image.jpg时,它可以正常工作。

server {
    listen 80;
    listen [::]:80 ipv6only=on;

    root /usr/share/nginx/mediawiki;
    index index.php index.html index.htm;

    ...

    location /wiki/ {
        index index.php;
        rewrite ^/wiki/([^?]*)(?:\?(.*))? /index.php?title=$1&$2 last;
    }

    location ~* /wiki/images/.*.(html|htm|shtml|php)$ {
        types { }
        default_type text/plain;
    }

    location ~* /wikiimages/ {
        try_files $uri /wiki/index.php;
    }

    location ~* \.(js|css|jpg|jpeg|png|gif|ico)$ {
        try_files $uri /wiki/index.php;
        expires max;
        log_not_found off;
    }

    location ~*\.php?$ {
        try_files $uri =404;
    #   # With php5-fpm:
        fastcgi_pass unix:/var/run/php5-fpm.sock;
        fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
        fastcgi_intercept_errors on;
        include fastcgi_params;
    }

    location /wiki/.*\.php?$ {
        try_files $uri =404;
    #   # With php5-fpm:
        fastcgi_pass unix:/var/run/php5-fpm.sock;
        fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
        fastcgi_intercept_errors on;
        include fastcgi_params;
    }
}

2 个答案:

答案 0 :(得分:4)

将error_log级别更改为debug + add rewrite log。类似的东西:

error_log /var/log/nginx/error.log debug;
rewrite_log on;

如需测试,请查看此处:https://gist.github.com/jmervine/8943627 - 有示例配置,可让您自动进行测试。使用完整日志,您可以解决问题。

我有这样的事情:

2016/04/21 13:02:10 [debug] 7566#7566: *1 http script regex: "^/wiki/([^?]*)(?:\?(.*))?"
2016/04/21 13:02:10 [notice] 7566#7566: *1 "^/wiki/([^?]*)(?:\?(.*))?" matches "/wiki/File:test.jpg", client: 127.0.0.1, server: , request: "GET /wiki/File:test.jpg HTTP/1.1", host: "localhost"
2016/04/21 13:02:10 [debug] 7566#7566: *1 http script copy: "/index.php"
2016/04/21 13:02:10 [debug] 7566#7566: *1 http script args
2016/04/21 13:02:10 [debug] 7566#7566: *1 http script copy: "title="
2016/04/21 13:02:10 [debug] 7566#7566: *1 http script capture: "File:test.jpg"
2016/04/21 13:02:10 [debug] 7566#7566: *1 http script copy: "&"
2016/04/21 13:02:10 [debug] 7566#7566: *1 http script capture: ""
2016/04/21 13:02:10 [debug] 7566#7566: *1 http script regex end
2016/04/21 13:02:10 [notice] 7566#7566: *1 rewritten data: "/index.php", args: "title=File:test.jpg&", client: 127.0.0.1, server: _, request: "GET /wiki/File:test.jpg HTTP/1.1", host: "localhost"

看起来你的正则表达式会更好......我今天晚些时候会尝试找到更好的东西。

答案 1 :(得分:0)

我更改了试图直接提供静态资源的正则表达式。

server {
    ...

    location ~* \.(js|css|gif|ico)$ {
        try_files $uri /wiki/index.php;
        expires max;
        log_not_found off;
    }

    ...
}