Golanggo-gin注册路由
Golanggo-gin注册路由
代码实现
<
package main
import (
"fmt"
"github/jihite/go-gin-example/pkg/setting"
"github/jihite/go-gin-example/routers"
"net/http"
)
func main() {
router := routers.InitRouter()
s := &http.Server{
Addr:          fmt.Sprintf(":%d", setting.HTTPPort),
Handler:        router,
ReadTimeout:    setting.ReadTimeout,
WriteTimeout:  setting.WriteTimeout,
MaxHeaderBytes: 1 << 20,
}
s.ListenAndServe()
}
http:Server:
Addr:监听的TCP地址,格式为:8000
Handler:http句柄,实质为ServeHTTP,⽤于处理程序响应HTTP请求
ReadTimeout:允许读取的最⼤时间
WriteTimeout:允许写⼊的最⼤时间
MaxHeaderBytes:请求头的最⼤字节数
实现InitRouter()
func InitRouter() *gin.Engine {
r := gin.New()
r.Use(gin.Logger())
r.Use(gin.Recovery())
gin.SetMode(setting.RunMode)
r.GET("/ping", func(c *gin.Context) {
c.JSON(200, gin.H{
"message": "pong",
})
})
apig := r.Group("/api")
{
apig.GET("/tags", api.GetTags)
apig.POST("/tags", api.AddTag)
apig.PUT("/tags/:id", api.EditTag)
apig.DELETE("/tags/:id", api.DeleteTag)
apig.POST("/tags/export", api.ExportTag)
apig.POST("/tags/import", api.ImportTag)
}
注册酷狗
return r
}
/ping 对应的是匿名函数
/tags对应的是具体的函数
func GetTags(c *gin.Context) {
}
func AddTag(c *gin.Context) {
}
其中
:Context是gin中的上下⽂,它允许我们在中间件之间传递变量、管理流、验证JSON请求、响应JSON请求等,在gin中包含⼤量Context的⽅法,如我们常⽤的DefaultQuery、Query、DefaultPostForm、PostForm等
RESTFUL中的⽅法:GET、POST、PUT、DELETE、OPTIONS
⽅法安全幂等作⽤
GET✔ ✔ 获取资源
POST××创建⼦资源
PUT✔ ✔ 创建、更新资源
DELETE×✔ 删除资源
OPTIONS✔ ✔ 验证服务是否正产
幂等:使⽤相同参数重复执⾏,并能获得相同结果的函数
POST、PUT区别
POST新建⼦资源;⽽PUT, 如果资源不存在则创建,否则更新

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。