php yii2 cli 参数,yii2 在控制器中验证请求参数的使用方法

该博客介绍了在Yii2框架中如何优化控制器中的请求参数验证。通过创建一个`ParamsValidateService`服务类,利用`ParamsValidateModel`模型来集中处理验证规则,避免了为每个API接口单独编写模型。这种方式允许在外部设置验证规则,简化了代码并提高了代码复用性。
摘要由CSDN通过智能技术生成

写api接口时一般会在控制器中简单验证参数的正确性。

使用yii只带验证器(因为比较熟悉)实现有两种方式(效果都不佳)。

针对每个请求单独写个 Model , 定义验证规则并进行验证。 缺点:写好多参数验证的 Model 类。

使用 独立验证器 中提到的 $validator->validateValue()方法直接验证变量值。缺点:写实例化很多验证器对象。

有么有“一劳永逸”的做法,像在 Model 中通过 rules 方法定义验证规则并实现快速验证的呢?有!

使用方法(实现效果)

namespace frontend\controllers\api;

use yii\web\Controller;

use common\services\app\ParamsValidateService;

class ArticleController extends Controller

{

// 文章列表

public function actionList()

{

$PVS = new ParamsValidateService();

$valid = $PVS->validate(\Yii::$app->request->get(), [

['category_id', 'required'],

['category_id', 'integer'],

['keyword', 'string'],

]);

if (!$valid) {

$this->apiError(1001, $PVS->getErrorSummary(true));

}

//...

}

// 新增文章

public function actionPost()

{

$PVS = new ParamsValidateService();

$valid = $PVS->validate(\Yii::$app->request->get(), [

[['category_id', 'title', 'content'], 'required'],

['category_id', 'integer'],

[['title'], 'string', 'max' => 64],

[['content'], 'string'],

]);

if (!$valid) {

$this->apiError(1001, $PVS->getErrorSummary(true));

}

//...

}

// 文章删除

public function actionDelete()

{

$PVS = new ParamsValidateService();

$valid = $PVS->validate(\Yii::$app->request->get(), [

['article_id', 'required'],

['article_id', 'integer'],

]);

if (!$valid) {

$this->apiError(1001, $PVS->getErrorSummary(true));

}

//...

}

}

实现方法

定义参数验证模型

定义参数验证模型ParamsValidateModel,继承 yii\db\ActiveRecord,重写attributes()方法,主要功能:

验证规则可从对象外部进行设置。

从验证规则中获取可赋值的属性。

namespace common\models\app;

use yii\db\ActiveRecord;

class ParamsValidateModel extends ActiveRecord

{

/**

* @var array 验证规则

*/

private $_rules = [];

private $_attributes = [];

// 设置验证规则

public function setRules($rules)

{

$this->_rules = $rules;

foreach ($rules as $item) {

$this->_attributes = array_unique(array_merge($this->_attributes, (array)$item[0]));

}

}

// 重写获取验证规则

public function rules()

{

return $this->_rules;

}

// 设置可用属性列表

public function attributes()

{

return $this->_attributes;

}

}

定义参数验证服务类

定义参数验证服务类,主要功能有:

设置参数列表和参数规则列表。

使用 参数验证模型 进行验证和存储验证错误消息。

使用魔术方法获取 参数验证模型 中的验证错误消息。

namespace common\services\app;

use common\models\app\ParamsValidateModel;

use yii\base\Component;

/**

* Class ParamsValidateService

* @package common\services\app

* @method array getErrors(\string $attribute)

* @method array getFirstErrors()

* @method array getFirstError(\string $attribute)

* @method array getErrorSummary(\boolean $showAllErrors)

*/

class ParamsValidateService extends Component

{

/**

* @var ParamsValidateModel 模型

*/

private $model = null;

public function init()

{

parent::init();

$this->model = new ParamsValidateModel();

}

/**

* @param array $data 数据项

* @param array $rules 验证规则

* @return bool

*/

public function validate($data, $rules)

{

// 添加验证规则

$this->model->setRules($rules);

// 设置参数

$this->model->load($data, '');

// 进行验证

return $this->model->validate();

}

public function __call($name, $params)

{

if ($this->model->hasMethod($name)) {

return call_user_func_array([$this->model, $name], $params);

} else {

return parent::__call($name, $params);

}

}

}

总结

以上所述是小编给大家介绍的yii2 在控制器中验证请求参数的使用方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值