Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
Y
yii2
Project
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
PSDI Army
yii2
Commits
413a1486
Commit
413a1486
authored
Jun 06, 2014
by
Qiang Xue
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
guide WIP [skip ci]
parent
5670bc3d
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
104 additions
and
53 deletions
+104
-53
input-validation.md
docs/guide/input-validation.md
+79
-10
structure-models.md
docs/guide/structure-models.md
+25
-43
No files found.
docs/guide/input-validation.md
View file @
413a1486
Validating Input
Validating Input
================
================
> Note: This section is under development.
As a rule of thumb, you should never trust the data coming from end users and should always validate them
before putting them to good use. In the
[
Models
](
structure-models.md#validation
)
section, we have described
how validation works in general. In this section, we will give more details about validation.
In the
[
Models
](
structure-models.md#validation
)
section, we have described how data validation works
in general. In this section, we will mainly focus on describing core validators, how to define your
own validators, and different ways of using validators.
## Validating Input
## Declaring Validation Rules
Assume you have a model that takes user input. In order to validate the input, you should define a set
of validation rules by overriding the
[
[yii\base\Model::rules()
]
] method, like the following,
## Data Validation
```
php
public
function
rules
()
{
return
[
// the name, email, subject and body attributes are required
[[
'name'
,
'email'
,
'subject'
,
'body'
],
'required'
],
// the email attribute should be a valid email address
[
'email'
,
'email'
],
];
}
```
The
`rules()`
method returns an array of rules, each of which is an array in the following format:
```
php
[
// required, specifies which attributes should be validated by this rule.
// For single attribute, you can use the attribute name directly
// without having it in an array instead of an array
[
'attribute1'
,
'attribute2'
,
...
],
// required, specifies the type of this rule.
// It can be a class name, validator alias, or a validation method name
'validator'
,
// optional, specifies in which scenario(s) this rule should be applied
// if not given, it means the rule applies to all scenarios
'on'
=>
[
'scenario1'
,
'scenario2'
,
...
],
// optional, specifies additional configurations for the validator object
'property1'
=>
'value1'
,
'property2'
=>
'value2'
,
...
]
```
When the
`validate()`
method is called, it does the following steps to perform validation:
### Getting Error Messages
1.
Determine which attributes should be validated by checking the current
[
[yii\base\Model::scenario|scenario
]
]
against the scenarios declared in
[
[yii\base\Model::scenarios()
]
]. These attributes are the active attributes.
2.
Determine which rules should be applied by checking the current
[
[yii\base\Model::scenario|scenario
]
]
against the rules declared in
[
[yii\base\Model::rules()
]
]. These rules are the active rules.
3.
Use each active rule to validate each active attribute which is associated with the rule.
### Empty Values
According to the above validation steps, an attribute will be validated if and only if it is
an active attribute declared in
`scenarios()`
and it is associated with one or multiple active rules
declared in
`rules()`
.
Yii provides a set of
[
built-in validators
](
tutorial-core-validators.md
)
to support commonly needed data
validation tasks. You may also create your own validators by extending
[
[yii\validators\Validator
]
] or
writing an inline validation method within model classes. For more details about the built-in validators
and how to create your own validators, please refer to the
[
Input Validation
](
input-validation.md
)
section.
### Declaring Validation Rules
### Error Messages
### Core Validators
### Conditional Validation
### Ad Hoc Validation
### Data Filtering
## Creating Validators
### Inline Validators
### Standalone Validators
###
Array Value
s
###
Empty Inputs and Array Input
s
##
Data Filtering
##
# Client-Side Validation
...
...
docs/guide/structure-models.md
View file @
413a1486
...
@@ -171,7 +171,8 @@ $model->scenario = 'login';
...
@@ -171,7 +171,8 @@ $model->scenario = 'login';
$model
=
new
User
([
'scenario'
=>
'login'
]);
$model
=
new
User
([
'scenario'
=>
'login'
]);
```
```
To support multiple scenarios by a single model, you may override the
[
[yii\base\Model::scenarios()
]
] method,
By default, the scenarios supported by a model are determined by the
[
validation rules
](
#validation
)
declared
in the model. However, you can customize this behavior by overriding the
[
[yii\base\Model::scenarios()
]
] method,
like the following:
like the following:
```
php
```
php
...
@@ -233,10 +234,10 @@ you may want to make sure all attributes are not empty and the `email` attribute
...
@@ -233,10 +234,10 @@ you may want to make sure all attributes are not empty and the `email` attribute
If the values for some attributes do not satisfy the corresponding business rules, appropriate error messages
If the values for some attributes do not satisfy the corresponding business rules, appropriate error messages
should be displayed to help the user to fix the errors.
should be displayed to help the user to fix the errors.
You may call
[
[yii\base\Model::validate()
]
] to
trigger validation. The method will go through every
*active rule*
You may call
[
[yii\base\Model::validate()
]
] to
validate the received data. The method will use
and make sure it is satisfied. If not, an error message will be generated for each failed rule and attribute.
the validation rules declared in
[
[yii\base\Model::rules()
]
] to validate every relevant attribute. If no error
The method returns a boolean value indicating whether all rules are satisfied. If not, you may retrieve the
is found, it will return true. Otherwise, it will keep the errors in the
[
[yii\base\Model::errors
]
] property
error messages through the property
[
[yii\base\Model::errors
]
] or
[
[yii\base\Model::firstErrors
]
]
. For example,
and return false
. For example,
```
php
```
php
$model
=
new
\app\models\ContactForm
;
$model
=
new
\app\models\ContactForm
;
...
@@ -254,7 +255,7 @@ if ($model->validate()) {
...
@@ -254,7 +255,7 @@ if ($model->validate()) {
To declare validation rules associated with a model, override the
[
[yii\base\Model::rules()
]
] method by returning
To declare validation rules associated with a model, override the
[
[yii\base\Model::rules()
]
] method by returning
the rules that the model
data should satisfy. The following example should the validation rules
the rules that the model
attributes should satisfy. The following example shows the validation rules declared
for the
`ContactForm`
model:
for the
`ContactForm`
model:
```
php
```
php
...
@@ -270,47 +271,28 @@ public function rules()
...
@@ -270,47 +271,28 @@ public function rules()
}
}
```
```
The
`rules()`
method returns an array of rules, each of which is an array in the following format:
A rule can be used to validate one or multiple attributes, and an attribute may be validated by one or multiple rules.
Please refer to the
[
Validating Input
](
input-validation.md
)
section for more details on how to declare
validation rules.
```
php
Sometimes, you may want a rule to be applied only in certain
[
scenarios
](
#scenarios
)
. To do so, you can
[
specify the
`on`
property of a rule, like the following:
// required, specifies which attributes should be validated by this rule.
// For single attribute, you can use the attribute name directly
// without having it in an array instead of an array
[
'attribute1'
,
'attribute2'
,
...
],
// required, specifies the type of this rule.
// It can be a class name, validator alias, or a validation method name
'validator'
,
// optional, specifies in which scenario(s) this rule should be applied
// if not given, it means the rule applies to all scenarios
'on'
=>
[
'scenario1'
,
'scenario2'
,
...
],
// optional, specifies additional configurations for the validator object
'property1'
=>
'value1'
,
'property2'
=>
'value2'
,
...
]
```
A rule may be applied to one or multiple attributes. A rule may be applicable only in certain
[
scenarios
](
#scenarios
)
.
When a rule is applicable in a scenario, it is called an
*active rule*
in that scenario.
When the
`validate()`
method is called, it does the following steps to perform validation:
```
php
public
function
rules
()
1.
Determine which attributes should be validated by checking the current
[
[yii\base\Model::scenario|scenario
]
]
{
against the scenarios declared in
[
[yii\base\Model::scenarios()
]
]. These attributes are the active attributes.
return
[
2.
Determine which rules should be applied by checking the current
[
[yii\base\Model::scenario|scenario
]
]
// username, email and password are all required in "register" scenario
against the rules declared in
[
[yii\base\Model::rules()
]
]. These rules are the active rules.
[[
'username'
,
'email'
,
'password'
],
'required'
,
'on'
=>
'register'
],
3.
Use each active rule to validate each active attribute which is associated with the rule.
According to the above validation steps, an attribute will be validated if and only if it is
// username and password are required in "login" scenario
an active attribute declared in
`scenarios()`
and it is associated with one or multiple active rules
[[
'username'
,
'password'
],
'required'
,
'on'
=>
'login'
],
declared in
`rules()`
.
];
}
```
Yii provides a set of
[
built-in validators
](
tutorial-core-validators.md
)
to support commonly needed data
If you do not specify the
`on`
property, the rule would be applied in all scenarios. A rule is called
validation tasks. You may also create your own validators by extending
[
[yii\validators\Validator
]
] or
an
*active rule*
if it can be applied in the current
[
[yii\base\Model::scenario|scenario
]
].
writing an inline validation method within model classes. For more details about the built-in validators
and how to create your own validators, please refer to the
[
Input Validation
](
input-validation.md
)
section.
## Massive Assignment <a name="massive-assignment"></a>
## Massive Assignment <a name="massive-assignment"></a>
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment