mysql表进行合法性检查_表单合法性检测

# 表单合法性检测

[上一页](# "上一页")[下一页](# "下一页")

在处理表单提交的数据的时候,建议尽量采用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方法也可以使用数组方式。

使用字段合法性检测后,你不再需要担心用户在提交表单的时候注入非法字段数据了。

[上一页](# "上一页")[下一页](# "下一页")

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值