我们来了解一下控制器定义,包括风格、是否需要继承以及各式各样的输出方式

一.控制器定义

1.控制器,即 controller,控制器文件存放在 controller 目录下;

2.类名和文件名大小写保持一致,并采用驼峰式(首字母大写);use think\Controller;class Index extends Controller

3.继承控制器基类,可以更方便使用功能,但不是必须的;

4.系统也提供了其它方式,在不继承的情况下完成相同功能;

5.前面我们知道如果是一个单词,首字母大写,比如 class Index;

6.URL 访问时直接 public/index 即可;

7.那么如果创建的是双字母组合,比如 class HelloWorld;

8.URL 访问时必须为:public/hello_world;

9.如果你想原样的方式访问 URL,则需要关闭配置文件中自动转换;'url_convert'=> false,

10.此时,URL 访问可以为:public/HelloWorld;

11.如果你想改变根命名空间 app 为其它,可以在根目录下创建.env 文件   项目的根目录下;

12.然后写上配对的键值对即可,app_namespace=application;

 

二.渲染输出

1.ThinkPHP 直接采用方法内 return 返回的方式直接就输出了;

2.使用 json 输出,直接采用 json 函数;$data = array('a'=>1, 'b'=>2, 'c'=>3);return json($data);

3.使用 view 输出模版,开启错误提示,可知道如何创建模版;return view();view默认情况下调用 view下的同名控制器和同名方法.html   

可以指定路径return view('show');默认会找app/index/view/index/upload.html;

4.默认输出方式为 html 格式输出,如果返回的是数组,则会报错;

5.可以更改配置文件里的默认输出类型'defualt_return_type =>"json"'

,更改为 json;return ['user'=>'Lee','age'=>100];'default_return_type'=> 'json',

6.一般来说,正常页面都是 html 输出,用于模版,AJAX 默认为 json;

7.如果继承了基类控制器,那么可以定义控制器初始化方法:initialize();

8.initialize()方法会在调用控制器方法之前执行;

protected function initialize()
{
//parent::initialize();
echo 'init';
}

9.initialize()方法不需要任何返回值,输出用 PHP 方式,return 无效;

 

 

控制器操作

一.前置操作

1.继承 Controller 类后可以设置一个$beforeActionList 属性来创建前置方法;

注意:$brforeActionList   名字别写错  写错不行的

//创建属性  名字不能错误
    protected $beforeActionList=[
        //方法first名字,默认所有方法执行时都调用
        'first',
        //方法three   except 排除方法show方法执行时 不调用three方法,多个方法用逗号隔开 "except"=>"show,test";
        'three'=>['except'=>'show'],
        //方法only  只有test方法执行时 会调用only方法
        "only" =>"test",
    ];

    //正常被执行的test方法
    public function test(){
        echo "1";
    }
    //正常被执行的show方法
    public function show(){
        return "sdfsdf";
    }
    
    //three 前置被调用的方法
    protected function three()
    {
        echo 'three<br/>';
    }
    //only 前置被调用的方法
    protected function only(){
        echo "fffff";
    }
        //frist 前置被调用的方法
    protected function first(){
        echo "first"."<br>";
    }

2.此时,我们可以分别 URL 访问不同的方法来理解前置的触发执行;

 

 

二.跳转和重定向

1.Controller 类提供了两个跳转的方法,success(msg,url)和 error(msg);

 

protected $flag = true;
  public function show(){
    if($this->flag){
        //如果不指定 url,则返回$_SERVER['HTTP_REFERER']
        $this->success("成功","../test_out/view/show");
    }else{
        //自动返回前一页
        $this->error("失败");
    }

    
  }

2.成功或错误有一个固定的页面模版:'thinkphp/tpl/dispatch_jump.tpl';

3.在 app.php 配置文件中,我们可以更改自己个性化的跳转页面;

// 默认跳转页面对应的模板文件
'dispatch_success_tmpl' => Env::get('think_path') 
'tpl/dispatch_jump.tpl',
'dispatch_error_tmpl'
=> Env::get('think_path') .
'tpl/dispatch_jump.tpl',

 

Java控制端 controller控制器_配置文件

 

 

三.空方法和空控制器

1.当访问了一个不存在的方法时,系统会报错,我们可以使用_empty()来拦截;

public function _empty($name)
{
return '不存在当前方法:'.$name;
}

2.当访问了一个不存在的控制器时,系统也会报错,我们可以使用 Error 类来拦截;

class Error
{
public function index(Request $request)
{
return '当前控制器不存在:'.$request->controller();
}
}

3.系统默认为 Error 类,如果需要自定义,则在 app.php 配置文件中修改;

// 默认的空控制器名

'empty_controller'

=> 'Error',  可以修改

 

//引用think\Request类
use think\Request;
class Error{

    public function index(Request $request) { 
        return '当前控制器不存在:'.$request->controller();
     }
}