ThinkChat2.0新版上线,更智能更精彩,支持会话、画图、阅读、搜索等,送10W Token,即刻开启你的AI之旅 广告
在处理表单提交的数据的时候,建议尽量采用Think\Model类提供的create方法首先进行数据创建,然后再写入数据库。 > create方法在创建数据的同时,可以进行更为安全的处理操作,而且这一切让你的表单处理变得更简单。 使用create方法创建数据对象的时候,可以使用数据的合法性检测,支持两种方式: ### 配置insertFields 和 updateFields属性 可以分别为新增和编辑表单设置`insertFields`和 `updateFields`属性,使用create方法创建数据对象的时候,不在定义范围内的属性将直接丢弃,避免表单提交非法数据。 insertFields 和 updateFields属性的设置采用字符串(逗号分割多个字段)或者数组的方式。 设置的字段应该是实际的数据表字段,而不受字段映射的影响。例如: ~~~ ~~~ namespace Home\Model; class UserModel extends \Think\Model{ protected $insertFields = array('account','password','nickname','email'); protected $updateFields = array('nickname','email'); } ~~~ ~~~ 定义后,调用add方法写入用户数据的时候,只能写入`'account','password','nickname','email'`这几个字段,编辑的时候只能更新`'nickname','email'`两个字段。 在使用的时候,我们调用create方法的时候,会根据提交类型自动识别insertFields和updateFields属性: ~~~ ~~~ D('User')->create(); ~~~ ~~~ ### 直接调用field方法 如果不想定义insertFields和updateFields属性,可以在调用create方法之前直接调用field方法,例如,实现和上面的例子同样的作用: 在新增用户数据的时候,使用: ~~~ ~~~ M('User')->field('account,password,nickname,email')->create(); ~~~ ~~~ 而在更新用户数据的时候,使用: ~~~ ~~~ M('User')->field('nickname,email')->create(); ~~~ ~~~ 这里的字段也是实际的数据表字段。 > field方法也可以使用数组方式。 使用字段合法性检测后,你不再需要担心用户在提交表单的时候注入非法字段数据了。