我试图在nginx中重定向请求到https, 除非它的形式是HOST/ANY_STRING_OF_CHARS/END_OF_URI,例如:
http://host.org/about # no redirect
http://host.org/users/sign_in #重定向到https://host.org/users/sign_in
这显然在Apache中工作,但我不明白bang是如何工作的(忽略如果它真的不起作用):
RewriteRule !/([a-z]+)$ https://%{SERVER_NAME}%{REQUEST_URI} [L,R]
如何在nginx重写规则中做到这一点?这不是我所希望的工作:
rewrite !/([a-z]+)$ https://$server_name$request_uri redirect;
这也不会重定向,以防我把逻辑弄反了:
rewrite /([a-z]+)$ https://$server_name$request_uri redirect;
帮助吗?
向客户端发送永久重定向:
server {
listen 80;
rewrite ^(/users/w+)$ https://$host$1 permanent;
...
}
对于负匹配,可以使用:
if ($request_uri !~ "^/users/w+$")
{
return 301 https://$host$request_uri;
}
set $test "0";
if ($request_uri ~ "condition") {
set $test "1";
}
if ($test ~ "0") {
return 301 redirect url;
}