thinkPHP中的三大自动

class UserModel extends Model{
protected $_validate=array(

//下面还需要再写数组。一个数组就是一条验证规则
//array('验证字段','验证规则','错误提示','验证条件','附加规则','验证时间'),
//验证字段:需要验证的表单字段名称,也可以表单当中的一些辅助字段,例如验证码,附加码,重复密码等
//验证规则,验证规则必须要结合附加规则一起使用
//错误提示:如果出现错误,抛出一个什么样的错误提示告知用户
//验证条件:0,1,2()
//附加规则:
// regex 使肜正则进行验证 可以自己在验证规则当中写一个正则表达示(第一上兄弟连论坛下载高老师的正则视频,
//第二,thinkphp功能强劲他为我们封了一些正则,第三,网上已为了准备了一些常用正则)
// function 使用函数进行验证,前面验证规则这个地方必须要写函数名time
// callback 是一个回调 他会去找当前UserModel当中的一个成员方法
// confirm 验证表单当中的两个字段是否相等。
// equal 验主下是否等于某个值
// in 是否在某一个范围内 验证规则当中需要写上一个数组
// unique 验证是否唯一,系统会要据字段目前的值查询数据库来判断是否有相同的值
//
// 如果用系统内置的一些常用正则,只需要写到错误提示即可,
// require 字段必须验证 email验证邮箱 url是验证url地址的 currency货币 number数字
// 验证时间: 是指数据库操作时间的验证时机
// 1新增数据的时候进行验证 Model::MODEL_INSERT
// 2 编辑的时候才进行验证 Model::MODEL_UPDATE
// 3 全部情况下验证 Model::MODEL_BOTH
//
array("user_name","require","用户名必须要填写!"),
array("user_name","6,12","用户名必须在6到12位之间",0,"length"),
array("real_name","require","需要填写真实的姓名!"),
array("password","require","密码必须要填!"),
array("password","8,12","密码必须在8到12位之间",0,"length"),
array("rePassword","require","重复密码必须要填写!"),
array("password","rePassword","两次输入的密码不一致",0,"confirm"),
array("email","require","邮箱必须要填写"),
array("email","email","邮箱格式错误!",1),
array("verify","require","验证码必须填"),
array("code","checkCode","验证码输入错误",0,"callback"),
);

protected $_auto=array(

//array('填充字段','填充内容','填充条件','附加规则');
//填充字段: 这个字段可以是表单当中的字段,也可以是数据库当中的字段。也可以是一些辅助字段
//填充内容,配合附加规则一同使用
//填充条件, 1,2,3分别对应新增、编辑和所有情况下 Model::MODEL_INSERT (默认参数为新增的时候进行填充)
// 附加规则, function callback, field(用其它字段来填充),表示此处可以拿到其他字段的一个值
// string , 字符串来填充。这一项,是thinkphp自动完成里面的默认选项

array("password","md5",3,"function"),
array("age","deal_int",3,"callback"),
);

protected $_map=array(
"username"=>"user_name", //不同的thinkPHP的版本可能会有差别,注意和$_validate中的字段对应
"realname"=>"real_name", //'是要在表单当中的字段写在前面'=>'是写到后面,数据表当中的真实字段写到后面',
);

protected function deal_int($data){
return (int)$data;
}
protected function checkCode($data){
if(md5($_POST['code'])!=$_SESSION['verify']){
return false;
}
return true;
}
}

时间: 2024-09-13 13:04:04

thinkPHP中的三大自动的相关文章

ThinkPHP中的三大自动简介_php实例

本文较为详细的讲述了ThinkPHP中的三大自动,是非常重要的应用,分享给大家供大家参考.具体如下: 一.自动验证 格式如下: array('验证字段','验证规则','错误提示','验证条件','附加规则','验证时间') 参数说明: 验证字段:需要验证表单字段名称 验证规则:必须要结合附加规则一起使用 错误提示:如果出现错误,抛出一个什么样的错误提示告知用户 验证条件:0.1.2 附加规则:1.regex使用正则验证 2.function使用函数验证 3.callback回调 4.confi

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

