本教程操作环境:windows7系统、laravel6版,dell g3电脑。
laravel中的常见路由有哪几种一句话总结:
6种:post,get,put,patch,delete,options
route::get($uri, $callback);route::post($uri, $callback);route::put($uri, $callback);route::patch($uri, $callback);route::delete($uri, $callback);route::options($uri, $callback);
1、lararel的csrf 保护 保护表单安全措施是怎么回事?作用:laravel 提供简单的方法保护你的应用不受到 跨站请求伪造 (csrf) 攻击。跨站请求伪造是一种恶意的攻击,它利用已通过身份验证的用户身份来运行未经授权的命令。
实现:表单中添加如下这句好:{{csrf_field()}}。详见代码
实质:就是在form表单中添加了一个token值; input type="hidden" name="_token" value="sqldhf...一串随机字符串"
原理是:检验表单的token值是否合法,合法就通过,否则就不通过
<form method="post" action="/profile"> {{ csrf_field() }} ...</form>
2、路由中的post请求方式如何书写?就是post方法:route::post('check',"logincontroller@check");
3、路由中的put请求如何实现?路由写法:route的put方法:route::put('put','logincontroller@put');
控制器写法:就是基础控制器的写法
请求页面设置请求类型为put:input type="hidden" name="_method" value="put"
路由中书写
// put请求route::get('putweb','logincontroller@putweb');// put的处理页面route::put('put','logincontroller@put');
控制器书写
// put请求页面public function putweb(){ return view('putweb');}// put请求处理页面public function put(request $request){ dd($request->input());}
请求页面书写
<form action="put" method="post"> <p> {{csrf_field()}} <input type="hidden" name="_method" value="put"> user: <input type="text" name="user" id=""> </p></form>
4、laravel页面中如何一个页面实现多种请求方式(我又可以get方式给页面数据,用户又可以搜索框来post请求)?match(指定请求):route::match(['get','post'],'/',"indexcontroller@index");
控制器代码:判断用户是否为post请求,如果是就输出用户搜索的,否则输出 正常显示到页面的数据
any(全部请求):route::any('/',"indexcontroller@index");
5、laravel资源路由的使用实例及实现(实际项目用的比较多)?实例:后台拥有很多模块,用户模块、管理模块等(增、删、改、查):这样直接在路由中写非常多非常麻烦
route::get('user/index','usercontroller@index');route::get('user/add','usercontroller@add');route::get('user/edit','usercontroller@edit');route::post('user/insert','usercontroller@insert');route::post('user/update','usercontroller@update');route::get('user/del','usercontroller@del');
实现:resource方法:route::resource('admin','indexcontroller');
| get|head | admin | admin.index | app\http\controllers\indexcontroller@index | web | #展示页面| post | admin | admin.store | app\http\controllers\indexcontroller@store | web | #添加操作| get|head | admin/create | admin.create | app\http\controllers\indexcontroller@create | web | #添加页面| delete | admin/{admin} | admin.destroy | app\http\controllers\indexcontroller@destroy | web | #删除操作| put|patch | admin/{admin} | admin.update | app\http\controllers\indexcontroller@update | web | #更新操作| get|head | admin/{admin} | admin.show | app\http\controllers\indexcontroller@show | web || get|head | admin/{admin}/edit | admin.edit | app\http\controllers\indexcontroller@edit | web | #修改页面| get|head | api/user | | closure | api,auth:api |
6、路由如何带参数和多个参数?大括号里参数:route::get('user/del/{id}',function($id){ echo $id; });
多个参数:route::get('userinfo/{name}/{sex}',function($name,$sex){ echo $name; echo $sex; });
可能带或不可能带的参数:问号+默认值:route::get('user/edit/{id?}',function($id="默认值"){ echo $id; });:带默认值保证不带参数的时候有值
7、控制器中如何访问路由中所带的参数?直接传入参数,$_get里面没有值
route::get('userinfo/{name}/{sex}',"indexcontroller@userinfo");// 新建userinfopublic function userinfo($a,$sex1){ var_dump($a); var_dump($sex1);}
8、命名路由是什么以及作用?是什么:就是给路由命名
实现:route::get('abc',"indexcontroller@abc")->name('one');
作用:获取别名的url地址:控制器中:route('one');可以到以one为别名的控制器中
作用:通过命名路由实现重定向(实现重定向的一种方式):控制器中:return redirect()->route('one');
9、路由组命名空间的作用以及实现?实现前后台控制器分离:需要在控制器目录下新建admin目录和home目录 在目录中新建控制器
在route的group方法中指定命名空间:route::group(['namespace'=>'admin'],function(){
在admin中的控制器要写好命名空间,并且继承控制器要use到控制器
//路由中代码route::group(['namespace'=>'admin'],function(){ route::get('admin','indexcontroller@index'); route::get('admin/user','usercontroller@index'); route::get('admin/goods','goodscontroller@index');});route::group(['namespace'=>'home'],function(){ route::get('/','indexcontroller@index');});#需要在控制器目录下新建admin目录和home目录 在目录中新建控制器#注意 需要修改命名空间控制器中代码<?php namespace app\http\controllers\admin; use illuminate\http\request; use db; use app\http\controllers\controller; class usercontroller extends controller { //index 方法 public function index(){ echo "我是后台控制器user"; } }
相关推荐:最新的五个laravel视频教程
以上就是laravel有几种路由的详细内容。
