首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

彩虹女神跃长空,Go语言进阶之Go语言高性能Web框架Iris项目实战-完善用户管理EP04

书接上回,上一回我们完成了用户管理页面的构建,并且通过前端的Vue.js框架动态地获取表单数据,同时异步请求后端Iris接口进行入库操作,过程中使用函数封装可复用的逻辑。 本回我们将继续完善用户管理功能。

唯一索引

虽然在之前的章节中已经完成了用户添加(注册)的功能,然而我们忽略了一个重要的细节,那就是用户名(username)应该是全局唯一的字段,而添加逻辑中并未做唯一性校验,事实上唯一性校验有两种方案,一种是入库之前做一次查询,但这样会浪费一次磁盘的IO操作,另外一种就是通过唯一索引进行拦截操作,这里我们采用后者,修改model.go文件:

这里为User结构体的字段Username添加unique索引,随后将user表删除,重新进行数据库迁移操作:

接着查看表结构:

发现username字段已经被Gorm添加了唯一索引:UNIQUE KEY `username` (`username`)

随后修改用户添加逻辑:

这里res结构体中的Error字段来返回错误,如果Error不等于nil,说明被唯一索引拦截了下来。

随后构建 ret 字典,声明错误码和提示信息,然后使用ctx.JSON函数序列化为Json格式返回给前端,注意别忘了用return关键字结束逻辑,否则代码会继续执行,返回值样例:

前端接收到返回值之后,可以通过alert方法打印返回值:

如图所示:

用户更新与删除

用户更新指的是密码的修改,首先需要构造新密码的表单变量:

注意,这里是动态表单,因为每一个表单会对应一个用户:

这里每返回一个用户,就会为该用户对应生成一个value字段。

随后在循环中绑定该字段:

如图所示:

随后绑定单击事件,向后端iris传递参数:

这里传递的参数是用户id以及用户的新密码,注意请求方式使用Put。

随后在后端Iris中添加更新逻辑:

这里使用Put函数监听路由,随后接受参数ID和Password,注意Put和Post方式都采用ctx.PostValue函数来获取参数。

接着使用db.First(&user, ID)函数来进行主键查询,查出用户的结构体变量对象,最后调用db.Save函数来存储更新结果:

可以看到,password和updated_at两个字段已经同步更新了。

接着是删除操作,首先前端添加删除按钮:

随后绑定删除事件:

注意这里的请求方式是delete。

如图所示:

随后编写后端删除逻辑:

这里使用Delete函数来监听路由,同时通过ctx.URLParamIntDefault函数获取前端请求的参数,注意Get和Delete方式获取参数的请求函数是一致的,同理,Post方式和Put方式也是相同的。

接着使用db.Delete(&model.User{}, ID)函数通过用户结构体做主键删除。

结语

至此,完成了用户结构体的增:用户添加(唯一索引拦截);删(主键删除);改(动态表单绑定修改密码);查(结构体单项和批量查询)。该项目已开源在Github:https://github.com/zcxey2911/IrisBlog ,与君共觞,和君共勉。

  • 发表于:
  • 原文链接https://kuaibao.qq.com/s/20221225A015N600?refer=cp_1026
  • 腾讯「腾讯云开发者社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 cloudcommunity@tencent.com 删除。

扫码

添加站长 进交流群

领取专属 10元无门槛券

私享最新 技术干货

扫码加入开发者社群
领券