登录
首页 >  数据库 >  MySQL

使用Go语言web框架wego实现用户登录功能

来源:SegmentFault

时间:2023-02-25 10:12:36 107浏览 收藏

本篇文章给大家分享《使用Go语言web框架wego实现用户登录功能》,覆盖了数据库的常见基础知识,其实一个语言的全部知识点一篇文章是不可能说完的,但希望通过这些问题,让读者对自己的掌握程度有一定的认识(B 数),从而弥补自己的不足,更好的掌握它。

介绍

本文通过一个简单的例子说明如何使用wego框架来实现用户登录功能。主要功能如下:

  1. 用户访问需要进行登录验证的页面时,首先会检查session的登录账号,若没有登录账号,则跳转到登录页面。
  2. 用户提交登录页面后,验证是否是合法的用户,若通过验证,则保存用户账号到session,并跳转到index页面。

说明:本例子采用基于cookie引擎的session

项目的结构

#应用名称
app_name = demo

[server]
#http监听端口
http_port = 8080

[session]
#session 是否开启
session_on = true
#session类型
session_store=cookie
#客户端的cookie的名称
cookie_name = "wego"
#session 过期时间, 单位秒
life_time = 3600
#session数据的hash字符串
hash_key = 123456

重点说明:

  • http_port = 8080
  • [session]

main文件

package main

import (
    "demo/controller"
    "github.com/haming123/wego"
    log "github.com/haming123/wego/dlog"
)

func main() {
    web, err := wego.InitWeb()
    if err != nil{
        log.Error(err)
        return
    }

    web.GET ("/show_login", controller.HandlerShowLogin)
    web.POST("/login_post", controller.HandlerLoginPost)
    web.GET ("/index", (*controller.HomeController).ShowHome)

    err = web.Run()
    if err != nil {
        log.Error(err)
    }
}

登录逻辑

用户访问需要进行登录验证的页面时,首先会检查session的登录账号,若没有登录账号,则跳转到登录页面, 登录页面的路由注册代码为:

web.GET ("/show_login", controller.HandlerShowLogin)

controller.HandlerShowLogin为"/show_login"注册了一个函数型处理器:

func HandlerShowLogin(c *wego.WebContext) {
    c.WriteHTML(http.StatusOK, "./view/login.html", nil)
}

login.html的内容如下:



    登录页面

用户登陆

用户账号:

登录密码:

用户点击"立即登录"后项服务器发送post请求:/login_post, /login_post请求的路由注册代码:

web.POST("/login_post", controller.HandlerLoginPost)

controller.HandlerLoginPost为一个函数型处理器:

func HandlerLoginPost(c *wego.WebContext) {
    account := c.Param.MustString("account")
    password := c.Param.MustString("password")
    if account == "admin" && password == "demo" {
        c.Session.Set("account", account)
        c.Session.Save()
        c.Redirect(302, "/index")
    } else {
        c.Session.Set("account", "")
        c.Session.Save()
        c.Redirect(302, "/show_login")
    }
}

重点说明:

  • 通过
    type BaseController struct {
    }
    func (this *BaseController) SetAccount(c *wego.WebContext, val string) {
        c.Data.Set("account", val)
    }
    func (this *BaseController) GetAccount(c *wego.WebContext) string {
        uid , _ := c.Data.GetString("account")
        return uid
    }
    func (this *BaseController) BeforeExec(ctx *wego.WebContext) {
        account, err := ctx.Session.GetString("account")
        if err != nil || account == "" {
            ctx.Redirect(302, "/show_login")
            return
        }
        this.SetAccount(c, account)
    }

    这样,若一个struct组合了BaseController, 便具有了BeforeExec方法,用户在访问处理器是首先会访问BeforeExec方法, 这样便可以共用登录验证逻辑, 不必在每个处理器中重复实现,大大简化了代码的编写。

    实现HomeController

    为了共用登录验证逻辑,首先需要HomeController中组合BaseController:

    type HomeController struct {
        BaseController
    }

    接下来是/index页面的处理器代码:

    func (this *HomeController) ShowHome(c *wego.WebContext) {
        c.WriteHTML(http.StatusOK, "./view/index.html", this.Account)
    }

    (this *HomeController)ShowHome是一个方法型处理器, 在ShowHome中读取index.html模板,并使用this.Account进行渲染。index.html模板的内容如下:

    
    
        Title
        hello : {{.}}
    
    

    好了,本文到此结束,带大家了解了《使用Go语言web框架wego实现用户登录功能》,希望本文对你有所帮助!关注golang学习网公众号,给大家分享更多数据库知识!

声明:本文转载于:SegmentFault 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>
评论列表