控制器定义
类名和文件名一样,
渲染输出
渲染输出使用 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
说明中间件注册成功