访问阶段
用途:访问权限限制 返回403
nginx:allow 允许,deny 禁止
allow ip;
deny ip;涉及到的网关,有很多的业务 都是在access阶段处理的,有复杂的访问权限控制 nginx:allow deny 功能太弱
一)access_by_lua
语法:
access_by_lua <lua-script-str>语境:http,server,location,location if
阶段:access tail
为每个请求在访问阶段的调用lua脚本进行处理。主要用于访问控制,能收集到大部分的变量。
用于在 access 请求处理阶段插入用户 Lua 代码。这条指令运行于 access 阶段的末尾, 因此总是在 allow 和 deny 这样的指令之后运行,虽然它们同属 access 阶段。
location /foo {
access_by_lua_block {
ngx.log(ngx.DEBUG,"12121212");
}
allow 192.168.31.247;
echo "access";
}access_by_lua 通过 Lua 代码执行一系列更为复杂的请求验证操作,比如实时查询数据库或者其他后端服务, 以验证当前用户的身份或权限。
利用 access_by_lua 来实现 ngx_access 模块的 IP 地址过滤功能:
对于限制ip的访问,等价于
二)access_by_lua_file
nginx.conf配置文件
test_access.lua
即如果访问如http://127.0.0.1/lua_access?token=234将得到403 Forbidden的响应。 这样我们可以根据如cookie/用户token来决定是否有访问权限。
Last updated
Was this helpful?