84669 人学习
152542 人学习
20005 人学习
5487 人学习
7821 人学习
359900 人学习
3350 人学习
180660 人学习
48569 人学习
18603 人学习
40936 人学习
1549 人学习
1183 人学习
32909 人学习
一般验证规则是这样写的:
// 验证确认密码是否和密码一致 array('repassword','password','确认密码不正确。',0,'confirm'),
第四个参数是0,表示数据库中存在repassword这列的话则验证,但是自己写的代码,难道不知道数据库中是否存在这列吗?
如果没有这列,写这个验证规则不是很多余吗?
如果有这一列,参数直接写1(必须验证)不是更好吗?
另外一个疑问就是:数据库中有必要为同一个用户名存两个相同的密码吗?
业精于勤,荒于嬉;行成于思,毁于随。
confirm 字段不是为了你存数据库使用的。使用场景一般是,用户注册、修改密码的时候,让用户输入两次密码第一次是用户设置的密码,第二次是用户确认密码
confirm的作用就是验证表单中的两个字段是否相同第4个参数有三个值可选:
Model::EXISTS_VALIDATE 或者0 存在字段就验证 (默认) Model::MUST_VALIDATE 或者1 必须验证 Model::VALUE_VALIDATE或者2 值不为空的时候验证
他说的存在字段并不是数据库存的字段,而是表单中的控件的name值,与数据库的那个字段不是同一个概念默认的情况下是表单中有这个name值的控件才进行验证的
confirm 字段不是为了你存数据库使用的。
使用场景一般是,用户注册、修改密码的时候,让用户输入两次密码
第一次是用户设置的密码,第二次是用户确认密码
confirm的作用就是验证表单中的两个字段是否相同
第4个参数有三个值可选:
他说的存在字段并不是数据库存的字段,而是表单中的控件的name值,与数据库的那个字段不是同一个概念
默认的情况下是表单中有这个name值的控件才进行验证的