Skip to main content
 Web开发网 » 站长学院 » Thinkphp教程

ThinkPHP自动验证与自动填充无效可能出现的原因(转载)

2021年08月01日7170百度已收录

  自动验证与自动填充是在使用ThinkPHP时经常用到的功能,但偶尔会遇到自动验证与自动填充无效的情况,本文就ThinkPHP 自动验证与自动填充无效可能的原因做一些分析。

  create()

  1、ThinkPHP 自动验证与自动填充是在创建数据对象 create() 时实现的,因此自动验证与自动填充无效很大程度上与 create() 有关。

  create 方法语法如下:

  create(mixed data, string type)

  data 表示接受的数据,type 表示本次的具体操作(写入还是更新数据)。两个参数都可省略,data 参数省略的情况下默认为接受 $_POST 数据,而 type 默认情况下由系统自动识别。

  但系统自动识别 type 是有缺陷的,当传入的字段有主键字段时,系统就识别为更新操作,否则就是写入操作。所以当主键字段非自动增长而是需要 SQL 写入时,那么自动验证和自动填充都可能无效。

  例如添加数据记录时,如果表单中有主键字段或者系统中产生了主键字段(如录入设备编号),那么 ThinkPHP 就认为本次操作为更新操作,对于例如下面设定的自动验证和填充都会略过:

  protected $_validate = array(

  // 新增时验证标题唯一

  array('title','','标题已经存在!',0,'unique',1),

  // 自动填充

  protected $_auto = array(

  // 新增时填充时间戳

  array('pubtime','time',1,'function'),

  尽管在操作中,执行了 add() 操作将数据写入了数据表,但这时会发现自动验证与自动填充无效。

  出现这种情况时,只需将操作类型显式的传入 create() 方法即可,即 create($_POST,1),告诉系统本次操作为写入数据。另外如果传入的数据不是 $_POST ,也要将数据当作参数传入,如 create($_GET)。

  2、字段未对应

  由于粗心,未对应好表单字段与数据表字段。

  3、数据表字段做了更改

  在开发过程中,更改了表字段名称,而缓存未及时更新,导致系统判断为无效字段而被 unset 掉。所以在更改了表字段名称之后,及时将 Runtime/Data 下的数据表缓存清除。

  3、Model 命名错误

  Model 命名错误,未严格按照规范命名,如头字母未大写或粗心导致字母顺序不对,多或少字母等。这等错误往往会直接导致模型失效。

  4、数据表无自增的id

  当我发现运用thinkphp的自动验证和自动填充时,排除以上错误时,还是失效,经过多次的尝试和一些列的搜索,终于找到了这个错误,就是数据表中没有自增的id,因为验证时找不到要验证的数据,所以会失败,以后要注意了。

  以上就是ThinkPHP自动验证与自动填充无效可能出现的几种原因,当出现问题时要一条一条的进行排除,相信自己一定可以找到错误的,当然还有一些未知的错误,如果您发现了另外的一种原因,欢迎大家联系我,及时更新,让更多的人少走弯路,加快开发的进度……

评论列表暂无评论
发表评论
微信