本帖最后由 thepoy 于 2020-7-18 22:10 编辑
想测试handler用协程处理。
type User struct {
gorm.Model
Username string `json:"username" form:"username" binding:"required" gorm:"not null;unique"`
Password string `json:"password" form:"password" binding:"required" gorm:"not null"`
Email string `json:"email" form:"email" binding:"required" gorm:"not null;unique"`
Phone string `json:"phone" form:"phone" binding:"required" gorm:"not null;unique"`
RegisterIP string `json:"register_ip" gorm:"not null"`
LastLoginTime time.Time `json:"last_login_time"`
LastLoginIP string `json:"last_login_ip"`
Blogs []Blog
}
func Regsiter(c *gin.Context) {
ctx := c.Copy() // 创建在协程中使用的副本
go func() { // 启用协程
defer func() { // 捕获协程中的异常
if err := recover(); err != nil {
log.Println("register failed: ", err)
}
}()
var form models.User
if err := ctx.ShouldBindWith(&form, binding.Form); err != nil {
log.Println("bind failed: ", err)
ctx.JSON(http.StatusBadRequest, gin.H{
"error": err.Error(),
})
return
}
ctx.JSON(http.StatusCreated, form)
}()
}
协程报错
2020/07/18 10:41:25 bind failed: multipart: NextPart: http: invalid Read on closed Body
2020/07/18 10:41:25 register failed: runtime error: invalid memory address or nil pointer dereference
协程内的ctx.JSON执行有问题,空指针错误应该也是来自于此。
当不用协程时,没有任何异常,代码正常运行和返回结果。
请问这是什么问题?
gin本身支持协程, 我想试一下异步。 |