ThinkPHP中create方法自动验证表单信息_第1页
ThinkPHP中create方法自动验证表单信息_第2页
ThinkPHP中create方法自动验证表单信息_第3页
ThinkPHP中create方法自动验证表单信息_第4页
ThinkPHP中create方法自动验证表单信息_第5页
已阅读5页,还剩1页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

本文格式为Word版,下载可任意编辑——ThinkPHP中create方法自动验证表单信息ThinkPHP中create方法自动验证表单信息

文章主要为大家细致介绍了ThinkPHP中create方法自动验证表单信息,具有确定的参考价值,感兴趣的小伙伴们可以参考一下。

自动验证是ThinkPHP模型层供给的一种数据验证方法,可以在使用create创造数据对象的时候自动举行数据验证。

原理:

create方法收集表单$_POST信息并返回,同时触发表单自动验证,过滤非法字段,

在操纵器中使用create方法,返回值为true/false,会自动触发模型类中的'$_validate属性(为父类Model中的方法,在子类Model中重写),在$_validate中自定义验证规矩(验证规矩下面会细致说明),当create方法没有数据即返回值为false时,通过$xxx对象-getError;获取并返回错误信息!

使用自动验证务必按照以下规矩格式定义:

protected$_validate=array

array验证字段1,验证规矩,错误提示,[验证条件,附加规矩,验证时间],

array验证字段2,验证规矩,错误提示,[验证条件,附加规矩,验证时间],

;

其中验证字段,验证规矩,错误提示是必填项,验证条件,附加规矩,验证时间为可选!

验证字段(必填):表单字段。

验证规矩(必填):require字段务必、email邮箱、urlURL地址、number数字,还可以结合附加规矩使用。

错误提示(必填):验证失败时返回的提示信息。

验证条件(可选):有0,1,2三种,0:_POST中存在的字段验证,默认;1:验证规矩定义了就务必验证;2:值不为空时验证.

附加规矩:

验证时间(可选):共有1,2,3三种,1:新增数据时候验证;2:编辑数据时候验证;3:全部处境下验证(默认);也可以可以根据业务需要增加其他的验证时间

下面附上代码:以注册为例

前台页面对比简朴,代码就不贴出来了,下面是前台注册界面截图

操纵器代码:

//注册

publicfunctionregister

$user=new\Model\UserModel;

//两个规律:收集,表示

if!empty$_POST

//create方法收集表单$_POST信息并返回,同时触发表单自动验证,过滤非法字段

$date=$user-create;

//通过create方法的返回值$date判断验证是否告成

if$date//返回实在数据的时候才举行添加

//implode把数组变为字符串

$date[user_hobby]=implode,,$date[user_hobby];

$info=$user-add$date;

if$info

//跳转首页

$this-redirectIndex/index;

else

//把错误信息调配到前台模板

$error=$user-getError;

$this-assignerror,$error;

ThinkPHP中create方法自动验证表单信息

//调用view视图

$this-display;

模型类代码:

classUserModelextendsModel

//是否批量处理验证,批量获取全部的错误验证信息

protected$patchValidate=true;//默认为false

//自动验证定义

protected$_validate=array

//array字段,验证规矩,错误提示,验证条件,附加规矩,验证时间

//①用户名验证,不能为空

arrayusername,require,用户名不能为空,

arrayusername,,该用户名已经被占用,0,unique,

//②密码验证,不为空

arraypassword,require,密码不能为空,

//③验证确认密码,务必填写,与密码保持一致

arraypassword2,require,确认密码务必填写,

arraypassword2,password,两次密码保持一致,0,confirm,

//④邮箱验证

arrayuser_email,email,邮箱格式不正确,2,

//⑤验证,数字组成,5-12位

arrayuser_,number,务必是数字,

arrayuser_,5,12,位数在5-12位之间,0,length,

//⑥学历验证,务必选一个

arrayuser_xueli,2,5,学位务必选择一个,0,between,

//⑦爱好验证,务必选择二个以上

//由于爱好返回的是数组,附加规矩中没有可以直接用的规矩,所以需自定义方法,用callback方法验证

arrayuser_hobby,check_hobby,爱好务必选两项或以上,1,callback,

;

//定义方法举行爱好验证

//参数$arg代表被验证的表单信息

functioncheck_hobby$arg

//判断数组长度是否大于2

ifcount$arg2

returnfalse;//会自动输出验证错误信息

ThinkPHP中create方法自动验证表单信息

returntrue;

把验证的错误信息在模板中给表示出来(片面代码)

tdstyle=width:13%;text-align:right;

labelfor=User_usernameclass=required用户名

span*/span/label

/td

tdstyle=width:87%;

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论