使用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":"用户名或密码错误"})
}
}
}
使用gin实现简单的注册和登录功能的更多相关文章
- 快速体验 Laravel 自带的注册、登录功能
快速体验 Laravel 自带的注册.登录功能 注册.登录经常是一件很伤脑筋的是,Laravel 提供了解决方案,可以直接使用它.试过之后,感觉真爽! 前提:本地已安装好了 PHP 运行环境.mysq ...
- 使用JFinal框架连接数据库,实现注册、登录功能
使用JFinal框架连接数据库,实现注册.登录功能 1.在Eclipse中新建Dynamic Web project项目 2.导入jfinal-2.2-bin-with-src.jar.c3p0-0. ...
- ssm整合实现注册与登录功能
最简洁易懂的SSM整合源码都在这里了 激情提示: 1.本项目是用IDEA编写的,不管你是习惯何种ide工具,那也只是工具而已,源代码才是本质 2.本项目只拥有注册和登录功能,简易的功能和详细的注释,是 ...
- java在线聊天项目1.1版 ——开启多个客户端,分别实现注册和登录功能,使用客户端与服务端信息request机制,重构线程,将单独的登录和注册线程合并
实现效果图: eclipse项目中初步整合之前的各个客户端和服务端的窗口与工具类,效果如下图: 已将注册服务器线程RegServer功能放到LoginServer中,使用客户端与服务端的request ...
- <每日一题>题目1:简单的注册和登录1.0
#版本1.0,最基本的注册登录'''1.注册,将账号和密码分别写在不同的文档里面2.登录,分别从账户文档和密码文档进行读取并登录''' #注册 Identity = input("请输入您想 ...
- java在线聊天项目1.2版 ——开启多个客户端,分别实现数据库注册和登录功能后,成功登陆则登录框消失,好友列表窗出现
登录框消失语句 dispose(); 好友列表窗出现 使用new FriendsFrame(phone,s); 登陆对话框代码修改如下: package com.swift.frame; import ...
- Net Core Identity 身份验证:注册、登录和注销 (简单示例)
一.前言 一般我们自己的系统都会用自己设置的一套身份验证授权的代码,这次用net core的identity来完成简单的注册.登录和注销. 二.数据库 首先就是创建上下文,我这里简单的建了Users和 ...
- 一步步开发自己的博客 .NET版(3、注册登录功能)
前言 这次开发的博客主要功能或特点: 第一:可以兼容各终端,特别是手机端. 第二:到时会用到大量html5,炫啊. 第三:导入博客园的精华文章,并做分类.(不要封我) 第四:做 ...
- App后台开发运维和架构实践学习总结(4)——APP的注册和登录功能设计
一.为什么需要注册和登录? 是否需要注册和登录的关键取决于产品形态. 如果用户注册登录对于用户需求.产品功能.商业模式本身带不来任何价值的话,就没必要设计这样的功能.比如一些实用工具类的产品:计算器. ...
- Node.js基于Express框架搭建一个简单的注册登录Web功能
这个小应用使用到了node.js bootstrap express 以及数据库的操作 :使用mongoose对象模型来操作 mongodb 如果没了解过的可以先去基本了解一下相关概念~ 首先注 ...
随机推荐
- Solo 开发者周刊 (第8期):Claude公司再度上新产品,成交额将超73亿美元
这里会整合 Solo 社区每周推广内容.产品模块或活动投稿,每周五发布.在这期周刊中,我们将深入探讨开源软件产品的开发旅程,分享来自一线独立开发者的经验和见解.本杂志开源,欢迎投稿. 好文推荐 Cla ...
- oeasy教您玩转vim - 12 - # 词头词尾
词头词尾 回忆上节课内容 我们这次学了向前一个单词 w 意思是 word 还学习了向后一个单词 b 意思是 backward 这俩命令都落在单词的第一个字母 还有什么好玩的命令吗? 动手练习 我们可以 ...
- RESTful服务与swagger
一开始刚学springboot的时候 restful服务+swagger一点都看不懂,现在知识学了一些,再回头看这些东西就简单很多了. 自己跟视频做了一个零件项目,里面写了一些零零散散的模块,其中在视 ...
- (2024最新)有效解决OpenAI Chatgpt Plus升级报错【您的银行卡被拒绝了/your card has been declined」,不用再问怎么办?
在OpenAI升级ChatGPT plus时我们可能会遇到升级报错[您的银行卡被拒绝了/your card has been declined」,有些人看到这个可能就会不知所措 注意,这个问题目前依旧 ...
- Label Studio数据标注--通过源码安装
Label Studio是Heartex公司开发的一款在线数据标注工具,分为社区版(开源)和企业版(云服务,收费),企业版提供了增强的安全性(单点登录.角色基于访问控制.SOC2).团队管理.分析和报 ...
- 【Java】Springboot 响应外切 实现数据脱敏
实现效果: 1.脱敏注解在模型类进行标记 package cn.cloud9.server.test.model; import cn.cloud9.server.struct.masking.ann ...
- 【微信小程序】 自定义组件
创建微信小程序组件 在小程序中创建组件: 1.项目根目录中创建[components]目录,存放自定义组件 2.进入components目录,给组件创建一个组件目录 3.右键组件目录,选择[创建Com ...
- 【Java】Main方法的命令行参数
可以使用命令行注入参数执行
- 【Vue】09 Webpack Part5 Vue组件化开发
[Vue组件文件打包:Vue-Loader] 复制之前上一个项目 然后在我们的src目录中创建App.vue文件 这个文件就是Vue的模块文件 [建议下载IDEA的Vue.js插件] Vue的模块分为 ...
- conda/anconda报错:WARNING conda.models.version:get_matcher(556): Using .* with relational operat
conda/anconda报错:WARNING conda.models.version:get_matcher(556): Using .* with relational operat 解决方法, ...