remoteAddr返回值错误

daemon · 2013-12-31 12:32:11 · 5301 次点击 · 大约8小时之前 开始浏览    置顶
这是一个创建于 2013-12-31 12:32:11 的主题,其中的信息可能已经有所发展或是发生改变。

在revel里,我用

revel.WARN.Println("commentData host:", c.Request.RemoteAddr)

来获取客户ip。

可是返回的却是:commentData host: 127.0.0.1:36633

这是为嘛啊。


有疑问加站长微信联系(非本文作者)

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

5301 次点击  
加入收藏 微博
3 回复  |  直到 2014-01-02 01:45:55
gihnius
gihnius · #1 · 11年之前

这个应该是 bug.

你可以打印 request.Header 来看看 ip 在哪个环境变量.

gihnius
gihnius · #2 · 11年之前

看了一下 源代码, request.RemoteAddr 竟然是 直接连接的 socket addr

这个调用: syscall.Sockaddr

严格说是正确的, 但是跟 http 有点出入. 如果这个不算 bug, 而且通过 nginx/apache 等服务器转发 Go http 时, 只能从 nginx/apache 服务器的 header 取得 remote ip 了。

daemon
daemon · #3 · 11年之前
gihniusgihnius #2 回复

看了一下 源代码, request.RemoteAddr 竟然是 直接连接的 socket addr 这个调用: `syscall.Sockaddr` 严格说是正确的, 但是跟 http 有点出入. 如果这个不算 bug, 而且通过 nginx/apache 等服务器转发 Go http 时, 只能从 nginx/apache 服务器的 header 取得 remote ip 了。

谢谢哇,看起来还是要多看看源码啊。

添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传