Laravel框架路由与MVC实例详解

时间:2022-11-20 19:00:15

本文实例讲述了Laravel框架路由MVC。分享给大家供大家参考,具体如下:

1、路由

路由的作用就是将用户的不同url请求转发给相应的程序进行处理,laravel的路由定义在routes文件夹中,默认提供了四个路由文件,其中web.php文件定义基本页面请求。

1.1、基本路由

最基本的路由请求是get与post请求,laravel通过Route对象来定义不同的请求方式。例如定义一个url为'req'的get请求,返回字符串‘get response':

  1. Route::get('req',function (){
  2. return 'get response';
  3. });

当我以get的方式请求http://localhost/Laravel/laravel52/public/req时,返回如下:

Laravel框架路由与MVC实例详解

同理,当定义post请求时,使用Route::post(url,function(){});

1.2、多请求路由

如果希望对多种请求方式采用相同的处理,可以使用match或any:

使用match来匹配对应的请求方式,例如当以get或post请求req2时,都返回match response:

  1. Route::match(['get','post'],'req2',function (){
  2. return 'match response';
  3. });

any会匹配任意请求方式,例如以任意方式请求req3,返回any response:

  1. Route::any('req3',function (){
  2. return 'any response';
  3. });

1.3、请求参数

必选参数:当以带参数的形式发送请求时,可以在路由中进行接收,用大括号将参数括起,用/分割,例如:

  1. Route::get('req4/{name}/{age}', function ($name, $age) {
  2. return "I'm {$name},{$age} years old.";
  3. });

以get请求时将参数传递,结果如下:

Laravel框架路由与MVC实例详解

可选参数:以上的参数是必须的,如果缺少某一个参数就会报错,如果希望某个参数是可选的,可以为它加一个?,并设置默认值,默认参数必须为最后一个参数,否则放中间没法识别:

  1. Route::get('req4/{name}/{age?}', function ($name, $age=0) {
  2. return "I'm {$name},{$age} years old.";
  3. });

正则校验:可以通过where对请求中的参数进行校验

  1. Route::get('req4/{name}/{age?}', function ($name, $age=0) {
  2. return "I'm {$name},{$age} years old.";
  3. })->where(['name'=>'[A-Za-z]+','age'=>'[0-9]+']);

1.4、路由群组

有时我们的路由可能有多个层级,例如定义一级路由home,其下有二级路由article,comment等,这就需要将article与comment放到home这个群组中。通过数组键prefix为路由article添加前缀home:

  1. Route::group(['prefix' => 'home'], function () {
  2. Route::get('article', function () {
  3. return 'home/article';
  4. });
  5. });

这样通过home/article就可以访问到该路由了。

1.5、路由命名

有时需要给路由起个名字,需要在定义路由时使用as数组键来指定路由名称。例如将路由home/comment命名为comment,在生成url与重定向时就可以使用路由的名字comment:

  1. Route::get('home/comment',['as'=>'comment',function(){
  2. return route('comment'); //通过route函数生成comment对应的url
  3. }]);

输出为http://localhost/Laravel/laravel52/public/home/comment

2、控制器

route路由只对请求进行分配跳转,具体的业务逻辑则需要由控制器来处理,控制器一般封装成为一个php类。控制器的文件一般放在app/Http/Controlers文件夹下。例如新建一个LoginController类继承自Controller,定义checkLog方法回应登录请求,

  1. namespace App\Http\Controllers;
  2. class LoginController extends Controller
  3. {
  4. public function checkLog($name){
  5. return $name.'登录成功';
  6. }
  7. }

在route.php中将login请求分配到checkLog方法:

  1. Route::get('login/{name}','LoginController@checkLog');

Laravel框架路由与MVC实例详解

同样的,可以为控制器路由起个名字,比如将其命名为login:

  1. Route::get('login/{name}',['uses'=>'LoginController@checkLog','as'=>'login']);

3、视图

controller负责处理应用的逻辑,应用的显示则由视图View负责,这体现了MVC中不同的逻辑之间的分离。视图一般位于/resource/views目录下,一般一个controller文件对应一个视图文件夹,因此我创建的视图为:views/Login/login.blade.php。blade文件是laravel的一个模板引擎,它编译为PHP储存起来。它包含HTML语言,可以在其中直接使用PHP,例如login.blade.php:

  1. <!DOCTYPE Html>
  2. <html>
  3. <head>
  4. <title>登录界面</title>
  5. </head>
  6. <body>
  7. {{$name}}登录成功
  8. </body>
  9. </html>

在controller的checkLog方法中调用视图并传入参数:

  1. public function checkLog($name){
  2. return View('Login/login',[
  3. "name"=>$name
  4. ]);
  5. }

4、模板

在mvc中通过Models与数据库中的表进行交互,每个数据库对应一个Model模板。laravel并没有定义models目录,一般可以在app目录下新建一个models文件夹存放模板文件。例如定义一个Student模板并指定表名与主键:

  1. namespace App\Models;
  2. use Illuminate\Database\Eloquent\Model;
  3. class Student extends Model
  4. {
  5. protected $table='student';
  6. protected $primaryKey='id';
  7. }

在controller中通过Student模板查询所有:

  1. namespace App\Http\Controllers;
  2. use App\Models\Student;
  3. class Login
  4. {
  5. public static function showDB(){
  6. $table=Student::all();
  7. dd($table);
  8. }
  9. }

希望本文所述对大家基于Laravel框架的PHP程序设计有所帮助。

原文链接:https://blog.csdn.net/theVicTory/article/details/80216978