Beego框架实战教程:项目搭建及注册用户_搭建beego工程化目录

还有兄弟不知道网络安全面试可以提前刷题吗?费时一周整理的160+网络安全面试题,金九银十,做网络安全面试里的显眼包!

王岚嵚工程师面试题(附答案),只能帮兄弟们到这儿了!如果你能答对70%,找一个安全工作,问题不大。

对于有1-3年工作经验,想要跳槽的朋友来说,也是很好的温习资料!

【完整版领取方式在文末!!】

93道网络安全面试题

需要体系化学习资料的朋友,可以加我V获取:vip204888 (备注网络安全)

内容实在太多,不一一截图了

黑客学习资源推荐

最后给大家分享一份全套的网络安全学习资料,给那些想学习 网络安全的小伙伴们一点帮助!

对于从来没有接触过网络安全的同学,我们帮你准备了详细的学习成长路线图。可以说是最科学最系统的学习路线,大家跟着这个大的方向学习准没问题。

😝朋友们如果有需要的话,可以联系领取~

1️⃣零基础入门
① 学习路线

对于从来没有接触过网络安全的同学,我们帮你准备了详细的学习成长路线图。可以说是最科学最系统的学习路线,大家跟着这个大的方向学习准没问题。

image

② 路线对应学习视频

同时每个成长路线对应的板块都有配套的视频提供:

image-20231025112050764

2️⃣视频配套工具&国内外网安书籍、文档
① 工具

② 视频

image1

③ 书籍

image2

资源较为敏感,未展示全面,需要的最下面获取

在这里插入图片描述在这里插入图片描述

② 简历模板

在这里插入图片描述

因篇幅有限,资料较为敏感仅展示部分资料,添加上方即可获取👆

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化资料的朋友,可以点击这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!


然后再提供一个方法,用于执行sql语句:



//操作数据库
func ModifyDB(sql string, args …interface{}) (int64, error) {
result, err := db.Exec(sql, args…)
if err != nil {
log.Println(err)
return 0, err
}
count, err := result.RowsAffected()
if err != nil {
log.Println(err)
return 0, err
}
return count, nil
}


再提供一个方法,用于之后的数据库操作:




//查询
func QueryRowDB(sql string) *sql.Row{
return db.QueryRow(sql)
}


然后再models中创建一个model文件:



package models

import (
“myblogweb/utils”
“fmt”
)

type User struct {
Id int
Username string
Password string
Status int // 0 正常状态, 1删除
Createtime int64
}

//--------------数据库操作-----------------

//插入
func InsertUser(user User)(int64, error){
return utils.ModifyDB(“insert into users(username,password,status,createtime) values (?,?,?,?)”,
user.Username,user.Password,user.Status,user.Createtime)
}

//按条件查询
func QueryUserWightCon(con string)int{
sql := fmt.Sprintf(“select id from users %s”,con)
fmt.Println(sql)
row:=utils.QueryRowDB(sql)
id :=0
row.Scan(&id)
return id
}

//根据用户名查询id
func QueryUserWithUsername(username string) int{
sql := fmt.Sprintf(“where username=‘%s’”,username)
return QueryUserWightCon(sql)
}

//根据用户名和密码,查询id
func QueryUserWithParam(username ,password string)int{
sql:=fmt.Sprintf(“where username=‘%s’ and password=‘%s’”,username,password)
return QueryUserWightCon(sql)
}


#### **2.2 view**


我们先在views包下,创建一个html页面:register.html。



注册 ​ ​

Welcome


