MIME type oddity when using try_files in combination with location/alias using regex captures

Christoph Schug chris+nginx at schug.net
Thu Aug 2 05:39:31 UTC 2012


Hello!

Given is following minimized test case

server {
     listen                          80;
     server_name                     t1.example.com;

     root                            /data/web/t1.example.com/htdoc;

     location                        ~ ^/quux(/.*)?$ {
         alias                       /data/web/t1.example.com/htdoc$1;
         try_files                   '' =404;
     }
}

on Nginx 1.3.4 (but not specific to that version)

# nginx -V
nginx version: nginx/1.3.4
TLS SNI support enabled
configure arguments: --prefix=/usr/share/nginx 
--conf-path=/etc/nginx/nginx.conf --sbin-path=/usr/sbin/nginx 
--http-log-path=/var/log/nginx/access.log 
--error-log-path=/var/log/nginx/error.log --pid-path=/var/run/nginx.pid 
--user=nginx --group=nginx --with-openssl=openssl-1.0.1c --with-debug 
--with-http_stub_status_module --with-http_ssl_module --with-ipv6

and following file system layout

# find /data/web/t1.example.com/htdoc/
/data/web/t1.example.com/htdoc/
/data/web/t1.example.com/htdoc/foo
/data/web/t1.example.com/htdoc/foo/bar.gif

Accessing the file directly returns the expected 'Content-Type' 
response header with the value 'image/gif'

$ curl -s -o /dev/null -D - -H 'Host: t1.example.com' 
http://127.0.0.1/foo/bar.gif
HTTP/1.1 200 OK
Server: nginx/1.3.4
Date: Thu, 02 Aug 2012 05:13:40 GMT
Content-Type: image/gif
Content-Length: 68
Last-Modified: Thu, 02 Aug 2012 05:04:56 GMT
Connection: keep-alive
ETag: "501a0a78-44"
Accept-Ranges: bytes

Accessing the file via location /quux returns 'Content-Type' response 
header with the value 'application/octet-stream' (basically it falls 
back to the setting of 'default_type')

$ curl -s -o /dev/null -D - -H 'Host: t1.example.com' 
http://127.0.0.1/quux/foo/bar.gif
HTTP/1.1 200 OK
Server: nginx/1.3.4
Date: Thu, 02 Aug 2012 05:13:42 GMT
Content-Type: application/octet-stream
Content-Length: 68
Last-Modified: Thu, 02 Aug 2012 05:04:56 GMT
Connection: keep-alive
ETag: "501a0a78-44"
Accept-Ranges: bytes

It is unclear to me if this is expected behavior (and if so, I am 
having a hard time to find it in the documentation) and what would be 
the best way to mitigate the problem. Defining nested locations within 
the /quux one for each combination of file extension/MIME type works but 
looks very wrong to me.

-cs



More information about the nginx mailing list