在上一课程中,你可能会对ThinkPHP的路由会有一丝丝疑惑,不过没关系,学完本课程,很多事都会豁然开朗。
控制器文件命名遵守IndexController.class.PHP的方式
控制器的定义
在开始之前,我们还是需要明确一下控制器的定义:
public function read($ID){echo "read page with " .$ID;
}
public function top(){
echo "top page ";
}
}
如所见,前面在路由篇提到的控制器就是这么定义的:
使用相应的命名空间,默认是namespace Home\Controller加载Think\Controller新建控制器继承于Controller(或子类)采用驼峰命名法,注意首字母大写控制器内的公共方法可以看作一个 *** 作,比如上面的read()和top()方法就可以看作 *** 作,我们在路由篇的时候都验证过了。
就是访问到top()方法,会在页面上打印出top page ,再次明确Home代表的是Home模块
有时候可能会遇到有和系统的关键字冲突的方法,这时候就可以使用设置 *** 作方法后缀来解决了,具体请看官方文档:
前置和后置 *** 作
前置和后置 *** 作指的是在执行某个 *** 作方法之前和之后会自动调用的方法,不过仅对访问控制器有效,如在IndexController中为top()方法添加前置后置方法:
"; } public function top(){ echo "top page "; } public function _after_top(){ echo "after top page "; }访问:
就会看到打印出:
使用前置和后置 *** 作要注意如下两点:
如果当前的 *** 作并没有定义 *** 作方法,而是直接渲染模板文件,那么如果定义了前置和后置方法的话,依然会生效。真正有模板输出的可能仅仅是当前的 *** 作,前置和后置 *** 作一般情况是没有任何输出的。
需要注意的是,在有些方法里面使用了exit或者错误输出之类的话 有可能不会再执行后置方法了。例如,如果在当前 *** 作里面调用了系统Action的error方法,那么将不会再执行后置 *** 作,但是不影响success方法的后置方法执行
可以用于表单的过滤和验证
参数绑定
参数绑定是通过直接绑定URL地址中的变量作为 *** 作方法的参数,可以简化方法的定义甚至路由的解析。
true参数绑定功能默认是开启的,其原理是把URL中的参数(不包括模块、控制器和 *** 作名)和 *** 作方法中的参数进行绑定。参数绑定有两种方式:按照变量名绑定和按照变量顺序绑定,默认使用的是按照变量名绑定,比如看下面的例子:
".$id; }public function archive($year,$month){
echo "$year ".$month;
}
对,这个就是上一篇路由所涉及的内容,在之前路由的路由设置处
'blogs/:id' => array('Index/read')我们将:id直接映射给read()方法的参数$id,所以现在回头再看,其实路由规则就是给了你一个自定义URL的功能。如果去掉上面的路由设置,我们正确的访问方式是:
上面的URl中ID就是变量名,如果你写成:
".$Title; }那么访问地址就是:
对于多个参数绑定的情况,只要将相应的变量名和值传进来就可以了,不在乎顺序,比如下面两个会返回相同的结果:
需要注意的是,不管那种情况之下,当你访问
是会报错的:
参数错误或者未定义:ID解决的一个好方法就是,给绑定的参数设置默认值,比如:
".$ID; }这样再次访问上面的URL,就会输出:
read page with0
tips:给绑定参数设置默认值是一个避免报错的好办法在实际的开发中,我们其实会见到没有显示变量名这样的URL,如:
怎么解决呢?这个时候,我们其实就可以用到第二种参数绑定:按照变量顺序绑定。要使用这种参数绑定,需要先在设置项中设置:
1一旦设置变量顺序绑定,这种情况下URL地址中的参数顺序非常重要,不能随意调整。这种情况下 *** 作方法的定义不需要改变,只是访问的URL变了而已,现在用上面的方式访问就可以正确访问了。
如果在变量顺序绑定的情况下,我们访问:
这两个结果显然是不一样,后者并不是我们想要的。所以这种情况需要严格遵守顺序来传值。
伪静态
URL伪静态通常是为了满足更好的SEO效果,ThinkPHP支持伪静态URL设置,可以通过设置URL_HTML_SUFFIX参数随意在URL的最后增加你想要的静态后缀,而不会影响当前 *** 作的正常执行,默认情况下,伪静态的设置为html。但我们可以自己设置,例如
'URL_HTML_SUFFIX'=>'shtml'
如果希望支持多个伪静态后缀,可以直接设置如下:
'URL_HTML_SUFFIX' => 'html|shtml|xml'
如果此项设置留空则表示可以支持所有的静态后缀。
也可以设置禁止访问的URL后缀通过URL_DENY_SUFFIX来设置,例如:
'URL_DENY_SUFFIX' => 'pdf|ico|png|gif|jpg',注: URL_DENY_SUFFIX的优先级比URL_HTML_SUFFIX要高。
URL生成
为了配合所使用的URL模式,我们需要能够动态的根据当前的URL设置生成对应的URL地址,为此,ThinkPHP内置提供了U方法,用于URL的动态生成,可以确保项目在移植过程中不受环境的影响。
定义规则
U方法的定义规则如下(方括号内参数根据实际应用决定):U('地址表达式',['参数'],['伪静态后缀'],['显示域名'])
地址表达式
地址表达式的格式定义如下:
[模块/控制器/ *** 作#锚点@域名]?参数1=值1&参数2=值2...如果不定义模块的话 就表示当前模块名称,下面是一些简单的例子:
U('User/add') // 生成User控制器的add *** 作的URL地址U('Article/read?id=1') // 生成Article控制器的read *** 作 并且id为1的URL地址U('Admin/User/select') // 生成Admin模块的User控制器的select *** 作的URL地址
参数
U方法的第二个参数支持数组和字符串两种定义方式,如果只是字符串方式的参数可以在第一个参数中定义,例如:
1,'status'=>1))U('Article/cate','cate_id=1&status=1')U('Article/cate?cate_id=1&status=1')三种方式是等效的,都是生成Article控制器的cate() *** 作 并且cate_id为1 status为1的URL地址
但是不允许使用下面的定义方式来传参数:
生成路由地址
U方法还可以支持路由,如果我们定义了一个路由规则为:
'Index/read'那么可以使用
最终生成的URL地址是:
跳转和重定向
这应该是在开发中最常用的功能之一。在应用开发中,经常会遇到一些带有提示信息的跳转页面,例如 *** 作成功或者 *** 作错误页面,并且自动跳转到另外一个目标页面。系统的\Think\Controller类内置了两个跳转方法success()和error(),用于页面跳转提示。
跳转
使用方法很简单,比如我们在Index控制器下新建一个方法user(),写上下面的内容:
add($data); if($result){ $this->success('success','/Home/User/addUser'); } else { $this->error('Failed'); } }M('User')表示实例化一个User对象,add()方法是向数据库添加一条纪录。然后我们需要新建一个UserController,在里面写上addUser()方法
use Think\Controller;class UserController extends Controller {
public function addUser()
{
echo 'add user done!';
}
}
然后在浏览器中访问,就可以看到add user done!了,下面详细来说说这两个重定向方法。
success()和error()方法的第一个参数表示提示信息,第二个参数表示跳转地址,第三个参数是跳转时间(单位为秒),例如:
success('done','/Home/Article/index',3);// redirect to /Article/error after 5 seconds when failed$this->error('failed','/Home/Article/error',5);如果不设置跳转时间,默认的等待时间success()方法是1秒,error()方法是3秒。看到上面的两个跳转地址前面都带上了/Home,如果你想简写为/Article/index,你需要在ThinkPHP的入口文件(项目目录下的index.php)中加上下面一行:
而且这两个方法都有对应的模板,默认的设置是两个方法对应的模板都是:
'TMPL_ACTION_ERROR' => THINK_PATH . 'Tpl/dispatch_jump.tpl',
'TMPL_ACTION_SUCCESS' => THINK_PATH . 'Tpl/dispatch_jump.tpl',你可以根据自己的需要来修改模版。
重定向
Controller类的redirect()方法可以实现页面的重定向功能。redirect()方法的参数用法和U函数的用法一致(参考上一部分URL生成部分),例如:
$this->redirect('/Home/Article/show',array('id' => 2),3,'Redirecting...');上面的用法是停留3秒后跳转到Article控制器的show() *** 作,并且显示页面跳转中字样Redirecting...,重定向后会改变当前的URL地址。
为了成功进行测试,我们在IndexController下添加redirectToArticle()方法并写上上面那行代码:
redirect('/Home/Article/show','Redirecting...'); }然后我们创建一个ArticleController,并且为他添加show()方法:
use Think\Controller;class ArticleController extends Controller {
public function show($id)
{
echo 'This is an Article Page';
// $id 变量我们后续会用到,现在只是演示跳转
}
}
然后在浏览器访问:,等待三秒,你就可以看到跳转之后的页面了。
如果你仅仅是想重定向要一个指定的URL地址,而不是到某个模块的 *** 作方法,可以直接使用redirect()函数重定向,例如
$this->redirect('/Home/Article/show/ID/3','Redirecting...',3);
注:控制器的redirect()方法和redirect()函数的区别在于前者是用URL规则定义跳转地址,后者是一个纯粹的URL地址注:好像官方文档是这样写的
$this->redirect('/New/category/cate_ID/2',5,'页面跳转中...');
以上所述就是本文的全部内容了,希望大家能够喜欢。
总结以上是内存溢出为你收集整理的ThinkPHP控制器详解全部内容,希望文章能够帮你解决ThinkPHP控制器详解所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)