thinkphp学习2-控制器

1.定义控制器

一般来说,ThinkPHP的控制器是一个类,而操作则是控制器类的一个公共方法

控制器通常需要继承系统的Controller类或者其子类,例如,下面定义了一个 \Home\Controller\IndexController 控制器类:

<?php
namespace Home\Controller;
use Think\Controller;

class IndexController extends Controller {
    public function hello(){
        echo ‘hello‘;
    }
    public function test(){
        echo ‘test‘;
   }
}
?>

控制器的名称采用驼峰法命名(首字母大写),操作方法的定义必须是公共方法,否则会报操作错误。

IndexController控制器类的hello和test方法就是操作方法,通过下面的URL地址访问控制器方法:

http://serverName/Home/Index/hello

http://serverName/Home/Index/test

2.实例化控制器

访问控制器的实例化通常是自动完成的,系统会根据URL地址解析出访问的控制器名称自动实例化,并且调用相关的操作方法。

如果你需要跨控制器调用的话,则可以单独实例化:

// 实例化Home模块的User控制器
$user = new \Home\Controller\UserController();

系统为上面的控制器实例化提供了一个快捷调用方法A,上面的代码可以简化为:

// 假设当前模块是Home模块
$user = A(‘User‘);
$blog = A(‘Admin/Blog‘);

3.前置和后置操作

前置和后置操作指的是在执行某个操作方法之前和之后会自动调用的方法,不过仅对访问控制器有效。

前置和后置操作的定义方式如下:

<?php
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<br/>‘;
    }
}

如果我们访问 http://serverName/index.php/Home/Index/index 结果会输出

before
index
after

4.Action参数绑定

参数绑定功能默认是开启的,其原理是把URL中的参数(不包括模块、控制器和操作名)和操作方法中的参数进行绑定。

要启用参数绑定功能,首先确保你开启了URL_PARAMS_BIND设置:

‘URL_PARAMS_BIND‘ => true, // URL变量绑定到操作方法作为参数

默认的参数绑定方式是按照变量名进行绑定,例如:

namespace Home\Controller;
use Think\Controller;
class BlogController extends Controller{
    public function read($id){
        echo ‘id=‘.$id;
    }

    public function archive($year=‘2013‘,$month=‘01‘){
        echo ‘year=‘.$year.‘&amp;month=‘.$month;
    }
}

当访问URL地址:

  http://serverName/index.php/Home/Blog/read/id/5

  http://serverName/index.php/Home/Blog/archive/year/2013/month/11

两个URL地址中的id参数和year和month参数会自动和read操作方法以及archive操作方法的同名参数绑定。

按照变量名进行参数绑定的参数必须和URL中传入的变量名称一致,但是参数顺序不需要一致。

如果使用下面的URL地址进行访问,参数绑定仍然有效:

  http://serverName/index.php?c=Blog&a=read&id=5

  http://serverName/index.php?c=Blog&a=archive&year=2013&month=11

如果用户访问的URL地址是:

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

那么会抛出下面的异常提示: 参数错误:id

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

public function read($id=0){
     echo ‘id=‘.$id;
}

始终给操作方法的参数定义默认值是一个避免报错的好办法。

第二种方式是按照变量的顺序绑定,这种情况下URL地址中的参数顺序非常重要,不能随意调整。要按照变量顺序进行绑定,必须先设置URL_PARAMS_BIND_TYPE为1:

  ‘URL_PARAMS_BIND_TYPE‘ => 1, // 设置参数绑定按照变量顺序绑定

操作方法的定义不需要改变,URL的访问地址分别改成:

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

   http://serverName/index.php/Home/Blog/archive/2013/11

5.AJAX返回

系统的\Think\Controller类提供了ajaxReturn方法用于AJAX调用后返回数据给客户端。并且支持JSON、JSONP、XML和EVAL四种方式给客户端接受数据,并且支持配置其他方式的数据格式返回。如果是EVAL方式的话,只会输出字符串data数据。

ajaxReturn方法调用示例:

$data[‘status‘]  = 1;
$data[‘content‘] = ‘content‘;
$this->ajaxReturn($data);

默认配置采用JSON格式返回数据(通过配置DEFAULT_AJAX_RETURN进行设置),我们可以指定格式返回,例如:

// 指定XML格式返回数据
$data[‘status‘]  = 1;
$data[‘content‘] = ‘content‘;
$this->ajaxReturn($data,‘xml‘);

