在 Yii 2.0 中数据验证失败:来源发布用户ID必须是一条字符串的分析解决(为了保证版本的兼容性,必须同时支持数字类型与字符串类型)

1、在 Yii 2.0 中数据验证失败:来源发布用户ID必须是一条字符串。如图1

图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

图2

5、查看生成的 SQL 语句,字段:source_pub_user_id 已经是字符串类型,如图3

图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)

 

永夜