IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Java知识库 -> gin框架自带的一些的鉴定权限机制 session cookie -> 正文阅读

[Java知识库]gin框架自带的一些的鉴定权限机制 session cookie

gin.Cookie() 使用

下面的小例子可以使用 postman 来请求,只要服务启动了,其实主要就是 Cookie 函数来拿到请求头的 value,用 SetCookie 函数来设置 cookie 的 value

func main() {
  r := gin.Default()
  r.Get("/cookie", handler.MyHandler)
  r.Run(":8080")
}
func MyHandler(c *gin.Context) {
  // 获取 cookie 的键 my_cookie 对应的 value
  cookie_value, err := c.Cookie("my_cookie")
 
  if err != nil {
    cookie_value = "no value"
    // 设置 cookie
    c.SetCookie("my_cookie", cookie_value, 3600, "/", "localhost", false, true)
  }
  
  // 然后我们可以在响应头中看下,result 是响应头的键,cookie_value 是响应头的值
  c.Header("result", cookie_value)
}

gin.BasicAuth() 中间件

如下,关键是使用 secrets 的 map 可以想象是数据库中的数据,然后在某个路由分组加上这个中间件 gin.BasicAuth(),此中间件需要在访问分组路由中的接口时候都能触发这个中间件识别,再然后登录时候通过 c.MustGet() 拿到用户名是什么,将用户名在“数据库”中做一个搜索,并将密码做一些匹配,如果成功,用户登录,返回正常 json

// 模拟一些私人数据
var secrets = gin.H{
	"foo":    gin.H{"email": "foo@bar.com", "phone": "123433"},
	"austin": gin.H{"email": "austin@example.com", "phone": "666"},
	"lena":   gin.H{"email": "lena@guapa.com", "phone": "523443"},
}

func main() {
	r := gin.Default()

	// 路由组使用 gin.BasicAuth() 中间件
	// gin.Accounts 是 map[string]string 的一种快捷方式
	authorized := r.Group("/admin", gin.BasicAuth(gin.Accounts{
		"foo":    "bar",
		"austin": "1234",
		"lena":   "hello2",
		"manu":   "4321",
	}))

	// /admin/secrets 端点
	// 触发 "localhost:8080/admin/secrets
	authorized.GET("/secrets", func(c *gin.Context) {
		// 获取用户,它是由 BasicAuth 中间件设置的
		user := c.MustGet(gin.AuthUserKey).(string)
		if secret, ok := secrets[user]; ok {
			c.JSON(http.StatusOK, gin.H{"user": user, "secret": secret})
		} else {
			c.JSON(http.StatusOK, gin.H{"user": user, "secret": "NO SECRET :("})
		}
	})

	// 监听并在 0.0.0.0:8080 上启动服务
	r.Run(":8080")
}

github.com/gin-contrib/sessions 包

虽然要引入 github.com/gin-contrib/sessions 包,但实际这个包也是属于 gin-gonic 组下的

r := gin.Default()

// 中间引入它,这个 secret 主要是为了生成密钥,可以随意指定字符串
store := cookie.NewStore([]byte("secret"))
// 指定浏览器端响应头的 cookie 的名字
r.Use(sessions.Sessions("SESSIONID222", store))

等到登录成功,session set 值之后,接口返回的响应头中就会有 Set-Cookie 字段,其中内部的 key 就是 SESSIONID222,如下图所示

在这里插入图片描述

然后浏览器会保存 cookie 的内容,后面请求时候请求头中都会带上这个 cookie 如下

在这里插入图片描述

上面已经定义好使用这样的方式鉴权了,下面加入登录之后如何保存登录信息呢?如下在某个 HandlerFunc 中

username := c.PostForm("username")
password := c.PostForm("password")

// 若数据库查询都存在且正确
if (username == "aaa" && password == "bbb") {
  s := sessions.Default(c)
  // 设置该用户的 session
  s.Set("user", username)
  // 保存
  s.Save()
} else {
  // todo: xxx
}

这样在一些页面中可以判定这个 s.Get(“user”) 的 session 是否存在来判定有没有登录

s := sessions.Default(c)
// 拿到请求者 session 里头的数据
username := s.Get("user")
if username != nil {
  // todo: xxx
} else {
  // todo: yyy
}

总结核心思想:就是每次首次登录时候,请求方是没有带 cookie 的请求头的,这时候后端会判断用户密码是否符合数据库要求匹配之后,将用户信息存储到 session 中,然后该次请求响应头中返回 Set-Cookie 的字段,里头是 session 信息,然后后面的所有请求都会带上 Cookie 的请求头,里头的内容是刚才 session 的信息,这样后面每次请求都能判定 session 里头的信息在后端 session 中是否有被存储过,如果存储过即判定可以访问。如果后面退出登录,实际就是后端把 session 存储清空了,这样前端即使带着 Cookie 的请求头过来,后端 session 中依然找不到数据,因此判定为没有登录,因此无法访问

其实可以形象的理解成,首次登录时候相当于一个人没有身份证去向政府申请身份证,然后政府部门(后端)存储好了身份证数据,然后把这个身份证返给你个人(返给前端),然后你每次到政府各个部门办事就只用拿着一个身份证就能办事了,如果政府部门因为一些原因删除了你身份证的认定(退出登录,后端清除 session),那你即使带着身份证也无法在各个政府部门办事了,因此你需要重新找政府部门办理新的身份证(重新登录)

实际生产中使用鉴权方式

实际中主要用 JWT 鉴权或者是 oauth2 的包来做鉴权

JWT 非常常用,具体 gin 如何来结合 JWT 来鉴权使用,我会在另一篇博文专门讲解

  Java知识库 最新文章
计算距离春节还有多长时间
系统开发系列 之WebService(spring框架+ma
springBoot+Cache(自定义有效时间配置)
SpringBoot整合mybatis实现增删改查、分页查
spring教程
SpringBoot+Vue实现美食交流网站的设计与实
虚拟机内存结构以及虚拟机中销毁和新建对象
SpringMVC---原理
小李同学: Java如何按多个字段分组
打印票据--java
上一篇文章      下一篇文章      查看所有文章
加:2022-02-09 20:33:44  更:2022-02-09 20:35:14 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 12:52:23-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码