如何阻止我的服务器向我的URL添加尾部斜杠?

时间:2015-05-05 16:39:13

标签: php html nginx

我有一台服务于简单应用程序的服务器。当我导航到服务器的IP地址http://XXX.XXX.X.X时,它会在应用程序的根目录中显示index.php文件。当我单击链接转到任何其他页面时,它会自动重定向或在页面的URL末尾添加斜杠。例如,如果链接的href为/about,则浏览器将转到http://XXX.XXX.X.X/about/。如果我手动尝试转到http://XXX.XXX.X.X/about,我也会被重定向到http://XXX.XXX.X.X/about/。我想摆脱拖尾斜线。我不确定这条斜线来自哪里。

我已尝试将此行添加到配置的服务器块中,如下所示:http://www.nginxtips.com/nginx-remove-trailing-slash/。它不起作用,我甚至无法访问除主页之外的任何页面。

rewrite ^/(.*)/$ /$1 permanent;

我查看了/var/log/nginx/access.log中的Nginx访问日志,似乎请求正从我请求的内容(例如http://XXX.XXX.X.X/about)重定向到带有添加的斜杠的同一页面({{ 1}})来自301.以下是日志中的代码:

http://XXX.XXX.X.X/about/

但我不确定他们为什么会被重定向或导致它的原因。

网络应用程序的详细信息:

Web应用程序的结构很像静态网站,每个页面都是一个带有index.php文件的目录。服务器的操作系统是Ubuntu服务器,Nginx是服务器,安装了PHP5-fpm。 Nginx配置文件如下。

nginx.conf

192.168.1.2 - - [06/May/2015:14:53:20 -0500] "GET /why HTTP/1.1" 301 178 "http://192.168.1.7/services/" "Mozilla/5.0 (X11; Ubuntu; Linux x86_64; rv:37.0) Gecko/20100101 Firefox/37.0"
192.168.1.2 - - [06/May/2015:14:53:20 -0500] "GET /why/ HTTP/1.1" 200 3086 "http://192.168.1.7/services/" "Mozilla/5.0 (X11; Ubuntu; Linux x86_64; rv:37.0) Gecko/20100101 Firefox/37.0"
192.168.1.2 - - [06/May/2015:14:53:20 -0500] "GET /contact HTTP/1.1" 301 178 "http://192.168.1.7/why/" "Mozilla/5.0 (X11; Ubuntu; Linux x86_64; rv:37.0) Gecko/20100101 Firefox/37.0"
192.168.1.2 - - [06/May/2015:14:53:20 -0500] "GET /contact/ HTTP/1.1" 200 2325 "http://192.168.1.7/why/" "Mozilla/5.0 (X11; Ubuntu; Linux x86_64; rv:37.0) Gecko/20100101 Firefox/37.0"

网站启用默认值

user  nginx;
worker_processes  1;

pid /run/nginx.pid;

events {
        worker_connections 1024;
        # multi_accept on;
}

http {
        sendfile on;
        tcp_nopush on;
        tcp_nodelay on;
        keepalive_timeout 65;
        types_hash_max_size 2048;
        server_tokens off;

        include /etc/nginx/mime.types;
        default_type application/octet-stream;

        access_log /var/log/nginx/access.log;
        error_log /var/log/nginx/error.log;

        gzip on;
        gzip_disable "msie6";

        # gzip_vary on;
        # gzip_proxied any;
        # gzip_comp_level 6;
        # gzip_buffers 16 8k;
        # gzip_http_version 1.1;
        # gzip_types text/plain text/css application/json application/javascript text/xml application/xml application/xml+rss text/javascript;

        include /etc/nginx/conf.d/*.conf;
        include /etc/nginx/sites-enabled/*;
}

0 个答案:

没有答案