自动验证是ThinkPHP模型层提供的一种数据验证方法,可以在使用create创建数据对象的时候自动进行数据验证. 原理: create()方法收集表单($_POST)信息并返回,同时触发表单自动验证,过滤非法字段, 在控制器中使用create()方法,(返回值为true/false),会自动触发模型类中的$_validate属性(为父类Model中的方法,在子类Model中重写),在$_validate中自定义验证规则(验证规则下面会详细说明),当create()方法没有数据即返回值为fals

ThinkPHP中的create方法与自动令牌验证实例教程_php实例

本文实例形式展示了ThinkPHP中的create方法与自动令牌验证的实现方法,具体步骤如下: 一.数据表结构 user表结构如下: id username password 二.view模板部分 \aoli\Home\Tpl\default\User\create.html页面如下: <form action="__URL__/addit" method="post"> <input type="text" name=&quo

Thinkphp中的curd应用实用要点

 这篇文章主要介绍了Thinkphp中的curd应用实用要点并附上了简单的示例,是篇非常不错的文章,这里推荐给大家.     这个主要闲的没事给大家写一下curd的具体应用,当然这里边主要讲curd,我做的是用户的增删改查,没有用三大自动 首先   代码如下: class IndexAction extends Action { public function index(){ header("Content-Type:text/html; charset=utf-8″); $user=M('u

thinkPHP中create方法与令牌验证实例浅析_php实例

本文实例讲述了thinkPHP中create方法与令牌验证.分享给大家供大家参考,具体如下: thinkPHP的create方法与令牌验证主要是涉及表单的安全性. 代码如下: <?php // 本类由系统自动生成,仅供测试用途 class IndexAction extends Action{ public function index(){ $this->display(); } //一般用户在网站完成信息的添加修改--但是有意外,用户吧网页另存为到本地了,然后在这当中模拟了很多组数据,然后

ThinkPHP 中M方法和D方法的具体区别

M方法和D方法的区别 ThinkPHP 中M方法和D方法都用于实例化一个模型类,M方法 用于高效实例化一个基础模型类,而 D方法 用于实例化一个用户定义模型类.   使用M方法 如果是如下情况,请考虑使用 M方法:   对数据表进行简单的 CURD 操作而无复杂的业务逻辑时 只有个别的表有较为复杂的业务逻辑时,将 M方法 与实例化 CommonModel 类进行结合使用 M方法 甚至可以简单看着就是对参数表名对应的数据表的操作:   $User = M('User');  使用D方法 如果是如下

thinkphp学习笔记9—自动加载

原文:thinkphp学习笔记9-自动加载 1.命名空间自动加载 在3.2版本中不需要手动加载类库文件,可以很方便的完成自动加载. 系统可以根据类的命名空间自动定位到类库文件,例如定义了一个类Org\Util\Auth类: namespace Org\Util; class Auth { } 保存到ThinkPHP/Library/Org/Util/Auth.class.php 这样我们就可以直接实例化了, new \Org\Util\Auth(); 实例化之后系统会自动加载 ThinkPHP/

ThinkPHP中公共函数路径和配置项路径的映射分析_php技巧

本文实例分析了ThinkPHP中公共函数路径和配置项路径的映射.分享给大家供大家参考.具体分析如下: ThinkPHP中在使用公共函数时(单一入口文件对应独立的项目),在Common文件夹中可以写公共的函数文件,写成文件名为common.php的文件会被系统自动加载,如果写成其他的函数名,则不会自动加载,但是有两种处理机制 1.在使用的时候手动加载 load('@.function');这样就会手动加载这个文件.@代表是在这个项目下的Common文件夹下的. 2.在配置文件中配置 复制代码 代码

thinkPHP中钩子的两种配置调用方法详解_php实例

本文实例讲述了thinkPHP中钩子的两种配置调用方法.分享给大家供大家参考,具体如下: thinkphp的钩子行为类是一个比较难以理解的问题,网上有很多写thinkphp钩子类的文章,我也是根据网上的文章来设置thinkphp的钩子行为的,但根据这些网上的文章,我在设置的过程中,尝试了十几次都没有成功,不过,我还是没有放弃,最后还是在一边调节细节,一边试验的过程中实现了钩子行为的设置.下面是我个人的设置经验,在这里跟大家分享一下. 个人做了两种设置,都试验成功了,一个简单点,在thinkphp