zoukankan      html  css  js  c++  java
  • ThinkPHP3.1新特性:Action参数绑定

    Action参数绑定功能提供了URL变量和操作方法的参数绑定支持,这一功能可以使得你的操作方法定义和参数获取更加清晰,也便于跨模块调用操作方法了。这一新特性对以往的操作方法使用没有任何影响,你也可以用新的方式来改造以往的操作方法定义。
    Action参数绑定的原理是把URL中的参数(不包括分组、模块和操作地址)和控制器的操作方法中的参数进行绑定。例如,我们给Blog模块定义了两个操作方法read和archive方法,由于read操作需要指定一个id参数,archive方法需要指定年份(year)和月份(month)两个参数。

    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的访问地址分别是:

    http://serverName/index.php/Blog/read/id/5
    http://serverName/index.php/Blog/archive/year/2012/month/03

    两个URL地址中的id参数和year和month参数会自动和read操作方法以及archive操作方法的同名参数绑定。
    输出的结果依次是:

    id=5
    year=2012&month=03

    Action参数绑定的参数必须和URL中传入的参数名称一致,但是参数顺序不需要一致。也就是说

    http://serverName/index.php/Blog/archive/month/03/year/2012

    和上面的访问结果是一致的,URL中的参数顺序和操作方法中的参数顺序都可以随意调整,关键是确保参数名称一致即可。
    如果用户访问的URL地址是(至于为什么会这么访问暂且不提):

    http://serverName/index.php/Blog/read/

    那么会抛出下面的异常提示:
    参数错误:id
    报错的原因很简单,因为在执行read操作方法的时候,id参数是必须传入参数的,但是方法无法从URL地址中获取正确的id参数信息。由于我们不能相信用户的任何输入,因此建议你给read方法的id参数添加默认值,例如:

        public function read($id=0){
            echo 'id='.$id;
            $Blog = M('Blog');
            $Blog->find($id);
        }

    这样,当我们访问

    http://serverName/index.php/Blog/read/

    的时候 就会输出

    id=0

    当我们访问

    http://serverName/index.php/Blog/archive/

    的时候,输出:

    year=2012&month=01

    via:http://www.thinkphp.cn/document/103.html

  • 相关阅读:
    mysql字符集编码整理
    mysql 修改字符集
    数据库高并发的设计
    mysql 中 character set 与 collation 的理解
    阿里代码规范检查工具的安装使用
    安卓学习Day05
    安卓学习Day04
    安卓学习Day03
    安卓学习day02
    安卓学习Day1
  • 原文地址:https://www.cnblogs.com/dekevin/p/4259566.html
Copyright © 2011-2022 走看看