Golang快速开发框架——增加认证基础测试模块(十)

背景

知识分享之Golang篇是我在日常使用Golang时学习到的各种各样的知识的记录,将其整理出来以文章的形式分享给大家,来进行共同学习。欢迎大家进行持续关注。

知识分享系列目前包含Java、Golang、Linux、Docker等等。

开发环境

  • 系统:windows10
  • 语言:Golang
  • golang版本:1.18
  • 代码仓库:FastDevelopGo

内容

日常我们使用golang开发项目时经常需要使用一些基础组件,每次新建较为繁琐,现有市面上的感觉不太适合自己,因此决定自己搭建一套,同时开源出来分享给大家使用,欢迎大家提出各种需求。
下面我们开始对于该框架进行继续完善,本节我们要完成的需求是:

  • 增加一个原始的登录页面
  • 增加一个原始的登录效验接口

1、在/templates/home目录下创建一个login.html页面

{{define "home/login"}}
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>登录页面</title>
</head>
<body>
    <form id="userLogin" name="userLogin" action="/api/login" method="POST">
        <div>
            <h2>用户登录</h2>
            <div>
                <label>用户名:</label>
                <input type="text" id="username" name="username" />
            </div>
            <div>
                <label>密码:</label>
                <input type="password" id="password" name="password" />
            </div>
            <div>
                <button type="submit">登录</button>
            </div>
        </div>
    </form>
</body>
</html>
{{end}}

2、在/src/base/web/router/init.go中的temRouter初始网关中增加登录页面解析

func temRouter(r *gin.Engine) {
    // 统一404错误
    r.GET("/404", func(c *gin.Context) {
        c.HTML(http.StatusOK, "error/404", gin.H{
            "title": "404",
        })
    })
    // 首页面
    r.GET("/index", func(c *gin.Context) {
        c.HTML(200, "home/index", gin.H{
            "title": "Gin 测试模板",
        })
    })
    // 登录页面
    r.GET("/login", func(c *gin.Context) {
        c.HTML(http.StatusOK, "home/login", gin.H{
            "title": "用户登录",
        })
    })

}

3、编写一些模拟接口

package router

import (
    "FastDevelopGo/src/base/log"
    "FastDevelopGo/src/base/mess"
    "github.com/gin-gonic/gin"
    "go.uber.org/zap"
    "net/http"
)

// 登录主网关
func loginRouter(r *gin.RouterGroup) {
    // 注册接口
    r.POST("/register", func(c *gin.Context) {
        c.JSON(http.StatusOK, mess.ResMessOK("注册用户"))
    })

    // 基础登录接口
    r.POST("/login", func(c *gin.Context) {
        username := c.DefaultPostForm("username", "")
        password := c.DefaultPostForm("password", "")
        log.Logger.Info("测试登录接口:", zap.String("username", username), zap.String("password", password))
        c.JSON(http.StatusOK, mess.ResMessOK("登录成功"))
    })

    // 日常会话验证接口
    r.POST("/verify", func(c *gin.Context) {
        c.JSON(http.StatusOK, mess.ResMessOK("验证会话有效性"))
    })
}

注:在核心网关IitRouter中增加了如下代码,以便于我们的模拟接口能成功被加载

// 以下为本框架中的基础接口部分,可以根据选择进行去除或添加
    rg := r.Group("/api")
    loginRouter(rg)

注意这里之前编写日志zap时提前存储了log.Logger,并且其中的Logger做了调整,如下图:

image.png
image.png
image.png

好了,基础的链路这样我们就编写完了,下面我们就要开始编写api/login接口的具体实现了,本框架准备使用OAuth2协议认证进行实现,具体实现请关注下一节

4、启动并访问http://127.0.0.1:8080/login进行测试

image.png
image.png

注:
这个框架我的初步想法时后续增加可视化页面、代码快速生成模块、项目框架快速生成模块等等,有其他需求想法的小伙伴欢迎在评论区留言或直接到代码仓库中提出宝贵的issue

欢迎大家积极start,大家的关注是我最大的动力。

本文声明:
88x31.png
知识共享许可协议
本作品由 cn華少 采用 知识共享署名-非商业性使用 4.0 国际许可协议 进行许可。