nginx 内置变量详解及隔离进行简单的拦截
2016-12-21 11:05
645 查看
1,nginx内置变量
nginx 有很多内置变量可以进行简单的过滤。
$arg_name 请求行中的name参数。 $args 请求行中参数字符串。 $cookie_name 名为name的cookie。 与$uri相同。 $http_name 任意请求头的值;变量名的后半部为转化为小写并且用下划线替代横线后的请求头名称。 $host “Host”请求头的值,如果没有该请求头,则为与请求对应的虚拟主机的首要主机名。 $query_string 与$args相同。 $realpath_root 按root指令或alias指令算出的当前请求的绝对路径。其中的符号链接都会解析成真是文件路径。 $remote_addr 客户端IP地址。 $remote_port 客户端端口。 $remote_user 为基本用户认证提供的用户名。 $request 完整的原始请求行。 $request_body 请求正文。在由proxy_pass指令和 fastcgi_pass指令处理的路径中, 这个变量值可用。 $request_body_file 请求正文的临时文件名。处理完成时,临时文件将被删除。 如果希望总是将请求正文写入文件,需要开启client_body_in_file_only。 如果在被代理的请求或FastCGI请求中传递临时文件名,就应该禁止传递请求正文本身。 使用proxy_pass_request_body off指令 和fastcgi_pass_request_body off指令 分别禁止在代理和FastCGI中传递请求正文。 $request_completion 请求完成时返回“OK”,否则返回空字符串。 $request_filename 基于root指令或alias指令,以及请求URI,得到的当前请求的文件路径。 $request_method HTTP方法,通常为“GET”或者“POST”。 $request_time 请求处理的时间,单位为秒,精度是毫秒(1.3.9, 1.2.6);请求处理时间从由客户端接收到第一个字节开始计算。 $request_uri 完整的原始请求行(带参数)。 $scheme 请求协议类型,为“http”或“https”。 $status 响应状态码。 $tcpinfo_rtt, $tcpinfo_rttvar, $tcpinfo_snd_cwnd, $tcpinfo_rcv_space 客户端TCP连接的信息,在支持套接字选项TCP_INFO的系统中可用。 $uri 当前请求规范化以后的URI。变量$uri的值可能随请求的处理过程而改变。 比如,当进行内部跳转时,或者使用默认页文件
特别需要注意的几个:
$arg_name 请求行中的name参数。 $http_name 任意请求头的值;变量名的后半部为转化为小写并且用下划线替代横线后的请求头名称。 $cookie_name 名为name的cookie
这个几个都是变量其中的name是具体的参数名称。
设计的特别精巧,和lua的类似。具体进行参数拦截就这样直接写了。
2,拦截head中token
比如在做移动客户端开发的时候,timestamp,token,sign,uuid参数
这个4个参数都是必须加上的。增加防刷的安全性。
token是客户端登录token。sign是请求数据签名。
防止别人拿到url然后刷登录接口。
最后一个是uuid,设备号,也能起到一定的防护作用。
禁用一个header头里面的uuid为Android-uuid-1122998800。注意这里是$http_uuid 后面的uuid 是header头里面的参数。
if ($http_uuid ~ 'android-uuid-1122998800') { return 403 "Error uuid forbidden."; }
进行ip拦截。如果发现有ip攻击直接禁用掉。
if ($remote_addr ~ '10.198.2.2') { return 403 "Error uuid forbidden."; }
禁用攻击日志。这部分日志会影响数据处理,直接禁用掉。
access_log off;
4,总结
可以禁用跳转,处理,其中里面有常用的内置变量。
可以根据自己的业务逻辑组织下。提供系统稳定性。
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
您可能感兴趣的文章:
- 分享最新版 nginx内置变量 大全
- nginx 多站点配置方法集合
- CentOS+Nginx+PHP+MySQL详细配置(图解)
- nginx提示:500 Internal Server Error错误的解决方法
- Windows下Nginx+PHP5的安装与配置方法
- Nginx 403 forbidden的解决办法
- nginx FastCGI错误Primary script unknown解决办法
- 权限问题导致Nginx 403 Forbidden错误的解决方法
- CentOS 6.4安装配置LNMP服务器(Nginx+PHP+MySQL)
- nginx 作为反向代理实现负载均衡的例子
- 一句简单命令重启nginx
- Nginx下301重定向域名的方法小结
- Nginx伪静态配置和常用Rewrite伪静态规则集锦
相关文章推荐
- 使用nginx 隔离进行简单的拦截
- nginx内置变量详解
- Nginx内置变量以及日志格式变量参数详解
- nginx内置变量详解
- Nginx 内置变量表( ngx_http_variables),Nginx 服务器配置详解
- Nginx内置变量以及日志格式变量参数详解
- 多台web的Varnish配置实例及内置变量详解
- nginx内置全局变量及含义
- nginx 内置变量
- nginx根据客户端ip进行简单转发(回发)
- nginx变量使用方法详解(1)
- GLSL语言内置的变量详解
- GLSL语言内置的变量详解
- 最简单的《域中隔离用户的FTP站点》详解
- nginx变量使用方法详解(3)
- nginx变量使用方法详解(4)
- nginx变量使用方法详解(5)
- awk的常用内置变量详解
- Nginx 一些内置的变量
- nginx 内置变量大全