一、前言

使用了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实现简单的注册和登录功能的更多相关文章

  1. 快速体验 Laravel 自带的注册、登录功能

    快速体验 Laravel 自带的注册.登录功能 注册.登录经常是一件很伤脑筋的是,Laravel 提供了解决方案,可以直接使用它.试过之后,感觉真爽! 前提:本地已安装好了 PHP 运行环境.mysq ...

  2. 使用JFinal框架连接数据库,实现注册、登录功能

    使用JFinal框架连接数据库,实现注册.登录功能 1.在Eclipse中新建Dynamic Web project项目 2.导入jfinal-2.2-bin-with-src.jar.c3p0-0. ...

  3. ssm整合实现注册与登录功能

    最简洁易懂的SSM整合源码都在这里了 激情提示: 1.本项目是用IDEA编写的,不管你是习惯何种ide工具,那也只是工具而已,源代码才是本质 2.本项目只拥有注册和登录功能,简易的功能和详细的注释,是 ...

  4. java在线聊天项目1.1版 ——开启多个客户端,分别实现注册和登录功能,使用客户端与服务端信息request机制,重构线程,将单独的登录和注册线程合并

    实现效果图: eclipse项目中初步整合之前的各个客户端和服务端的窗口与工具类,效果如下图: 已将注册服务器线程RegServer功能放到LoginServer中,使用客户端与服务端的request ...

  5. <每日一题>题目1:简单的注册和登录1.0

    #版本1.0,最基本的注册登录'''1.注册,将账号和密码分别写在不同的文档里面2.登录,分别从账户文档和密码文档进行读取并登录''' #注册 Identity = input("请输入您想 ...

  6. java在线聊天项目1.2版 ——开启多个客户端,分别实现数据库注册和登录功能后,成功登陆则登录框消失,好友列表窗出现

    登录框消失语句 dispose(); 好友列表窗出现 使用new FriendsFrame(phone,s); 登陆对话框代码修改如下: package com.swift.frame; import ...

  7. Net Core Identity 身份验证:注册、登录和注销 (简单示例)

    一.前言 一般我们自己的系统都会用自己设置的一套身份验证授权的代码,这次用net core的identity来完成简单的注册.登录和注销. 二.数据库 首先就是创建上下文,我这里简单的建了Users和 ...

  8. 一步步开发自己的博客 .NET版(3、注册登录功能)

    前言 这次开发的博客主要功能或特点:    第一:可以兼容各终端,特别是手机端.    第二:到时会用到大量html5,炫啊.    第三:导入博客园的精华文章,并做分类.(不要封我)    第四:做 ...

  9. App后台开发运维和架构实践学习总结(4)——APP的注册和登录功能设计

    一.为什么需要注册和登录? 是否需要注册和登录的关键取决于产品形态. 如果用户注册登录对于用户需求.产品功能.商业模式本身带不来任何价值的话,就没必要设计这样的功能.比如一些实用工具类的产品:计算器. ...

  10. Node.js基于Express框架搭建一个简单的注册登录Web功能

    这个小应用使用到了node.js  bootstrap  express  以及数据库的操作 :使用mongoose对象模型来操作 mongodb 如果没了解过的可以先去基本了解一下相关概念~ 首先注 ...

随机推荐

  1. mybatis 逆行工程 附源码

    导读 逆向工程说白了,就可以简化开发工作量,自动生成一些死板的东西,比如POJO.映射文件等等,然后在将代码拷贝至实际工程,直接拿来用! 项目结构 GeneratorSqlMap.java impor ...

  2. 在Visual Studio Code中,鼠标双击PHP变量的时候,如何选择包括$在内的整个变量名

    依次点击:文件->首选项->设置 并在"editor.wordSeparators"设置中为您的语言指定删除"$"符号:

  3. webpack4.15.1 学习笔记(六) — 代码拆分(Code Splitting)

    目录 入口起点 防止重复 动态导入(dynamic imports) 代码拆分能够将代码分离到不同的 bundle 中,然后可以按需加载或并行加载这些文件.代码拆分可以用于获取更小的 bundle,以 ...

  4. 使用了条件三元运算符来判断 this.temp.id 是否存在且 mt_qty 是否已被赋值

    mt_qty: (this.temp.id && this.temp.mt_qty) ? this.temp.mt_qty : event.wo_wip,在这个修正后的代码中,使用了条 ...

  5. [oeasy]python0079_控制序列_光标位置设置_ESC_逃逸字符_CSI

    光标位置 回忆上次内容 上次我们研究的比较杂 类型转化 进制转化 捕获异常 版本控制 生成帮助文档 变量的常用类型 变量的生命周期控制   数据类型主要研究了两个 字符串 str   整型数字 int ...

  6. fragment的查找和移除

    FragmentManager fragmentmanger = getSupportFragmentManager(); FragmentTransaction fragmenttransactio ...

  7. Linux Kernel CFI机制简介及测试禁用

    PS:要转载请注明出处,本人版权所有. PS: 这个只是基于<我自己>的理解, 如果和你的原则及想法相冲突,请谅解,勿喷. 环境说明   无 前言   当我们为android移植linux ...

  8. OpenStack 基本命令

    keystone source /etc/keystone/admin-openrc.sh #登录 openstack user create --password ps1234 --email hq ...

  9. 【Mybatis】04 官方文档指北阅读 vol2 配置 其一

    https://mybatis.org/mybatis-3/zh/configuration.html 配置 MyBatis 的配置文件包含了会深深影响 MyBatis 行为的设置和属性信息. 配置文 ...

  10. 【Java】系统找不到指定路径

    报错信息: 2021-05-26 13:50:11,737 RMI TCP Connection(3)-127.0.0.1 ERROR DefaultRolloverStrategy contains ...