前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >[GO] GO语言gin框架实现管理员认证登陆接口

[GO] GO语言gin框架实现管理员认证登陆接口

作者头像
唯一Chat
发布2020-10-30 10:19:55
9780
发布2020-10-30 10:19:55
举报
文章被收录于专栏:陶士涵的菜地

后台用户登录验证功能是很多项目的必须要有的逻辑 , 也是常见的技术需求 .

要实现这个逻辑首先要有数据库表结构如下:

代码语言:javascript
复制
CREATE TABLE `user` (
 `id` int(11) NOT NULL AUTO_INCREMENT,
 `name` varchar(50) NOT NULL DEFAULT '',
 `password` varchar(50) NOT NULL DEFAULT '',
 `nickname` varchar(50) NOT NULL DEFAULT '',
 `created_at` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,
 `updated_at` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,
 `deleted_at` timestamp NULL DEFAULT NULL,
 `avator` varchar(100) NOT NULL DEFAULT '',
 PRIMARY KEY (`id`),
 KEY `idx_name` (`name`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8

gin框架路由入口去获取post的数据

代码语言:javascript
复制
func LoginCheckPass(c *gin.Context) {
    password := c.PostForm("password")
    username := c.PostForm("username")

    info, uRole, ok := CheckKefuPass(username, password)
    userinfo := make(map[string]interface{})
    if !ok {
        c.JSON(200, gin.H{
            "code": 400,
            "msg":  "验证失败",
        })
        return
    }
    userinfo["name"] = info.Name
    userinfo["kefu_id"] = info.ID
    userinfo["type"] = "kefu"
    if uRole.RoleId != 0 {
        userinfo["role_id"] = uRole.RoleId
    } else {
        userinfo["role_id"] = 2
    }
    userinfo["create_time"] = time.Now().Unix()

    token, _ := tools.MakeToken(userinfo)
    userinfo["ref_token"] = true
    refToken, _ := tools.MakeToken(userinfo)
    c.JSON(200, gin.H{
        "code": 200,
        "msg":  "验证成功,正在跳转",
        "result": gin.H{
            "token":       token,
            "ref_token":   refToken,
            "create_time": userinfo["create_time"],
        },
    })
}

先忽略掉生成token部分 ,只看查询数据库用户名密码部分

代码语言:javascript
复制
func CheckKefuPass(username string, password string) (models.User, models.User_role, bool) {
    info := models.FindUser(username)
    var uRole models.User_role
    if info.Name == "" || info.Password != tools.Md5(password) {
        return info, uRole, false
    }
    uRole = models.FindRoleByUserId(info.ID)

    return info, uRole, true
}

model里面

代码语言:javascript
复制
func FindUser(username string) User {
    var user User
    DB.Where("name = ?", username).First(&user)
    return user
}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020-10-26 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档