2019.01.10yii2---应用结构----model----验证规则

本文详细介绍了在Yii框架中如何使用ContactForm模型进行数据验证,包括验证规则的定义、数据的有效性检查及错误信息的处理。通过实例展示了如何在前端页面接收用户输入,并利用Model::validate()方法验证数据,确保数据符合业务规则。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.概念:输入的数据,假定ContactForm模型,(首页的http://y2aa-frontend.test/index.php?r=site%2Fcontact

你可能想确保所有属性不为空且 email 属性包含一个有效的邮箱地址,

如果某个属性的值不满足对应的业务规则,

相应的错误信息应显示,以帮助用户修正错误。

http://y2aa-frontend.test/index.php?r=site%2Fcontact页面)

2.可调用 yii\base\Model::validate() 来验证接收到的数据是否为空,

该方法使用yii\base\Model::rules()申明的验证规则来验证每个相关属性是否符合条件,

如果没有找到错误,会返回 true, 否则它会将错误保存在 yii\base\Model::$errors 属性中并返回false

(首页验证此段代码。浏览器输入url  http://y2aa-frontend.test/index.php?r=site%2Findex

(frontend/web/index.php中写的)

$model = new \frontend\models\ContactForm;//实例化模型类(可以打印出来结果的)

// 将用户输入的数据---赋值给模型属性(attributes)
$model->attributes = \Yii::$app->request->post('ContactForm');
echo '<pre>';
//var_dump($model->attributes);(包含所有属性的值 name,)
echo '</pre>';
if ($model->validate()) {
    // 所有输入数据都有效 all inputs are valid
    echo 111111;
} else {
    // 验证失败打印错误信息:$errors 是一个包含错误信息的数组
        echo $errors = $model->errors;
}

(//var_dump($model->attributes);(包含所有属性的值 name,)的结果)

http://y2aa-frontend.test/index.php?r=site%2Findex

(echo $errors = $model->errors;的结果)

http://y2aa-frontend.test/index.php?r=site%2Findex

3.不同情景下,使用不同的的验证规则。

(frontend/models/contactform.php)

(frontend/web/index.php中写的)

$model = new \frontend\models\ContactForm;

// 用户输入数据赋值到模型属性
$model->attributes = \Yii::$app->request->post('ContactForm');
echo '<pre>';
//var_dump($model->attributes);
echo '</pre>';
if ($model->validate()) {
    // 所有输入数据都有效 all inputs are valid
    echo 111111;
} else {
    // 验证失败:$errors 是一个包含错误信息的数组
        echo $errors = $model->errors;
}

((http://y2aa-frontend.test/index.php?r=site%2Findex))

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值