# 快速入门(十三):初始化、前置和后置操作
本章的内容讲解了如何在ThinkPHP控制器的操作方法调用之前或者之后做一些额外的操作,涉及到的知识点包括初始化操作、前置和后置操作。
## 初始化操作
如果要在控制器的任何操作方法之前都执行某个方法的话,可以使用下面的方式:
~~~
namespace Home\Controller;
use Think\Controller;
class IndexController extends Controller{
// 初始化方法
public function _initialize(){
echo 'initialize<br/>';
}
public function index(){
echo 'index';
}
public function hello(){
echo 'hello';
}
}
~~~
如果我们访问 `http://serverName/index.php/Home/index/index`
结果会输出
~~~
initialize
index
~~~
如果我们访问 `http://serverName/index.php/Home/index/hello`
结果会输出
~~~
initialize
hello
~~~
可以看出,无论是执行index操作还是hello操作 都会首先执行`_initialize`操作方法。
如果把`_initialize`操作方法定义到一个公共的控制器类里面的话,那么所有的控制器操作方法之前都会执行。
## 前置和后置操作
`_initialize`方法是调用所有操作方法之前都会执行,前置和后置操作则是针对某个特定的操作方法而言。
如果当前访问的操作是存在(必须是实际在控制器中定义过)的,系统会检测当前操作是否具有前置和后置操作,如果存在就会按照顺序执行,前置和后置操作的方法名是在要执行的方法前面加 `_before_`和`_after_`,例如:
~~~
namespace Home\Controller;
use Think\Controller;
class IndexController extends Controller{
//前置操作方法
public function _before_index(){
echo 'before<br/>';
}
public function index(){
echo 'index<br/>';
}
//后置操作方法
public function _after_index(){
echo 'after';
}
}
~~~
如果我们访问 `http://serverName/index.php`
结果会输出
~~~
before
index
after
~~~
对于任何操作方法我们都可以按照这样的规则来定义前置和后置方法。
如果在操作方法里面使用了exit或者error方法的话 有可能不会再执行后置方法了,例如:
~~~
namespace Home\Controller;
use Think\Controller;
class IndexController extends Controller{
//前置操作方法
public function _before_index(){
echo 'before<br/>';
}
public function index(){
echo 'index<br/>';
exit;
}
//后置操作方法
public function _after_index(){
echo 'after';
}
}
~~~
如果我们再次访问结果会输出
~~~
before
index
~~~
> 除了初始化、前置和后置操作之外,我们还可以在控制器以外的地方对操作方法进行扩展,这个以后会在行为扩展部分描述。