dsjbest2014 2017-04-19 16:15
浏览 294
已采纳

在beego中处理表单提交的正确方法是什么?

I'm trying to submit form data in beego and store it to database. And have some questions:

  • how correct handle request and transform it to object?
  • Should I validate request or transformed object?

My controller action:

func (c *ServicesController) Edit() {
    var err error
    var id, _ = c.GetUint64(":id")
    var serviceModel = models.Service{}
    var service models.Service

    service, err = serviceModel.FindById(id)

    c.Data["Service"] = service

    if err == orm.ErrNoRows || err == orm.ErrMissPK  {
        c.Abort("404")
    }

    if c.Ctx.Input.IsPost() {
        err = nil
        if err := c.ParseForm(&service); err != nil {
            c.Abort("500")
        }

        serviceModel.CreateOrUpdate(service)
    }

    c.TplName = "services/edit.html"
}

Model:

type Service struct {
    Id       uint64 `form:"-"`
    Name     string `orm:"size(100)" valid:"Required; MaxSize(100)" form:"name"`
}

func init() {
    orm.RegisterModel(new(Service))
}

func (s *Service) FindById(id uint64) (Service, error) {
    o := orm.NewOrm()
    service := Service{Id: id}
    err := o.Read(&service)

    return service, err
}

func (s *Service) CreateOrUpdate(service Service)  {
    o := orm.NewOrm()
    o.InsertOrUpdate(&service)
}

But when I'm trying to submit form (with InsertOrUpdate) it anyway creates new object because I have no id field in the form (because I retrieving object from id param from route). Should I pass id to form anyway or how to hack it?

  • 写回答

1条回答 默认 最新

  • dqnqpqv3841 2017-04-19 23:51
    关注

    Just add the ID after you parse the form:

    if err := c.ParseForm(&service); err != nil {
        c.Abort("500")
    }
    service.Id = id
    

    Looking through beego's source, I think you could do:

    if c.Ctx.Input.IsPost() {
        c.Input().Add("id", id)
        err = nil
        if err := c.ParseForm(&service); err != nil {
            c.Abort("500")
        }
    
        serviceModel.CreateOrUpdate(service)
    }
    

    But if not, I would just restructure your code a little bit:

    func (c *ServicesController) Edit() {
        var id, _ = c.GetUint64(":id")
        var service models.Service{}
        var serviceModel = models.Service{}
        var err error
    
        if c.Ctx.Input.IsPost() {
            if err = c.ParseForm(&service); err != nil {
                c.Abort("500")
            }
            service.Id = id
            serviceModel.CreateOrUpdate(service)
        } else {
            service, err = serviceModel.FindById(id)
            if err == orm.ErrNoRows || err == orm.ErrMissPK  {
            c.Abort("404")
        }
    
        c.Data["Service"] = service
        c.TplName = "services/edit.html"
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 有了解d3和topogram.js库的吗?有偿请教
  • ¥100 任意维数的K均值聚类
  • ¥15 stamps做sbas-insar,时序沉降图怎么画
  • ¥15 unity第一人称射击小游戏,有demo,在原脚本的基础上进行修改以达到要求
  • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看
  • ¥15 关于#Java#的问题,如何解决?
  • ¥15 加热介质是液体,换热器壳侧导热系数和总的导热系数怎么算
  • ¥100 嵌入式系统基于PIC16F882和热敏电阻的数字温度计
  • ¥15 cmd cl 0x000007b
  • ¥20 BAPI_PR_CHANGE how to add account assignment information for service line