我正在尝试将请求重定向到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,但我不明白爆炸是如何工作的(忽略它是否真的起作用):
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;
请帮忙吗?
答案 0 :(得分:21)
向客户端发送永久重定向:
server {
listen 80;
rewrite ^(/users/\w+)$ https://$host$1 permanent;
...
}
您可以使用的否定匹配:
if ($request_uri !~ "^/users/\w+$")
{
return 301 https://$host$request_uri;
}
答案 1 :(得分:1)
set $test "0";
if ($request_uri ~ "condition") {
set $test "1";
}
if ($test ~ "0") {
return 301 redirect url;
}