1、在 Yii 2.0 中数据验证失败:来源发布用户ID必须是一条字符串。如图1
2、原因在于字段:source_pub_user_id 之前在表中是 int(11) 类型,后来修改为了 varchar(64),基于 Gii 重新生成的模型文件中,验证规则如下
/** * {@inheritdoc} */ public function rules() { return [ [['source_pub_user_id'], 'string', 'max' => 64], ]; }
3、接口已经对接了多个客户端,为了保证版本的兼容性,不能够强制要求客户端调整字段的类型为字符串类型,仍然需要兼容数字类型,因此,在 Gii 生成的验证规则之前,先执行过滤器,转换为字符串类型,调整验证规则如下
/** * @inheritdoc */ public function rules() { $rules = [ /* 创建 */ // 标准化 "source_pub_user_id" 输入 ['source_pub_user_id', 'filter', 'filter' => function ($value) { // 在此处标准化输入的来源发布用户ID return (string) $value; }, 'on' => self::SCENARIO_CREATE], ]; $parentRules = parent::rules(); return ArrayHelper::merge($rules, $parentRules); }
4、在 Yii 2.0 中数据验证成功,如图2
5、查看生成的 SQL 语句,字段:source_pub_user_id 已经是字符串类型,如图3
INSERT INTO `cpa_task` (`group_id`, `source`, `source_uuid`, `source_pub_user_id`, `source_callback_url`, `channel_id`, `channel_code`, `channel_type_id`, `channel_type_code`, `status`, `created_at`, `updated_at`) VALUES ('015ce30b116ce86058fa6ab4fea4ac63', 'spider', '825e6d5e36468cc4bf536799ce3565cf', '3', 'http://scms.wjdev.chinamcloud.cn/api/thirdPush/callBack', 1, 'qq', 1, 'qq_cw', 1, 1566280998, 1566280998)
原创文章,作者:ItWorker,如若转载,请注明出处:https://blog.ytso.com/250475.html