大橙子网站建设,新征程启航
为企业提供网站建设、域名注册、服务器等服务
这篇文章给大家分享的是golang实现用户登录注册的方法,相信大部分人都还没学会这个技能,为了让大家学会,给大家总结了以下内容,话不多说,一起往下看吧。
为天水等地区用户提供了全套网页设计制作服务,及天水网站建设行业解决方案。主营业务为网站设计、做网站、天水网站设计,以传统方式定制建设网站,并提供域名空间备案等一条龙服务,秉承以专业、用心的态度为用户提供真诚的服务。我们深信只要达到每一位用户的要求,就会得到认可,从而选择与我们长期合作。这样,我们也可以走得更远!
第一步 注册models
models下建立models.go
models.go文件
package models import ( "github.com/astaxie/beego" "github.com/astaxie/beego/orm" _ "github.com/go-sql-driver/MySQL" ) func RegisterDB() { //注册驱动 orm.RegisterDriver("mysql", orm.DRMySQL) //数据库链接 //注册默认数据库 var db_url string = beego.AppConfig.String("username_DB") + ":" + beego.AppConfig.String("password_DB") + "@tcp(" + beego.AppConfig.String("host_DB") + ")/" + beego.AppConfig.String("name_DB") + "?charset=" + beego.AppConfig.String("charset") beego.Info(db_url) orm.RegisterDataBase("default", "mysql", db_url) // orm.RegisterDataBase("default", "mysql", "an:111@tcp(127.0.0.1:3306)/yoo_home?charset=utf8") // //注册model orm.RegisterModel(new(TUser)) }
第二步 数据库连接的需要
conf下的app.conf文件
appname = an httpport = 8080 runmode = dev sessionon = true #数据库为mysql host_DB = "127.0.0.1" port_DB = "3306" charset = "utf8" name_DB = "ancg" username_DB = "an" password_DB = 111
第三步 写个简单的前端 view界面
views 下建立client.html文件
客户端接口测试
第四步 在models中 建立TUser 用来为数据库自动建表使用
TUser.go
package models import ( "github.com/astaxie/beego/orm" //_"github.com/go-sql-driver/mysql" ) //用户表 type TUser struct { //用户序号 Id int64 //电话号码 Tep string //密码 Pwd string //收款人 Payee string //地址 Address string //收款帐号 Amount string //账号类别 AmountType string //是否消费者 IsCustomer bool //是否商家 IsSeller bool //是否配送员 IsDiliver bool //是否管理员 IsManager bool //微信openId Vid string //是否冻结 IsLock bool //创建时间 --- 时间戳 AddTime int64 } //新建用户 func AddUser(user *TUser) (int64, error) { o := orm.NewOrm() //数据库 userId, err := o.Insert(user) //插入数据 return userId, err } //查询账号 func GetUserById(userId int64) (*TUser, error) { o := orm.NewOrm() //数据库 user := new(TUser) //TUser就是第9行struct的数据库,就是mysql的表 qs := o.QueryTable("t_user") //表名为t_user err := qs.Filter("id", userId).One(user) //One是指查询一条数据,One(user)是查询mysql表中一条数据 return user, err } //手机号查询账号 func GetUserByTel(tel string) (*TUser, error) { o := orm.NewOrm() user := new(TUser) //TUser就是第9行struct的数据库,就是mysql的表 qs := o.QueryTable("t_user") //表名为t_user err := qs.Filter("tel", tel).One(user) //One是指查询一条数据,One(user)是查询mysql表中一条数据 return user, err } //微信Id查询账号 func GetUserByVid(vid int64) (*TUser, error) { o := orm.NewOrm() user := new(TUser) //TUser就是第9行struct的数据库,就是mysql的表 qs := o.QueryTable("t_user") //表名为t_user err := qs.Filter("vid", vid).One(user) //One是指查询一条数据,One(user)是查询mysql表中一条数据 return user, err }
第五步 controllers 里面建立一个主接options的文件,用对应option来调用其它的controllers
client.go文件
package controllers import ( "github.com/astaxie/beego" "time" ) type ClientController struct { beego.Controller } func (this *ClientController) Get() { this.TplName = "client.html" } func (this *ClientController) Post() { options := this.Input().Get("options") beego.Info(options) //请求检查方法 if options != "" { switch options { case "login": this.login() case "register": this.register() default: this.Data["json"] = map[string]interface{}{"status": 400, "msg": "无对应处理方法!", "time": time.Now().Format("2006-12-12 12:12:12")} this.ServeJSON() return } this.Data["json"] = map[string]interface{}{"status": 400, "msg": "options为空", "time": time.Now().Format("2006-12-12 12:12:12")} this.ServeJSON() return } }
以上就是golang实现用户登录注册的方法,详细使用情况还需要大家自己亲自动手使用过才能领会。如果想了解更多相关内容,欢迎关注创新互联行业资讯频道!