GoFly框架登录Token使用

news2024/11/28 6:49:02

token是验证请求接口用户身份的标识,框架建议开发者在识别用户身份时使用token尽量不要明文传用户标识数据。 

一、生成用户登录token

通过routeuse.GenerateToken生成登录token,方法返回生成的token字符串和err错误提示,其中routeuse.UserClaims是您要token记录用户信息,ID是登录的用户ID(必填),其他参数下面有说明,其他参数根据需要选择添加。

//生成token方式一
token, err := routeuse.GenerateToken(&routeuse.UserClaims{
    ID:         res["id"].Int64(),
    Accountid:  res["accountID"].Int64(),
    BusinessID: res["businessID"].Int64(),
})
//生成token方式二(2.2.6版本)参数:gf.Map{"ID": 1,"Accountid": 1,"BusinessID": 1}参数个数更加业务需求添加
token, err := gf.CreateToken(gf.Map{"ID": user_id})
if err != nil {
    gf.Failed().SetMsg(err.Error()).Regin(c)
} else {
    gf.Success().SetMsg("登录成功返回token!").SetData(token).Regin(c)
}

当前token用户存储的用户信息如下:

ID         int64  `json:"id"`         //用户数据id
Accountid  int64  `json:"accountid"`  //A端主账号id
BusinessID int64  `json:"businessID"` //B端主账号id

二、刷新Token

如果请求头中有token则在 gf.Success().SetMsg("请求成功返回").Regin(c)  返回中我们统一封装返回最新Token,如果需要手动刷新token则用下面方法刷新。

token := c.Request.Header.Get("Authorization")
newtoken, err := routeuse.Refresh(token)
if err != nil {
    gf.Failed().SetMsg(err.Error()).Regin(c)
} else {
    gf.Success().SetMsg("刷新token").SetData(newtoken).Regin(c)
}

三、退出登录

退出登录自己处理token失效,jwt是把token信息都存储在加密字符串,不存储数据,无法提供token字符串过期处理,社区建议退出登录把前端token清空即可,在项目开发中一般设计来说用不到token销毁,用户退出登录后前端后清除token,接口不会再传token,而且token也会过期。特殊情况自己选择判断退出登录方式,为了性能框架不做退出登录销毁操作,我们框架不强制使用Redis,所以无法指定Redis来做验证记录存储,内置缓存不可滥用,可能会导致内存消耗增大。如果项目特殊要求必须销毁,可使用缓存存储和数据库来记录已经销毁的token。

//退出登录
func (api *Index) Logout(c *gf.GinCtx) {
    user, err := gf.ParseTokenNoValid(c) //当前用户
    if err == nil {
    //把用户信息登录状态loginstatus修改为已退出登录
        gf.Model("business_account").Where("id", user.ID).Data(gf.Map{"loginstatus": 0}).Update()
    }
    gf.Success().SetMsg("退出登录").SetData(true).Regin(c)
}

四、解析token获取用户信息

获取用户信息分两种情况,一是请求接口需要token验证,另一种是请求接口不需要token验证的。

1.需要token验证

需要验证接口在请求时gin框架中间件就开始验证用户token信息,通过验证的我们把解析好的用户信息放在请求上下文,通过 gf.GetUserInfo(c)获取用户信息,代码如下:

//1.方法一(推荐) 
//框架版本>=2.2.0
//请求中间件拦截验证,失败直接返回验证失败提示(验证失败直接返回错误,验证通过才往下执行,并直接获取用户id 或者token更多信息)
getuser, _ := c.Get("user") //当前用户
user := getuser.(gf.UserObj)//把获取数据转成User用户对象就可user.ID获取用户的id了,同样user.AccountID, user.BusinessID获取账号的accountID和businessID
//或者只获取用户id
user_id, _ := c.Get("userID") //当前用户ID
accountID, _ := c.Get("accountID") //当前添加当前用户的账号(也就是添加本账号数据的用户userID)
businessID, _ := c.Get("businessID") //当前用户businessID(saas账号ID)
//2.方法二 
//不返回错误提示
user, exists := gf.GetUserInfo(c) //当前用户
if !exists {
    gf.Failed().SetMsg("登录失效").Regin(c)
    return
}
//3.方法三(2.2.1后拦截时直接返回错误提示)
//返回错误信息
user, err := gf.GetUserInfoErr(c) //当前用户
if err!=nil {
    gf.Failed().SetMsg(err.Error()).Regin(c)
    return
}
// user.ID 就获取用户的
// user.AccountID 就获取business_accounta用户表对应用户数据的account_id
// user.BusinessID 就获取business_accounta用户表对应用户数据的business_id
2.不需要token验证的接口

