首页 > 极客资料 博客日记
使用gin实现简单的注册和登录功能
2024-09-10 22:00:03极客资料围观21次
本篇文章分享使用gin实现简单的注册和登录功能,对你有帮助的话记得收藏一下,看极客之家收获更多编程知识
一、前言
使用了gorm操作数据库,后端基于gin框架,只是一个简单的注册和登录与数据库交互的后端实现例子。
二、目录结构
-templates
--regist.html
--login.html
-main.go
三、代码
regist.html
点击查看代码
<!DOCTYPE html>
<html>
<head>
<title>注册</title>
</head>
<body>
<h1>用户注册</h1>
<form action="/register" method="POST">
<label for="username">用户名:</label>
<input type="text" name="username" required><br><br>
<label for="password">密码:</label>
<input type="password" name="password" required><br><br>
<label for="email">邮箱:</label>
<input type="text" name="email" required><br><br>
<label for="age">年龄:</label>
<input type="text" name="age" required><br><br>
<button type="submit">注册</button>
</form>
<!-- 错误信息展示 -->
{{ if .error }}
<p style="color:red">{{ .error }}</p>
{{ end }}
</body>
</html>
login.html
点击查看代码
<!DOCTYPE html>
<html>
<head>
<title>登录</title>
</head>
<body>
<h1>用户登录</h1>
<form action="/login" method="POST">
<label for="username">用户名:</label>
<input type="text" name="username" required><br><br>
<label for="password">密码:</label>
<input type="password" name="password" required><br><br>
<button type="submit">登录</button>
</form>
<!-- 错误信息展示 -->
{{ if .error }}
<p style="color:red">{{ .error }}</p>
{{ end }}
<!-- 成功信息展示 -->
{{ if .success }}
<p style="color:red">{{ .success }}</p>
{{ end }}
</body>
</html>
main.go
点击查看代码
package main
import (
"log"
"net/http"
_ "github.com/go-sql-driver/mysql"
"github.com/gin-gonic/gin"
"github.com/jinzhu/gorm"
)
var db *gorm.DB
var err error
//定义数据表
type User struct {
gorm.Model
Username string `gorm:"unique" json:"username"`
Password string `json:"password"`
Age string `json:"age"`
Email string `json:"email"`
}
//连接数据库,使用gorm
func ConDB(){
dsn :="root:root@(127.0.0.1:3306)/mydb?charset=utf8mb4&parseTime=True&loc=Local"
db,err = gorm.Open("mysql",dsn)
if err!=nil{
log.Println(err)
}
//迁移数据表
db.AutoMigrate(&User{})
}
func main() {
//注册路由
r := gin.Default()
//连接数据库
ConDB()
//加载模版
r.LoadHTMLGlob("templates/*")
//注册路由,实现登录和注册,get获取页面,post提交数据
r.GET("/register",ShowRegisterPage)
r.POST("/register",Regist)
//登录
r.GET("/login",ShowLoginPage)
r.POST("/login",Login)
r.Run(":8080")
}
//注册页面
func ShowRegisterPage(c *gin.Context){
c.HTML(http.StatusOK,"regist.html",nil)
}
//注册提交
func Regist(c *gin.Context) {
//获取表单数据
username := c.PostForm("username")
password := c.PostForm("password")
age := c.PostForm("age")
email := c.PostForm("email")
//查询用户是否存在
user :=new(User) //初始化的user是默认id=0
db.Where("username = ?",username).First(user)
log.Println(*user)
if user.ID !=0 {
c.HTML(http.StatusCreated,"regist.html",gin.H{"error":"用户已存在"})
return
} else {
newuser := User{
Username: username,
Password: password,
Age: age,
Email: email,
}
db.Create(&newuser)
c.HTML(http.StatusOK,"login.html",gin.H{"success":"注册成功,请登录"})
}
}
//登录界面
func ShowLoginPage(c *gin.Context){
c.HTML(http.StatusOK,"login.html",nil)
}
//登录路由
func Login(c *gin.Context){
//获取数据
username := c.PostForm("username")
password := c.PostForm("password")
//查询用户并验证密码
var loginuser User
db.First(&loginuser,"username = ?",username)
if loginuser.ID ==0 {
c.HTML(http.StatusBadRequest,"login.html",gin.H{"error":"用户不存在!"})
return
}else {
// log.Panicln("first:-+++++>>>",loginuser)
// log.Panicln("find::->>>>>",loginuser)
if password == loginuser.Password {
c.JSON(http.StatusOK,"登录成功!")
} else {
c.HTML(http.StatusBadRequest,"login.html",gin.H{"error":"用户名或密码错误"})
}
}
}
版权声明:本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:jacktools123@163.com进行投诉反馈,一经查实,立即删除!
标签:
相关文章
最新发布
- Nuxt.js 应用中的 prerender:routes 事件钩子详解
- 【问题解决】Tomcat由低于8版本升级到高版本使用Tomcat自带连接池报错无法找到表空间的问题
- 【FAQ】HarmonyOS SDK 闭源开放能力 —Vision Kit
- 六、Spring Boot集成Spring Security之前后分离认证流程最佳方案
- 《JVM第7课》堆区
- .NET 8 高性能跨平台图像处理库 ImageSharp
- 还在为慢速数据传输苦恼?Linux 零拷贝技术来帮你!
- 刚毕业,去做边缘业务,还有救吗?
- 如何避免 HttpClient 丢失请求头:通过 HttpRequestMessage 解决并优化
- 让性能提升56%的Vue3.5响应式重构之“版本计数”