默认的JSONP格式返回的处理方法是jsonpReturn,如果你采用不同的方法,可以设置:

   ‘DEFAULT_JSONP_HANDLER‘ => ‘myJsonpReturn‘, // 默认JSONP格式返回的处理方法

或者直接在页面中用callback参数来指定。

如下:http://localhost:81/myapp/home/index/test?callback=jsCallback

输出为:

jsCallback({"name":"\u5468\u5bcc\u6c11","age":26});

6.跳转和重定向

系统的\Think\Controller类内置了两个跳转方法success和error,用于页面跳转提示,而且可以支持ajax提交。

success和error方法的第一个参数表示提示信息,第二个参数表示跳转地址,第三个参数是跳转时间(单位为秒),例如:

// 操作完成3秒后跳转到 /Article/index
$this->success(‘操作完成‘,U(‘/Article/index‘),3);
// 操作失败5秒后跳转到 /Article/error
$this->error(‘操作失败‘,U(‘/Article/error‘),5);

跳转地址是可选的,success方法的默认跳转地址是$_SERVER["HTTP_REFERER"],error方法的默认跳转地址是javascript:history.back(-1);

默认的等待时间success方法是1秒,error方法是3秒

success和error方法会自动判断当前请求是否属于Ajax请求,如果属于Ajax请求则会调用ajaxReturn方法返回信息。 ajax方式下面,success和error方法会封装下面的数据返回:

$data[‘info‘]   =   $message; // 提示信息内容
$data[‘status‘] =   $status;  // 状态 如果是success是1 error 是0
$data[‘url‘]    =   $jumpUrl; // 成功或者错误的跳转地址

Controller类的redirect方法可以实现页面的重定向功能。

redirect方法的参数用法和U函数的用法一致,例如:

//重定向到New控制器的Category操作
$this->redirect(‘New/category‘, array(‘cate_id‘ => 2), 5, ‘页面跳转中...‘);

7.URL生成

ThinkPHP内置提供了U方法,用于URL的动态生成,可以确保项目在移植过程中不受环境的影响。

U方法的定义规则如下(方括号内参数根据实际应用决定):

     U(‘地址表达式‘,[‘参数‘],[‘伪静态后缀‘],[‘显示域名‘])

