乐趣区

thikphp-控制器

控制器定义

类名和文件名一样,

渲染输出

渲染输出使用 return 输出

<?php
namespace app\admin\controller;
use app\admin\model\User;

class Index
{public function Index(){
        $data = array(
            'ming' => 'ming',
            'ming' => 'xiao'
        );
        return json($data);
    }

}

此时页面渲染出 json 文件

不能在控制器中中断代码。。
使用 halt 输出

<?php
namespace app\admin\controller;
use app\admin\model\User;

class Index
{public function Index(){
        $data = array(
            'ming' => 'ming',
            'ming' => 'xiao'
        );
        halt("输出测试");
        return json($data);
    }

}

使用 halt 输出

多级控制器

多级控制器 多级控制器直接在命名空间中使用

<?php


namespace app\admin\controller\Index;


class Blog
{public function index(){ }

    public function read($id){var_dump(url('index/blog/read', ['id' => 5, 'name' => 'ming']));
        return $id;
    }
}

定义了 Index 命名空间下的子控制器 Blog
目录结构

定义路由规则

<?php
use think\facade\Route;

Route::rule('blog/:id', 'index.blog/read');
Route::rule('/', 'Index/index');

访问 index 路由下的 blog 目录

基础控制器

控制器都会有一个基础控制器
系统会提供一个

app\BaseController

基础控制器

目录文件如下

所有的控制都有一个基础控制类
appBaseController

由于是多应用模式。。基础类移动到目录下

更改命名空间

namespace app\index\controller;

use think\App;
use think\exception\ValidateException;
use think\Validate;
<?php

namespace app\index\controller;

use think\Request;

class Index extends BaseController
{
    /**
     * 显示资源列表
     *
     * @return \think\Response
     */
    public function index()
    {$action = $this->request->action();
        $path = $this->app->getBasePath();
        var_dump($action);
        var_dump($path);
    }

    /**
     * 显示创建资源表单页.
     *
     * @return \think\Response
     */
    public function create()
    {//}

    /**
     * 保存新建的资源
     *
     * @param  \think\Request  $request
     * @return \think\Response
     */
    public function save(Request $request)
    {//}

    /**
     * 显示指定的资源
     *
     * @param  int  $id
     * @return \think\Response
     */
    public function read($id)
    {//}

    /**
     * 显示编辑资源表单页.
     *
     * @param  int  $id
     * @return \think\Response
     */
    public function edit($id)
    {//}

    /**
     * 保存更新的资源
     *
     * @param  \think\Request  $request
     * @param  int  $id
     * @return \think\Response
     */
    public function update(Request $request, $id)
    {//}

    /**
     * 删除指定资源
     *
     * @param  int  $id
     * @return \think\Response
     */
    public function delete($id)
    {//}
}

输出内容

string(5) "index" string(43) "/home/ming/PhpstormProjects/untitled12/app/"

控制器验证

<?php

namespace app\index\controller;

use think\exception\ValidateException;
use think\Request;

class Index extends BaseController
{
    /**
     * 显示资源列表
     *
     * @return \think\Response
     */
    public function index()
    {
        try {
            $this->validate( [
                'name'  => 'thinkphp',
                'email' => 'thinkphp@qq.com',
            ],  'app\index\validate\User');
        } catch (ValidateException $e) {
            // 验证失败 输出错误信息
            dump($e->getError());
        }
    }

    /**
     * 显示创建资源表单页.
     *
     * @return \think\Response
     */
    public function create()
    {//}

    /**
     * 保存新建的资源
     *
     * @param  \think\Request  $request
     * @return \think\Response
     */
    public function save(Request $request)
    {//}

    /**
     * 显示指定的资源
     *
     * @param  int  $id
     * @return \think\Response
     */
    public function read($id)
    {//}

    /**
     * 显示编辑资源表单页.
     *
     * @param  int  $id
     * @return \think\Response
     */
    public function edit($id)
    {//}

    /**
     * 保存更新的资源
     *
     * @param  \think\Request  $request
     * @param  int  $id
     * @return \think\Response
     */
    public function update(Request $request, $id)
    {//}

    /**
     * 删除指定资源
     *
     * @param  int  $id
     * @return \think\Response
     */
    public function delete($id)
    {//}
}

这样控制器验证

空控制器

空控制器是当找不到的方法的时候调用的方法

    public function __call($name, $arguments)
    {// TODO: Implement __call() method.
        return 'error request';
    }

资源控制器

创建 restful 控制器
输入

php think make:controller index@Blog

生成资源控制器
生成 api

<?php

namespace app\index\controller;

use think\Request;

class Blog
{
    /**
     * 显示资源列表
     *
     * @return \think\Response
     */
    public function index()
    {//}

    /**
     * 保存新建的资源
     *
     * @param  \think\Request  $request
     * @return \think\Response
     */
    public function save(Request $request)
    {//}

    /**
     * 显示指定的资源
     *
     * @param  int  $id
     * @return \think\Response
     */
    public function read($id)
    {//}

    /**
     * 保存更新的资源
     *
     * @param  \think\Request  $request
     * @param  int  $id
     * @return \think\Response
     */
    public function update(Request $request, $id)
    {//}

    /**
     * 删除指定资源
     *
     * @param  int  $id
     * @return \think\Response
     */
    public function delete($id)
    {//}
}

注册资源路由即可

Route::resource('blog', 'Blog');

控制器中间件

编写控制器

<?php


namespace app\index\middleware;

class Hello
{public function handle($request, \Closure $next){
        $request->hello = 'ming';
        return $next($request);
    }
}

使用路由注册控制器

<?php

use think\facade\Route;

Route::rule('ming', 'index/index')->middleware(
    [app\index\middleware\Hello::class]
);

访问 http://localhost:8082/index/ming
出现 ming

说明中间件注册成功

退出移动版