go语言实现简单登陆样例

目录

1、代码实现样例:

2、postman调用,获取登陆后的token:


1、代码实现样例:

复制代码
package main

import (
	"net/http"
	"time"

	"github.com/dgrijalva/jwt-go"
	"github.com/gin-gonic/gin"
)

var (
	// 密钥,用于签署 JWT 令牌
	signingKey = []byte("secret")
)

// 用户信息
type User struct {
	Username string `json:"username"`
	Password string `json:"-"`
}

// 模拟用户数据
var users = map[string]User{
	"user1": {"user1", "password1"},
	"user2": {"user2", "password2"},
}

// 登录处理程序
func LoginHandler(c *gin.Context) {
	var credentials struct {
		Username string `json:"username"`
		Password string `json:"password"`
	}
	if err := c.BindJSON(&credentials); err != nil {
		c.JSON(http.StatusBadRequest, gin.H{"error": "Invalid request"})
		return
	}

	// 检查用户名和密码
	user, ok := users[credentials.Username]
	if !ok || user.Password != credentials.Password {
		c.JSON(http.StatusUnauthorized, gin.H{"error": "Invalid username or password"})
		return
	}

	// 创建 JWT 令牌
	token := jwt.New(jwt.SigningMethodHS256)
	claims := token.Claims.(jwt.MapClaims)
	claims["username"] = user.Username
	claims["exp"] = time.Now().Add(time.Hour * 24).Unix() // 令牌过期时间为24小时

	// 签名令牌
	tokenString, err := token.SignedString(signingKey)
	if err != nil {
		c.JSON(http.StatusInternalServerError, gin.H{"error": "Failed to generate token"})
		return
	}

	// 返回令牌给客户端
	c.JSON(http.StatusOK, gin.H{"token": tokenString})
}


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

	// 登录路由
	r.POST("/login", auth2.LoginHandler)

	// 启动服务
	r.Run(":8080")
}

2、postman调用,获取登陆后的token:

相关推荐
Csvn22 分钟前
Python 两大经典坑点 —— 可变默认参数 & 闭包延迟绑定
后端·python
Csvn36 分钟前
定时任务 — Crontab 从入门到生产实战
后端
ServBay2 小时前
Laravel Herd MCP 的替代,多语言与跨平台的 AI 本地开发选择
后端·ai编程·mcp
GoGeekBaird3 小时前
Prompt、Context、Harness 工程全景图
后端
SimonKing3 小时前
艹,维护AI写的代码,我心态崩了......
java·后端·程序员
AskHarries3 小时前
MCP 基础:Server、Tool、Resource 和 Prompt
后端·程序员
长栎3 小时前
你写的 DCL 单例,在反序列化面前就是个弟弟——单例模式的破局与重建
后端
长栎3 小时前
命令模式和策略模式代码长一样——你分不清是因为你没看穿它们的本质
后端
用户298698530143 小时前
Java Word 文档样式进阶:段落与文本背景色设置完全指南
java·后端