Go Gin 框架 curl -I 返回 404 的问题

萤火的萤 · · 602 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

在使用 Go 的 Gin Web 框架的时候,发现一个有趣的问题,curl 一个 router 是正常的,但是加上 -I 参数就 404 了,就像下面这样

package mainimport "github.com/gin-gonic/gin"func main() {
   r := gin.Default()
   r.GET("/ping", func(c *gin.Context) {
       c.JSON(200, gin.H{            "message": "pong",
       })
   })
   r.Run() // listen and serve on 0.0.0.0:8080}

正常的

curl http://127.0.0.1:8080/ping{"message":"pong"}

404的

curl -I http://127.0.0.1:8080/ping



HTTP/1.1 404 Not FoundContent-Type: text/plainDate: Wed, 31 Oct 2018 04:35:22 GMTContent-Length: 18

然后通过抓包发现,curl -I 的 http method 是 HEAD,但是我们只定义了GET,所以它就理所当然的 404 了

大部分时候这个样子,对我们也没什么影响,但是部分 slb 在对 http 服务做健康检查的时候,用的 HEAD 的 method,而且只认为 2xx 是正常的,所以,对于部分 router 我们可以用 Any 方法来注册所有 method 的路由,保证健康检查的正确性

package mainimport "github.com/gin-gonic/gin"func main() {
   r := gin.Default()
   r.Any("/ping", func(c *gin.Context) {
       c.JSON(200, gin.H{            "message": "pong",
       })
   })
   r.Run() // listen and serve on 0.0.0.0:8080}

结果

curl -I http://127.0.0.1:8080/ping

HTTP/1.1 200 OKContent-Type: application/json; charset=utf-8Date: Wed, 31 Oct 2018 05:13:20 GMTContent-Length: 18

这个 Any 方法十分简单实用

func (group *RouterGroup) Any(relativePath string, handlers ...HandlerFunc) IRoutes {    group.handle("GET", relativePath, handlers)    group.handle("POST", relativePath, handlers)    group.handle("PUT", relativePath, handlers)    group.handle("PATCH", relativePath, handlers)    group.handle("HEAD", relativePath, handlers)    group.handle("OPTIONS", relativePath, handlers)    group.handle("DELETE", relativePath, handlers)    group.handle("CONNECT", relativePath, handlers)    group.handle("TRACE", relativePath, handlers)    return group.returnObj()
}


本文来自:51CTO博客

感谢作者:萤火的萤

查看原文:Go Gin 框架 curl -I 返回 404 的问题

入群交流(和以上内容无关):加入Go大咖交流群,免费领全套学习资料或添加微信:muxilin131420 备注:入群;或加QQ群:729884609

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