zoukankan      html  css  js  c++  java
  • thinkphp 表单合法性检测

    在处理表单提交的数据的时候,建议尽量采用ThinkModel类提供的create方法首先进行数据创建,然后再写入数据库。

    大理石平台厂家

    create方法在创建数据的同时,可以进行更为安全的处理操作,而且这一切让你的表单处理变得更简单。

    使用create方法创建数据对象的时候,可以使用数据的合法性检测,支持两种方式:

    一、可以配置insertFields 和 updateFields属性

    可以分别为新增和编辑表单设置insertFields和 updateFields属性,使用create方法创建数据对象的时候,不在定义范围内的属性将直接丢弃,避免表单提交非法数据。

    insertFields 和 updateFields属性的设置采用字符串(逗号分割多个字段)或者数组的方式。

    设置的字段应该是实际的数据表字段,而不受字段映射的影响。例如:

    1. namespace HomeModel;
    2. class UserModel extends ThinkModel{
    3. protected $insertFields = array('account','password','nickname','email');
    4. protected $updateFields = array('nickname','email');
    5. }

    定义后,调用add方法写入用户数据的时候,只能写入'account','password','nickname','email'这几个字段,编辑的时候只能更新'nickname','email'两个字段。

    在使用的时候,我们调用create方法的时候,会根据提交类型自动识别insertFields和updateFields属性:

    1. D('User')->create();

    二、直接调用field方法

    如果不想定义insertFields和updateFields属性,可以在调用create方法之前直接调用field方法,例如,实现和上面的例子同样的作用: 在新增用户数据的时候,使用:

    1. M('User')->field('account,password,nickname,email')->create();

    而在更新用户数据的时候,使用:

    1. M('User')->field('nickname,email')->create();

    这里的字段也是实际的数据表字段。

    field方法也可以使用数组方式。

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

  • 相关阅读:
    《Effective Java》第9章 异常
    《Effective Java》第7章 方法
    《Effective Java》第6章 枚举和注解
    《Effective Java》第5章 泛型
    《Effective Java》第4章 类和接口
    《Effective Java》第3章 对于所有对象都通用的方法
    使用Spring加载properties配置文件.md
    第7章 插件的使用和写法
    第6章 jQuery与Ajax的应用
    第5章 jQuery对表单、表格的操作及更多应用
  • 原文地址:https://www.cnblogs.com/furuihua/p/11842207.html
Copyright © 2011-2022 走看看