1、go run 文件名
如遇上面问题:go mod tidy
2、查看配置信息:go env
3、windows用set修改配置文件,linux用export修改
4、中间件
(1)、全局中间件
r.Use(中间件函数名())
(2)、Next()方法
(3)、局部中间件
直接将中间件函数名用在路由上
eg: r.GET(“/ce”, MiddleWare(), func(c *gin.Context) {…})
(4)、其他中间件
REST API 端点身份验证
OAuth2身份验证
session验证
jwt验证等
5、cookie和session
// 导入session包
“github.com/gin-contrib/sessions”
// 导入session存储引擎
“github.com/gin-contrib/sessions/cookie”
(1)、cookie
详情见:https://www.topgoer.com/gin%E6%A1%86%E6%9E%B6/%E4%BC%9A%E8%AF%9D%E6%8E%A7%E5%88%B6/cookie%E7%BB%83%E4%B9%A0.html
next()顾名思义就是挂起继续向下⾛,然后执⾏完成下⾯的函数,会反过来最后执⾏该中间件
abort()顾名思义就是终⽌的意思,也就是说执⾏该函数,会终⽌后⾯所有的该请求下的函数。
首先在一个路由中用SetCookie将cookie写入,绿色是写入
然后再从另一个路由中取出,红色是取出;注:也可以使用中间件方式取出
cookie缺点:不安全,明文;增加带宽消耗;可以被禁用;cookie有上限
(2)、session
学习地址:https://www.cnblogs.com/qzhc/p/13454583.html
创建基于cookie的储存引擎,aaa参数是用于加密的密钥
var store = sessions.NewCookieStore([]byte(“aaa”))
// 设置session中间件,参数mysession,指的是session的名字,也是cookie的名字
// store是前面创建的存储引擎,我们可以替换成其他存储引擎
r.Use(sessions.Sessions(“mysession”, store))
后面的可以在路由中设置和读取session值
// 初始化session对象
session := sessions.Default©
// 读取session值 session.Get(“mysession”) // session是键值对格式数据,因此需要通过key查询数据
// 设置session数据 session.Set(“hello”, “world”)
// 删除session数据 session.Delete(“hello”)
//清空session session.Clear()
// 保存session数据 session.Save()
// 删除整个session session.Clear()
//转发到另一个url c.Request.URL.Path = “/hi” r.HandleContext©
6、结构体验证
直接在创建结构体的时候进行数据的验证:binding
Age int form:"age" binding:"required,gt=10"
7、生成日志文件/验证码
首先创建一个保存日志文件的文件:f, _ := os.Create(“gin.log”)
然后用io写入:gin.DefaultWriter = io.MultiWriter(f)
验证码:https://blog.csdn.net/aaaadong/article/details/90645113
8、后面还有很多内容学习
网址:https://www.topgoer.com/gin%E6%A1%86%E6%9E%B6/%E5%85%B6%E4%BB%96/