Nginx中不支持嵌套的if判断,所以使用变量的方式进验证,网上有很多关于这种的方式!
server {
listen 521;
server_name default_server;
set $notlogin 0;
# 拦截指定页面,~* 是不区分大小写,~ 区分大小写
if ($request_uri ~* "tyg.html"){
set $notlogin '${notlogin}1';
}
# 取出来的值是空字符串,不能使用~进行匹配
if ($cookie_userId = ''){
set $notlogin '${notlogin}2';
}
# 拦截后重写地址,参数会一起传入重写地址
if ($notlogin = '01') {
rewrite ^/ http://tyg.com/templates/tygController;
}
if ($notlogin = '012') {
rewrite ^/ http://tyg.com/cpt/tyg.html;
}
# 请求
location / {
proxy_pass http://tyg.com/;
}
location ~ .*\.(html|htm|gif|jpg|jpeg|bmp|png|ico|txt|js|css|woff|ttf|js|swf|svga|json)$ {
root E:\tygPage;
index login.html;
#expires 0d;
}
}