首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >WEBrick:日志发布数据

WEBrick:日志发布数据
EN

Stack Overflow用户
提问于 2013-08-23 08:08:21
回答 2查看 2.6K关注 0票数 3

我正在运行一个简单的WEBrick服务器来调试POST数据。我想将POST数据输出到日志中。

我的代码是:

代码语言:javascript
复制
server.mount_proc '/' do |req, res|
    res.body = "Web server response:\n"
    # Output POST data here...
end

其中server只是一个WEBrick服务器。

有什么建议吗?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2013-08-23 08:13:31

使用req.body访问原始post数据。

代码语言:javascript
复制
server.mount_proc '/' do |req, res|
    res.body = "Web server response:\n"
    p req.body # <---
end

如果您想要解析的数据(作为散列),使用req.query代替。

更新

自定义:AccessLog

代码语言:javascript
复制
require 'webrick'

log = [[ $stderr, WEBrick::AccessLog::COMMON_LOG_FORMAT + ' POST=%{body}n']]

server = WEBrick::HTTPServer.new :Port => 9000, :AccessLog => log
server.mount_proc '/' do |req, res|
    req.attributes['body'] = req.body
    res.body = "Web server response:\n"
end
server.start
票数 5
EN

Stack Overflow用户

发布于 2013-08-23 08:27:37

你试过网猫吗?看看你是否拥有它:

代码语言:javascript
复制
$ man nc

然后您可以启动这样的服务器:

代码语言:javascript
复制
$ nc -l 8080    (-l act as a server, listening on port 8080)
(hangs)

如果我向a=10&b=20发送带有数据“http://locahost:8080”的post请求,则netcat输出:

代码语言:javascript
复制
$ nc -l 8080    
POST / HTTP/1.1
Host: localhost:8080
User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10.6; rv:23.0) Gecko/20100101 Firefox/23.0
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
Accept-Language: null
Accept-Encoding: gzip, deflate
DNT: 1
Content-Length: 9
Content-Type: text/plain; charset=UTF-8
Connection: keep-alive
Pragma: no-cache
Cache-Control: no-cache

a=10&b=20
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/18397892

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档