常用的nginx rewrite重写规则有以下几种:
1. 重定向:
- 将所有请求重定向到一个新的URL:`rewrite ^/(.*)$ http://newdomain.com/$1 permanent;`
- 将只有特定路径的请求重定向到新的URL:`rewrite ^/old-path/(.*)$ /new-path/$1 permanent;`
- 将HTTP请求重定向到HTTPS:`rewrite ^/(.*)$ https://$host/$1 permanent;`
2. URL重写:
- 将URL中的查询字符串参数添加到重定向后的URL中:`rewrite ^/path/(.*)$ /path?param=$1 last;`
- 将URL中的查询字符串参数重写为路径参数:`rewrite ^/path\?param=(.*)$ /path/$1 last;`
- 将URL中的路径参数重写为查询字符串参数:`rewrite ^/path/(.*)$ /path?param=$1 last;`
3. 防止目录暴露:
- 防止访问以点开头的隐藏文件或目录:`rewrite /\.([^./]+)$ /$1 last;`
- 防止访问未包含文件扩展名的文件:`rewrite ^/path/(.*)$ /path/$1.html last;`
- 防止访问未包含文件扩展名的目录:`rewrite ^/path/(.*)$ /path/$1/ last;`
4. 路径重写和代理:
- 将请求重写到指定路径下的文件:`rewrite ^/path/(.*)$ /new-path/$1 last;`
- 将请求重写到另一个服务器的路径:`rewrite ^/path/(.*)$ http://newdomain.com/$1 last;`
- 将请求重写到另一个服务器的路径,并保持原始的URI和查询参数:`rewrite ^/path/(.*)$ http://newdomain.com/$1$is_args$args last;`
5. 条件重写:
- 仅当请求的主机名为特定值时进行重写:`if ($http_host = "old.domain.com") { rewrite ^/(.*)$ http://new.domain.com/$1 permanent; }`
- 仅当请求的方法为POST时进行重写:`if ($request_method = POST) { rewrite ^/(.*)$ /new-path/$1 last; }`
- 仅当请求的URL不包含特定字符串时进行重写:`if ($request_uri !~ "allowed-string") { rewrite ^/(.*)$ /new-path/$1 last; }`
请注意,在使用rewrite规则时,应谨慎使用if语句,因为它可能导致配置复杂性和性能问题。