ThinkPHP3.1版的Action参数绑定功能提供了URL变量和操作方法的参数绑定支持,这一功能可以使得你的操作方法定义和参数获取更加清晰,也便于跨模块调用操作方法。这一新特性对以往的操作方法使用没有任何影响,你也可以用新的方式来改造以往的操作方法定义。
Action参数绑定的原理是把URL中的参数(不包括分组、模块和操作地址)和控制器的操作方法中的参数进行绑定。例如,我们给Blog模块定义了两个操作方法read和archive方法,由于read操作需要指定一个id参数,archive方法需要指定年份(year)和月份(month)两个参数。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
class BlogAction extends Action{ public function read( $id ){ echo 'id=' . $id ; $Blog = M( 'Blog' ); $Blog ->find( $id ); } public function archive( $year = '2012' , $month = '01' ){ echo 'year=' . $year . '&month=' . $month ; $Blog = M( 'Blog' ); $year = $year ; $month = $month ; $begin_time = strtotime ( $year . $month . "01" ); $end_time = strtotime ( "+1 month" , $begin_time ); $map [ 'create_time' ] = array ( array ( 'gt' , $begin_time ), array ( 'lt' , $end_time )); $map [ 'status' ] = 1; $list = $Blog ->where( $map )->select(); } } |
URL的访问地址分别是:
1
2
|
http://serverName/index.php/Blog/read/id/5 http://serverName/index.php/Blog/archive/year/2012/month/03 |
两个URL地址中的id参数和year和month参数会自动和read操作方法以及archive操作方法的同名参数绑定。
输出的结果依次是:
1
2
|
id=5 year=2012&month=03 |
Action参数绑定的参数必须和URL中传入的参数名称一致,但是参数顺序不需要一致。也就是说
1
|
http://serverName/index.php/Blog/archive/month/03/year/2012 |
和上面的访问结果是一致的,URL中的参数顺序和操作方法中的参数顺序都可以随意调整,关键是确保参数名称一致即可。
如果用户访问的URL地址是(至于为什么会这么访问暂且不提):
1
|
http://serverName/index.php/Blog/read/ |
那么会抛出下面的异常提示:
参数错误:id
报错的原因很简单,因为在执行read操作方法的时候,id参数是必须传入参数的,但是方法无法从URL地址中获取正确的id参数信息。由于我们不能相信用户的任何输入,因此建议你给read方法的id参数添加默认值,例如:
1
2
3
4
5
|
public function read( $id =0){ echo 'id=' . $id ; $Blog = M( 'Blog' ); $Blog ->find( $id ); } |
这样,当我们访问
1
|
http://serverName/index.php/Blog/read/ |
的时候 就会输出
1
|
id=0 |
当我们访问
1
|
http://serverName/index.php/Blog/archive/ |
的时候,输出:
1
|
year=2012&month=01 |