Register
​ {{/*背景动画*/}}
```

页面效果:

添加表单验证:

我们使用jquery来实现js部分,在js目录下,创建子目录lib,在里面放jquery框架文件,并在页面中引入。

然后重新创建一个js文件:blog.js

首先添加表单验证:

$(document).ready(function () {
    //注册表单验证
    $("register-from").validate({
        rules:{
            username:{
                required:true,
                rangelength:[5,10]
            },
            password:{
                required:true,
                rangelength:[5,10]
            },
            repassword:{
                required:true,
                rangelength:[5,10],
                equalTo:"#register-password"
            }
        },
        messages:{
            username:{
                required:"请输入用户名",
                rangelength:"用户名必须是5-10位"
            },
            password:{
                required:"请输入密码",
                rangelength:"密码必须是5-10位"
            },
            repassword:{
                required:"请确认密码",
                rangelength:"密码必须是5-10位",
                equalTo:"两次输入的密码必须相等"
            }
        },
        submitHandler:function (form) {
            var urlStr = "/register";
            // alert("urlStr:"+urlStr)
            $(form).ajaxSubmit({
                url:urlStr,
                type:"post",
                dataType:"json",
                success:function (data,status) {
                    alert("data:"+data.message)
                    if (data.code == 1){
                        setTimeout(function () {
                            window.location.href="/login"
                        },1000)
                    }
                },
                err:function (data,status) {
                    alert("err:"+data.message+":"+status)
                }
            })
        }
    })
})

当用户点击表单的submit按钮,会跳转到/register路径,而因为设置为post请求,所以我们可以在post中完成表单的注册。如果注册成功,再跳转到/login路径。

2.3 controller

我们在controllers包下创建一个新的controller,用来处理用户的注册:

package controllers
​
import "github.com/astaxie/beego"
​
type RegisterController struct {
    beego.Controller
}
​
func (this *RegisterController) Get(){
    this.TplName = "register.html"
}
​
func (this *RegisterController) Post() {
​
    //获取表单信息
    username := this.GetString("username")
    password := this.GetString("password")
    repassword := this.GetString("repassword")
    fmt.Println(username, password, repassword)
    log.INFO(username, password, repassword)
​
    //注册之前先判断该用户名是否已经被注册,如果已经注册,返回错误
    id := models.QueryUserWithUsername(username)
    fmt.Println("id:", id)
    if id > 0 {
        this.Data["json"] = map[string]interface{}{"code": 0, "message": "用户名已经存在"}
        this.ServeJSON()
        return
    }
​
    //注册用户名和密码
    //存储的密码是md5后的数据,那么在登录的验证的时候,也是需要将用户的密码md5之后和数据库里面的密码进行判断
    password = utils.MD5(password)
    fmt.Println("md5后:", password)
​
    user := models.User{0, username, password, 0, time.Now().Unix()}
    _, err := models.InsertUser(user)
    if err != nil {
        this.Data["json"] = map[string]interface{}{"code": 0, "message": "注册失败"}
    } else {
        this.Data["json"] = map[string]interface{}{"code": 1, "message": "注册成功"}
    }
    this.ServeJSON()
​
}
​

接下来,我们需要新注册一个路由,修改router.go文件:

func init() {
    beego.Router("/", &controllers.MainController{})
    beego.Router("/register", &controllers.RegisterController{})
}

然后我们创建一个Post()方法,用于处理post的请求:

​
//处理注册
func (this *RegisterController) Post() {
    //获取表单信息
    username := this.GetString("username")
    password := this.GetString("password")
    repassword := this.GetString("repassword")
    fmt.Println(username, password, repassword)
​
    //注册之前先判断该用户名是否已经被注册,如果已经注册,返回错误
    id := models.QueryUserWithUsername(username)
    fmt.Println("id:",id)
    if id > 0 {
        this.Data["json"] = map[string]interface{}{"code":0,"message":"用户名已经存在"}
        this.ServeJSON()
        return
    }
​
    //注册用户名和密码
    //存储的密码是md5后的数据,那么在登录的验证的时候,也是需要将用户的密码md5之后和数据库里面的密码进行判断
    password = utils.MD5(password)
    fmt.Println("md5后:",password)
​
    user := models.User{0,username,password,0,time.Now().Unix()}
    _,err :=models.InsertUser(user)
    if err != nil{
        this.Data["json"] = map[string]interface{}{"code":0,"message":"注册失败"}
    }else{
        this.Data["json"] = map[string]interface{}{"code":1,"message":"注册成功"}
    }
    this.ServeJSON()
}

思路就是先接收表单信息,然后判断数据库中是否已经存在了该用户名,如果已经存在,那么无法进行注册,我们可以通过json返回信息:用户名已经存在。

否则再进行注册,出于对密码安全的考虑,我们可以在数据库中存储密码的md5加密数据。

所以在工具包中,再添加一个工具类:myUtils.go

package utils
​
import (
    "fmt"
    "crypto/md5"
)


**在结束之际,我想重申的是,学习并非如攀登险峻高峰,而是如滴水穿石般的持久累积。尤其当我们步入工作岗位之后,持之以恒的学习变得愈发不易,如同在茫茫大海中独自划舟,稍有松懈便可能被巨浪吞噬。然而,对于我们程序员而言,学习是生存之本,是我们在激烈市场竞争中立于不败之地的关键。一旦停止学习,我们便如同逆水行舟,不进则退,终将被时代的洪流所淘汰。因此,不断汲取新知识,不仅是对自己的提升,更是对自己的一份珍贵投资。让我们不断磨砺自己,与时代共同进步,书写属于我们的辉煌篇章。**


需要完整版PDF学习资源

**需要体系化学习资料的朋友,可以加我V获取:vip204888 (备注网络安全)**

**网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**

**[需要这份系统化资料的朋友,可以点击这里获取](https://bbs.csdn.net/topics/618540462)**

**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**

  • 7
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值