html5中文学习网

您的位置: 首页 > 网络编程 > PHP编程 » 正文

ZenTaoPHP框架的数据验证机制_PHP教程_编程技术

[ ] 已经帮助:人解决问题

项目中数据验证在web应用中尤其显得重要。下面来给大家介绍下ZenTaoPHP框架的数据验证机制。3huHTML5中文学习网 - HTML5先行者学习网

一、首先来确定一个问题,即验证的规则放在什么地方?3huHTML5中文学习网 - HTML5先行者学习网

mvc程序中,每一层都可以放验证规则。比如很多的表单验证,会自动根据用户的输入进行验证,然后给予提示。那么数据验证放在哪一层呢?这个问题网络上大家有很多的争议。有的人主要放在view这一层,有的则主张放在control层。禅道框架选择了model层。3huHTML5中文学习网 - HTML5先行者学习网

为什么这样做呢?因为model层是最低的一层,所有的数据操作,都要经过model来进行处理。那么只要在这一关把数据验证做好,就可以保证数据的准确和安全。当然,框架的用户,可以同时在前端加上js的验证,和model层的验证不会冲突的。下面来看下如何使用禅道的数据过滤机制。3huHTML5中文学习网 - HTML5先行者学习网

禅道的数据过滤分为两个部分,一个是数据修正,一个是数据验证。这个是受php的filter扩展启发,它里面就是分为了这两个部分。先来看数据修正的例子:3huHTML5中文学习网 - HTML5先行者学习网

二、数据修正:3huHTML5中文学习网 - HTML5先行者学习网

 3huHTML5中文学习网 - HTML5先行者学习网

$bug = fixer::input('post')3huHTML5中文学习网 - HTML5先行者学习网

->add('openedBy', $this->app->user->account) 3huHTML5中文学习网 - HTML5先行者学习网

->add('openedDate', $now) 3huHTML5中文学习网 - HTML5先行者学习网

->setDefault('project,story,task', 0) 3huHTML5中文学习网 - HTML5先行者学习网

->setDefault('openedBuild', '') 3huHTML5中文学习网 - HTML5先行者学习网

->setIF($this->post->assignedTo != '', 'assignedDate', $now) 3huHTML5中文学习网 - HTML5先行者学习网

->setIF($this->post->story != false, 'storyVersion', $this->loadModel('story')->getVersion($this->post->story))3huHTML5中文学习网 - HTML5先行者学习网

->specialChars('title,steps,keyword') 3huHTML5中文学习网 - HTML5先行者学习网

->cleanInt('product, module, severity') 3huHTML5中文学习网 - HTML5先行者学习网

->join('openedBuild', ',') 3huHTML5中文学习网 - HTML5先行者学习网

->remove('files, labels')3huHTML5中文学习网 - HTML5先行者学习网

->get();3huHTML5中文学习网 - HTML5先行者学习网

首先,是调用fixer这个类的input方法,它的参数post表示是从$_POST变量中获取数据。3huHTML5中文学习网 - HTML5先行者学习网

紧接着的两行add(),是向数据中增加两个变量。然后后面的两行setDefault则是表示,当这个变量没有传值的时候,设成默认的值。3huHTML5中文学习网 - HTML5先行者学习网

接下来是两行setIF。setIF共有三个参数,第一个是判断条件,后面两个分别是key和value。也就是当条件为true的时候,设置$key = $value。3huHTML5中文学习网 - HTML5先行者学习网

下面的spechialchars则表示对这三个字段进行htmlspecialchars处理3huHTML5中文学习网 - HTML5先行者学习网

最后,还需要把两个不需要的变量去掉,使用remove。3huHTML5中文学习网 - HTML5先行者学习网

通过get方法就可以得到一个已经经过修改的完整的数据集合。这个集合已经可以准备入库了。让我们来看下数据是如何验证的。3huHTML5中文学习网 - HTML5先行者学习网

三、数据检查3huHTML5中文学习网 - HTML5先行者学习网

/3huHTML5中文学习网 - HTML5先行者学习网

这句sql插入语句通过data方法,将修正过的数据传递给dao对象,然后通过autoCheck()对其进行自动检查。autoCheck会根据数据库里面字段的类型,长度进行判断。如果类型不对,或者长度不对,会自动记录错误。然后后面调用了batchCheck()方法,对一批字段进行非空的验证。当然也可以通过check()方法对单个字段进行验证。3huHTML5中文学习网 - HTML5先行者学习网

if(dao::isError()) die(js::error(dao::getError())); 对,就是这样一句话,如果dao::isError(),则执行getError()方法,然后将其合并成js的字符串,以警告框的形式弹出。执行了getError()之后,所有的错误被清空,这样不会影响下次的执行。3huHTML5中文学习网 - HTML5先行者学习网

3huHTML5中文学习网 - HTML5先行者学习网
3huHTML5中文学习网 - HTML5先行者学习网
(责任编辑:)
推荐书籍
推荐资讯
关于HTML5先行者 - 联系我们 - 广告服务 - 友情链接 - 网站地图 - 版权声明 - 人才招聘 - 帮助