官方文档传送门:http://localhost:8000/?token=go1http://laravelacademy.org/post/7836.html
简介
控制器用于将相关的 HTTP 请求封装到一个类中进行处理,这些控制器类存放在 app/Http/Controllers 目录下.
创建一个控制器
在命令行输入如下命令:
php artisan make:controller UserController
效果如下:
成功创建一个控制器
在创建的新UserController控制器里创建show方法如下:
image.png
然后再web里定义路由:
Route::get('user/{id}', 'UserController@show');
创建路由
在 resources/veiws 目录下创建 user 子目录,然后在 user 目录下新建 profile.blade.php 文件,编辑文件内容如下:
{{dd($user)}}
在浏览器输入:http://localhost:8000/user/1 如下显示:
控制器中间件
在路由上给控制器添加中间件,代码如下所示:
Route::get('ro','UserController@show') -> middleware('token');
同样们也可以把中间件放在控制器的构造方法中,如下图所示:
资源控制器
Laravel的资源控制器可以让我们很便捷的构建基于资源的RESTful控制器,下面我们来创建一个资源控制器,在命令行输入如下命令:
php artisan make:controller PostController --resource
成功创建资源控制器
该文件是生成在:\app\Http\Controllers\目录下的PostController.php文件;
该文件主要有如下方法:
/**
* Display a listing of the resource.
*
* @return \Illuminate\Http\Response
*/
public function index()
{
//
echo "index";
}
/**
* Show the form for creating a new resource.
*
* @return \Illuminate\Http\Response
*/
public function create()
{
//
echo "create";
}
/**
* Store a newly created resource in storage.
*
* @param \Illuminate\Http\Request $request
* @return \Illuminate\Http\Response
*/
public function store(Request $request)
{
//
echo "store";
}
/**
* Display the specified resource.
*
* @param int $id
* @return \Illuminate\Http\Response
*/
public function show($id)
{
//
echo "show";
}
/**
* Show the form for editing the specified resource.
*
* @param int $id
* @return \Illuminate\Http\Response
*/
public function edit($id)
{
//
echo "edit";
}
/**
* Update the specified resource in storage.
*
* @param \Illuminate\Http\Request $request
* @param int $id
* @return \Illuminate\Http\Response
*/
public function update(Request $request, $id)
{
//
echo "update";
}
/**
* Remove the specified resource from storage.
*
* @param int $id
* @return \Illuminate\Http\Response
*/
public function destroy($id)
{
//
echo "destroy";
}
然后通过resource为方法注册一个资源路由:
Route:resource('posts','PostController');
资源控制器处理动作:
下面来进行测试:
index方法:
路由:
Route::get('form',function(){
return view("form");
});
Route::resource('posts','PostController') ;
form表单创建在\resources\views\下:
<form action = "posts" , method ="get">
<input type = "text" name = "token" />
<input type = "submit" value = "submin"/>
</form>
浏览器输入:http://localhost:8000/form,显示如下:
点击submit,显示如下:
由于form表单只支持get和post提交,所以其他提交方法得使用伪造表单法,即在表单中输入:
{{ method_field('请求') }}
//post提交需要使用如下方法避免 CSRF 攻击,具体请参考官方文档:http://laravelacademy.org/post/7820.html
{{ csrf_field() }}
update 方法:
路由依旧是上述路由只需要修改form表单内容如下:、
<form action = "posts\1" , method ="post">
{{ method_field('PUT') }}
{{ csrf_field() }}
<input type = "text" name = "token" />
<input type = "submit" value = "submin"/>
</form>
action里还可以这样写:{{ route('posts.update')}},1
浏览器输入:http://localhost:8000/form,显示如下:
form表单
点击submit,显示如下:
其他方法一也是样,只需要更改form表单里的{{ method_field('请求') }}‘请求’即可,在这不多做解释了。