我正在尝试将请求重定向到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]
Run Code Online (Sandbox Code Playgroud)
如何在nginx重写规则中执行此操作?这不符合我的希望:
rewrite !/([a-z]+)$ https://$server_name$request_uri redirect;
Run Code Online (Sandbox Code Playgroud)
如果我有向后逻辑,这也不会重定向:
rewrite /([a-z]+)$ https://$server_name$request_uri redirect;
Run Code Online (Sandbox Code Playgroud)
请帮忙?
Jac*_*ack 22
向客户端发送永久重定向:
server {
listen 80;
rewrite ^(/users/\w+)$ https://$host$1 permanent;
...
}
Run Code Online (Sandbox Code Playgroud)
对于负面匹配,您可以使用:
if ($request_uri !~ "^/users/\w+$")
{
return 301 https://$host$request_uri;
}
Run Code Online (Sandbox Code Playgroud)