地址表达式的格式定义如下:

   [模块/控制器/操作#锚点@域名]?参数1=值1&参数2=值2...

如果不定义模块的话 就表示当前模块名称,下面是一些简单的例子:

U(‘User/add‘); // 生成User控制器的add操作的URL地址
U(‘Blog/read?id=1‘); // 生成Blog控制器的read操作 并且id为1的URL地址
U(‘Admin/User/select‘); // 生成Admin模块的User控制器的select操作的URL地址

U方法的第二个参数支持数组和字符串两种定义方式,如果只是字符串方式的参数可以在第一个参数中定义,例如:

U(‘Blog/cate‘,array(‘cate_id‘=>1,‘status‘=>1));
U(‘Blog/cate‘,‘cate_id=1&status=1‘);
U(‘Blog/cate?cate_id=1&status=1‘);

注意:如果你是在模板文件中直接使用U方法的话,需要采用 {:U(‘参数1‘, ‘参数2‘…)} 的方式。

时间: 2024-10-14 13:34:13

thinkphp学习2-控制器的相关文章

ThinkPHP 学习之控制器 ( Controller )

/** * ThinkPHP version 3.1.3 * 部署方式:应用部署 * 文内的 http://localhost/ 由实际主机地址代替 */ 入口文件 index.php: <?php define('THINK_PATH','./ThinkPHP/'); //定义项目名称和路径 define('APP_NAME','Myapp'); define('APP_PATH','./home/'); define('APP_DEBUG',true); //加载框架入口文件 require

ThinkPHP学习(二)理清ThinkPHP的目录结构及访问规则,创建第一个控制器

ThinkPHP的目录结构 回顾上一篇的安装目录: 目录对应关系 F:\\PHP├─index.php       入口文件├─README.md       README文件├─Application     应用目录├─Public          资源文件目录└─ThinkPHP        框架目录 thinkphp 的目录结构 ThinkPHP 的目录结构非常清晰和容易部署.大致的目录结构如下,以项目为基础进行部署. ┎━ThinkPHP 框架系统目录┃ ┝ ThinkPHP.ph

Thinkphp学习笔记------- RBAC

1.首先去extends扩展包里找到RBAC类 2.复制里面创建四张表的SQL语句放到mysql里执行,得到四张表. 3.需要自己创建一个user表,字段随意,一般是username password之类存储用户登录信息. 4.RBAC一般就是六个方法:依次为-->用户列表   角色列表   节点列表  添加用户  添加角色  添加节点 5.操作顺序是-->添加角色-->添加节点-->给角色分配节点-->添加用户-->给用户指定角色 6.对角色表(role)进行添加和L

thinkphp学习笔记4—眼花缭乱的配置

1.配置类别 ThinkPHP提供了灵活的全局配置功能,ThinkPHP会依次加载管理配置>项目配置>调试配置>分组配置>扩展配置>动态配置,所以后面的配置权限要大于前面的,因为后面的配置会覆盖前面同名配置,同事会生辰配置缓存文件无需重复解析,减小开销. 惯例配置:在惯例配置内对大多数常用参数进行默认配置,因为惯例配置最先加载,优先级别最低,如果不需要做特殊配置的话,完全可以保持默认值,惯例配置位于ThinkPHP/Conf/convention.php,内容摘抄如下: &l

ThinkPhp学习01

原文:ThinkPhp学习01 一.ThinkPHP的介绍           MVC  M - Model 模型                工作:负责数据的操作  V - View  视图(模板)        工作:负责前台页面显示  C - Controller 控制器(模块) 工作:描述功能 框架二.ThinkPHP的获取            http://www.thinkphp.cn三.ThinkPHP核心文件介绍      ├─ThinkPHP.php     框架入口文件 

ThinkPHP 学习(2)---一个简单的起步的例子

文件夹目录是核心目录ThinkPHP,入口文件是index.php,ThinkPHP里面的文件含义下次详解,接下来是启动一个自己的程序,现在可以修改一下入口文件,一般情况下会将自己的文件放在一个文件夹,我现在是先建立自己的文件夹,一个前台Home文件夹,一个后台文件夹Admin,怎么建立一个结构拥有ThinkPHP功能的文件夹呢?打开index.php,加入如下代码, <?php    //1.确定应用名称Home    define('APP_NAME','Admin');    //2.确定

《PHP框架ThinkPHP学习》系列技术文章整理收藏

<PHP框架ThinkPHP学习>系列技术文章整理收藏 1修改ThinkPHP缓存为Memcache的方法 2Thinkphp实现MySQL读写分离操作示例 3ThinkPHP调用百度翻译类实现在线翻译 4使用ThinkPHP+Uploadify实现图片上传功能 5Thinkphp使用mongodb数据库实现多条件查询方法 6ThinkPHP实现多数据库连接的解决方法 7改写ThinkPHP的U方法使其路由下分页正常 8ThinkPHP实现将SESSION存入MYSQL的方法 9ThinkPH

Thinkphp学习回顾(一)之基本结构目录

TP框架的学习一般都是从了解框架的基本结构开始的,每个文件都有其专属的作用,我的TP框架的回顾也从基本结构开始讲起. 一.ThinkPHP的获取 http://www.thinkphp.cn   这是官方网址,我的TP学习使用的是3.1.3完整版 下载之后,将文件名改为Thinkphp,然后放到自己的项目文件夹下,比如我们要做的项目就是bbs,也就是留言板. 二. 搭建基本结构    //TP 中结构的搭建是自动的 TP 中结构的搭建是自动的,我们只需要在bbs文件夹下建一个index.php的

thinkphp学习笔记5—模块化设计

1.模块结构 完整的ThinkPHP用用围绕模块/控制器/操作设计,并支持多个入口文件盒多级控制.ThinkPHP默认PATHINFO模式,如下: http://serverName/index.php(或者其他应用入口文件)/模块/控制器/操作/[参数名/参数值...] 应用:由同一个入口文件访问的项目称为一个应用,在完整版的代码中就是Application 模块:一个应用下面可以包含多个模块,每个模块对应独立的目录,在完整版的代码中有Admin,Home,Common,Runtime四个模块

ThinkPHP学习(四)volist标签高级应用之多重嵌套循环

Action代码: public function index(){ $prod = I("get.prod_en"); $id = I("get.id", 0, "int"); if ($prod == ""){ $serviceProduct = array();//多重循环遍历的数组 //数据保存在两张表中,这里通过循环初始化$serviceProduct数组 $service = M("product_cla