如何按顺序应用验证组
编辑本页警告:您正在浏览的文档欧宝官网下载appob娱乐下载Symfony 2.8,现已不再维护。
读本页的更新版本用于Syob娱乐下载mfony 6.2(当前稳定版本)。
如何按顺序应用验证组
在某些情况下,您希望按步骤验证组。要做到这一点,可以使用GroupSequence
特性。在这种情况下,一个对象定义了一个组序列,该序列决定了应该验证的订单组。
例如,假设你有一个用户
类,并希望仅在所有其他验证都通过时验证用户名和密码是否不同(以避免出现多个错误消息)。
- 注释
- YAML
- XML
- PHP
12 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29
/ / src / AppBundle /实体/ User.php名称空间AppBundle\实体;使用ob娱乐下载\组件\安全\核心\用户\用户界面;使用ob娱乐下载\组件\验证器\约束作为断言;/ * * *@Assert\GroupSequence({"User", "Strict"}) */类用户实现了用户界面{/ * * *@Assert\ NotBlank * /私人$用户名;/ * * *@Assert\ NotBlank * /私人$密码;/ * * *@Assert\IsTrue(message="密码不能匹配您的用户名",groups={"严格"})*/公共函数isPasswordSafe(){返回($这->用户名= = !$这->密码);}}
在本例中,它将首先验证组中的所有约束用户
(与默认的
组)。只有当该组中的所有约束都有效时,第二组,严格的
,将被验证。
谨慎
正如你已经看到的如何仅应用所有验证约束的子集(验证组),默认的
组和包含类名的组(例如。用户
)。然而,当使用组序列时,它们不再相同。的默认的
Group现在将引用组序列,而不是不属于任何组的所有约束。
这意味着您必须使用{名称}
(如。用户
)组。当使用默认的
,你得到一个无限递归(如默认的
组引用组序列,该组序列将包含默认的
引用相同组序列的组,…)。
属性中定义组序列validation_groups
形式选择:
12 3 4 5 6 7 8 9 10 11 12 13 14
使用ob娱乐下载\组件\验证器\约束\GroupSequence;使用ob娱乐下载\组件\形式\AbstractType;/ /……类MyType扩展AbstractType{/ /……公共函数configureOptions(OptionsResolver$解析器){$解析器->setDefaults ([“validation_groups”= >新GroupSequence ([“第一”,“第二”))));}}
组序列提供程序
想象一个用户
实体,可以是普通用户或高级用户。当它是高级用户时,应该向用户实体添加一些额外的约束(例如信用卡详细信息)。要动态确定应该激活哪些组,可以创建组序列提供程序。首先,创建实体和名为溢价
:
- 注释
- YAML
- XML
- PHP
12 3 4 5 6 7 8 9 10 11 12 13 14 16 17 18 19 20 21 22
/ / src / AppBundle /实体/ User.php名称空间AppBundle\实体;使用ob娱乐下载\组件\验证器\约束作为断言;类用户{/ * * *@Assert\ NotBlank * /私人$的名字;/ * * *@Assert\ CardScheme(*计划={}“签证”,*组={"溢价 "}, * ) */私人$信用卡;/ /……}
现在,更改用户
要实现的类GroupSequenceProviderInterface并添加getGroupSequence (),方法,该方法应该返回要使用的组的数组:
12 3 4 5 6 7 8 9 10 11 12 13 14 16 17 18 19 20 21
/ / src / AppBundle /实体/ User.php名称空间AppBundle\实体;/ /……使用ob娱乐下载\组件\验证器\GroupSequenceProviderInterface;类用户实现了GroupSequenceProviderInterface{/ /……公共函数getGroupSequence(){$组=数组(“用户”);如果($这->isPremium ()) {$组[] =“溢价”;}返回$组;}}
最后,您必须通知Validator组件您的用户
类提供了需要验证的组序列:
- 注释
- YAML
- XML
- PHP
12 3 4 5 6 7 8 9 10 11 12
/ / src / AppBundle /实体/ User.php名称空间AppBundle\实体;/ /……/ * * *@Assert\ GroupSequenceProvider * /类用户实现了GroupSequenceProviderInterface{/ /……}
此工作,包括代码示例,是根据创作共用BY-SA 3.0许可证。