因为需要token验证,请求时候gin框架路由中间件基于不会拦截做token验证,所以请求头就不存在用户信息,只能通过请求传过来的token字符串直接解析获取用户信息。用 gf.ParseTokenGetInfo(c)返回获取用户信息。

user, err := gf.ParseTokenGetInfo(c)
if err != nil {
    gf.Failed().SetMsg("登录失效请重新登录!").SetData(err).Regin(c)
}
// user.ID 就获取用户的id

或者你自己调用jwt中的方法解析

token := c.Request.Header.Get("Authorization")
user, err = routeuse.ParseToken(token)
// user.ID 就获取用户的id

Token的应用就这些没如果还有不明白可咨询gofly技术支持客服微信。

3.仅获取token信息-不需验证
    data, err := gf.ParseTokenNoValid(c)
    if err != nil {
        gf.Failed().SetMsg("获取token信息失败").SetData(err.Error()).SetExdata(data).Regin(c)
    } else {
        gf.Success().SetMsg("获取token信息成功").SetData(data).Regin(c)
    }

五、前端请求接口传递token

前端调用后端api接口时,如果接口是需要token信息的,那么我们在接口请求头添加 Authorization 字段来传递token内容字符串,如下:

headers={Authorization:token字符串内容""}

其中token通过您登录接口返回即可。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2062578.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

删除或丢失的移动硬盘数据如何恢复?三种办法助你找回宝贵资料

在数字化时代,移动硬盘已成为我们存储重要数据不可或缺的工具。然而,数据丢失或误删除的情况时有发生,让人倍感焦虑。别担心,本文将为你详细介绍如何恢复删除或丢失的移动硬盘数据,帮助你找回那些宝贵的资料。 一、检…

太仓自闭症谱系(ASD)儿童

在我国,自闭症谱系(ASD)儿童被称为“星星的孩子”,他们犹如夜空中闪烁的星星,孤独而遥远。为了关爱这些特殊的孩子,让他们更好地融入社会,太仓市星星雨特殊儿童康复中心应运而生。这家康复中心致…

【YashanDB认证】YCA学习记录

第一章:YashanDB基础介绍 国产化数据库的发展及未来 崖山数据库系统:YashanDB是【深圳计算科学研究院】完全自主研发设计的新型数据库系统,经过工信部下述机构权威检测,内核代码自主率100%。 YashanDB 核心交易型数据库 企业级…

拆卸并简单分析一个充电宝线路板

原因 一个很久的充电宝,电量完全不能满足使用,拆解下来的保护板分析 结构图解 除了下图,还有一些外围电路 工作原理图解 电池保护芯片XB8606A(停产) VM连接的是充电口的负极,而这个芯片通过控制电池…

IEEEtran类模板中算法Algorithm的写法

1、注释掉默认的引用 % \usepackage{algorithmic} % \usepackage{algorithm}2、在\begin{document}之前加以下内容 \usepackage[ruled,norelsize,vlined,linesnumbered]{algorithm2e} \makeatletter \newcommand{\removelatexerror}{\let\latexerror\gobble} \makeatother3、…

2 kubeflow系统架构 学习笔记

1 Kubeflow生态系统 2 生态系统说明 2.1. Hardware(硬件层) 提供计算资源的底层硬件支持。GPU(如NVIDIA)通常用于加速机器学习和深度学习的计算任务,而Intel和AMD则可能提供CPU计算资源。 2.2. Infrastructure&…

线程池【详解】

线程池 1、 线程池概念 如果有非常多的任务需要非常多的线程来完成,每个线程的工作时间不长,就需要创建很多线程,工作完又立即销毁[线程频繁创建和销毁线程] 频繁创建和销毁线程非常消耗性能,那么线程池,就是可以创建一些线程,放在"池子"中,用的时候去池子取一个线…

RJ45网口链接器和PCB板结构再生产上需要注意那些方面

华强盛电子导读:工程技术前面199中间2643后面0038 关于网口和PCB板板结合插件会出现几个问题 ...网口的尺寸结构,PCB板板的孔位小,这里强调,建议孔位开大一点,便于生产插件方便。 在插件生产过程中,RJ45网…

免费批量自动校正图片、PDF文档方向工具

功能介绍:批量自动识别图片和PDF文档页面方向,并校正为正确阅读方向(非倾斜纠偏) jpg校正演示 #修复exif信息导致的jpg图像显示和实际旋转不一致问题 #增加图像DPI选项,优先原图或者固定DPI,但这些只会对产生旋转的图…

qss的border-image和background-image和background-coloor和color

如果你的图片和按钮一样大,譬如40X40,那么两者都可以。 如果你的图片和按钮不一样大,用border-image会填充或者拉伸缩放以自适应按钮。 background-image则不会。 所以一般情况下,使用border-image会更合适。 border-image&…

深度学习入门:卷积神经网络 | CNN概述,图像基础知识,卷积层,池化层(超详解!!!)

目录 🍔 前言 🍔 图像基础知识 1. 像素和通道的理解 2. 小节 🍔 卷积层 1. 卷积计算 2. Padding 3. Stride 4. 多通道卷积计算 5. 多卷积核卷积计算 6. 特征图大小 7. PyTorch 卷积层 API 7. 小节 🍔 池化层 1. 池…

openlayers+vite+vue3加载离线地图并实现初始化(一)

前景提示:本文主要讲解使用vite工具构建的项目,利用openlayers实现离线地图的主要一些功能,包括初始化地图、打点、画线、弹窗等等,这些后续有时间会持续为大家更新,本文主要阐述如何实现其首要功能离线地图的初始化。…

linux系统删除文件后,可用率没变,磁盘还是满的

linux系统磁盘清理排查 前言排查解决 前言 某天更新服务时,发现服务怎么也上传不了,原因是磁盘空间不足,这很简单,直接找到大文件删除rm -rf 即可,但是我删除之后,df -h 发现磁盘空间一点变化都没有&#…

Unity XR Interaction Toolkit 通过两个手柄控制物体放大缩小

1:给物体添加 XR General Grab Transformer 脚本 2:XR Grab Interactable 的 select mode 选择 Multiple

基于Burp爆破验证码

目录 基于Burp爆破验证码 一、验证码识别 二、爆破 1、访问登录请求并发送至intruder模块 2、访问验证码url并将截取的请求发送至captcha-killer模块 3、intruder模块设置 3、爆破结果 4、使用burp完成上述操作,存在以下问题: 基于Burp爆破验证码…

Transformer系列-6丨LRNet和Stand-Alone Self-Attention网络解析

0. 前言 本次主要分享之前看的两篇将自注意力机制self-attention应用在视觉感知任务的文章,分别为LRNet和Stand-alone self-attention。为了深化读者的理解,本文提供了较为详细的中文注释的代码。 首先了解一下这两篇文章的背景,其都是在Vi…

【CSP:202309-1】坐标变换(其一)(Java)

题目链接 202309-1 坐标变换(其一) 题目描述 求解思路 直接暴力模拟即可。 实现代码 import java.util.Scanner;public class Main {public static void main(String[] args) {Scanner in new Scanner(System.in);int n, m;n in.nextInt();m in.…

Python 实现自定义异常

在Python编程中,异常处理是保证程序健壮性的重要机制。Python提供了一些内置的异常类,如ValueError、TypeError、IndexError等,开发者可以直接使用这些类来捕获和处理程序运行中出现的各种错误。然而,某些场景下,内置的…

破晓之战:物流“三剑客”扬帆东南亚

【潮汐商业评论/原创】 70公里的曼谷至春武里省之旅,在日常或许只是一趟轻松的自驾。但对于“美美”服装的员工来说,这却成了一场午夜时分的紧急挑战。 忙碌了一整天的她,直到凌晨才猛然想起,VIP客户的货物必须在清晨前送达春武…

Android.bp和Android.mk文件有的区别

文章目录 1. 构建系统2. 语法和格式3. 可维护性和扩展性4. 编译效率5. 未来趋势 在Android的构建系统中, Android.mk和 android.bp是用于定义如何编译项目文件的两种文件类型,它们有一些显著的区别。 1. 构建系统 Android.mk:使用于基于GN…