nginx 获取body参数_Nginx 记录HTTP请求的body数据

一般我们在开发过程中,尤其是和另外一个系统联调的时候,接口无法获取正常的参数,而抓包又异常困难的话,从 nginx 入手,不失为一个好的思路。

0x00. 准备nginx 的变量$request_body 即为http请求的body数据

只有在 location中 有 proxy_pass,fastcgi_pass,scgi_pass命令存在时,$request_body变量才会有值。

反向代理使用 proxy_pass

PHP 服务使用 fastcgi_pass

0x01 配置

1. 原理:

定义一个专门接收body数据的日志格式,然后在带有proxy_pass,fastcgi_pass,scgi_pass的 location 中添加 log日志

2. 定义日志格式的命令:log_format ;

可能会用到以下nginx变量参数 说明 示例

$remote_addr 客户端地址 211.28.65.253

$remote_user 客户端用户名称 --

$time_local 访问时间和时区 18/Jul/2012:17:00:01 +0800

$request 请求的URI和HTTP协议 "GET / HTTP/1.1"

$http_host 请求地址,即浏览器中你输入的地址(IP或域名) www.baidu.com 192.168.100.100

$status HTTP请求状态 200

$upstream_status upstream状态 200

$body_bytes_sent 发送给客户端文件内容大小 1547

$http_referer url跳转来源 https://www.baidu.com/

$http_user_agent 用户终端浏览器等信息 "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/68.0.3440.106 Safari/537.36";

$ssl_protocol SSL协议版本 TLSv1

$ssl_cipher 交换数据中的算法 RC4-SHA

$upstream_addr 后台upstream的地址,即真正提供服务的主机地址 10.10.10.100:80

$request_time 整个请求的总时间 0.205

$upstream_response_time 请求过程中,upstream响应时间 0.002

3. 添加日志

命令:access_log ;

注:此命令需要在 带有proxy_pass,fastcgi_pass,scgi_pass的 location 中添加,否则无法获取到http请求的body值

0x02 完整配置示例http {

log_format body_logs '$remote_addr - $remote_user [$time_local] "$request" '

'$status $body_bytes_sent body:"$request_body" "$http_referer" '

'"$http_user_agent" "$http_x_forwarded_for"';

server {

listen 80;

location /api {

fastcgi_pass 127.0.0.1:9000;

access_log /your/logs/path/post_body.log body_logs;

}

}

}

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Nginx获取请求体(body参数有多种方式,这里介绍其中两种常用的方式: 1. 使用 Nginx 的 ngx_http_lua_module 模块解析请求体 首先需要安装 ngx_http_lua_module 模块,然后在 Nginx 配置文件中添加以下配置: ``` location /test { content_by_lua_block { ngx.req.read_body() local args, err = ngx.req.get_post_args() if not args then ngx.say("failed to get post args: ", err) return end ngx.say("args: ", cjson.encode(args)) } } ``` 上述配置中,`ngx.req.read_body()` 用于读取请求体,`ngx.req.get_post_args()` 用于解析请求体中的 POST 参数,如果是 JSON 格式的请求体,可以使用 `ngx.req.get_body_data()` 获取原始的请求体数据,然后使用 JSON 库进行解析。 2. 使用 Nginx 的 ngx_http_echo_module 模块解析请求体 ngx_http_echo_module 模块可以让 Nginx 支持类似于 PHP 中 $_POST 的功能。需要安装 ngx_http_echo_module 模块,然后在 Nginx 配置文件中添加以下配置: ``` location /test { echo_request_body; } ``` 上述配置中,`echo_request_body` 指令用于输出请求体中的所有参数。如果只想输出某个参数,可以使用 `echo_request_body_var` 指令,例如: ``` location /test { echo_request_body_var name; # 输出 name 参数的值 } ``` 在 Java 的 Servlet 中,可以使用 HttpServletRequest 对象获取请求参数、请求头和请求体。以下是示例代码: ```java protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { // 获取参数 String name = request.getParameter("name"); String age = request.getParameter("age"); // 获取请求头 String userAgent = request.getHeader("User-Agent"); // 获取请求体 BufferedReader reader = request.getReader(); StringBuilder sb = new StringBuilder(); String line = null; while ((line = reader.readLine()) != null) { sb.append(line); } String body = sb.toString(); // 处理请求 // ... // 返回响应 response.setContentType("text/html;charset=utf-8"); PrintWriter out = response.getWriter(); out.println("Hello, " + name); out.flush(); out.close(); } ``` 在上述代码中,`request.getParameter()` 方法用于获取参数,`request.getHeader()` 方法用于获取请求头,`request.getReader()` 方法用于获取请求体的字符流,可以通过读取字符流获取请求体的内容。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值