laravel 前后台路由分离

在laravel中创建文件放置前台和后台控制器

找到app/providers/RouteServiceProvider.PHP文件

在内配置

例:

  1. <?php  
  2.   
  3. namespace App\Providers;  
  4.   
  5. use Illuminate\Routing\Router;  
  6. use Illuminate\Foundation\Support\Providers\RouteServiceProvider as ServiceProvider;  
  7.   
  8. class RouteServiceProvider extends ServiceProvider  
  9. {  
  10.     /**  
  11.      * This namespace is applied to the controller routes in your routes file.  
  12.      *  
  13.      * In addition, it is set as the URL generator's root namespace.  
  14.      *  
  15.      * @var string  
  16.      */  
  17.     protected $namespace = 'App\Http\Controllers';  
  18.     protected $frontendNamespace;  
  19.     /**  
  20.      * Define your route model bindings, pattern filters, etc.  
  21.      *  
  22.      * @param  \Illuminate\Routing\Router  $router  
  23.      * @return void  
  24.      */  
  25.     public function boot(Router $router)  
  26.     {  
  27.         //  
  28.         $this->frontnamespace = 'App\Http\Controllers\Front';  
  29.         parent::boot($router);  
  30.     }  
  31.     /**  
  32.      * Define the routes for the application.  
  33.      *  
  34.      * @param  \Illuminate\Routing\Router  $router  
  35.      * @return void  
  36.      */  
  37.     public function map(Router $router)  
  38.     {  
  39.         //配置路由所在文件  
  40.         // $backendUrl = config('route.backend_url');  
  41.         // $frontendUrl = config('route.frontend_url');  
  42.         // $apiUrl = config('route.api_url');  
  43.                 //  
  44.                 $router->group(['namespace' => $this->namespace], function ($router) {  
  45.                     require app_path('Http/routes.php');  
  46.                 });  
  47.                 //前台  
  48.                 $router->group(['namespace' => $this->frontnamespace], function ($router)   
  49.                 {  
  50.                     // 'domain' => $backendUrl,  
  51.                     require app_path('Http/routes_front.php');  
  52.                 });  
  53.     }  
  54. }  




  1. <?php  
  2.   
  3. namespace App\Providers;  
  4.   
  5. use Illuminate\Routing\Router;  
  6. use Illuminate\Foundation\Support\Providers\RouteServiceProvider as ServiceProvider;  
  7.   
  8. class RouteServiceProvider extends ServiceProvider  
  9. {  
  10.     /**  
  11.      * This namespace is applied to the controller routes in your routes file.  
  12.      *  
  13.      * In addition, it is set as the URL generator's root namespace.  
  14.      *  
  15.      * @var string  
  16.      */  
  17.     protected $namespace = 'App\Http\Controllers';  
  18.     protected $backendNamespace;  
  19.     protected $frontendNamespace;  
  20.     protected $apiNamespace;  
  21.     protected $currentDomain;  
  22.   
  23.     /**  
  24.      * Define your route model bindings, pattern filters, etc.  
  25.      *  
  26.      * @param  \Illuminate\Routing\Router $router  
  27.      * @return void  
  28.      */  
  29.     public function boot(Router $router)  
  30.     {  
  31.         //  
  32.         $this->backendNamespace = 'App\Http\Controllers\Backend';  
  33.         $this->frontendNamespace = 'App\Http\Controllers\Frontend';  
  34.         $this->apiNamespace = 'App\Http\Controllers\API';  
  35. //        $this->currentDomain = $this->app->request->server->get('HTTP_HOST');  
  36.         $this->currentDomain = isset($_SERVER['HTTP_HOST']) ? $_SERVER['HTTP_HOST'] : "";  
  37.   
  38.         parent::boot($router);  
  39.     }  
  40.   
  41.     /**  
  42.      * Define the routes for the application.  
  43.      *  
  44.      * @param  \Illuminate\Routing\Router $router  
  45.      * @return void  
  46.      */  
  47.     public function map(Router $router)  
  48.     {  
  49. //        $router->group(['namespace' => $this->namespace], function ($router) {  
  50. //            require app_path('Http/routes.php');  
  51. //        });  
  52.   
  53.         $backendUrl = config('route.backend_url');  
  54.         $frontendUrl = config('route.frontend_url');  
  55.         $apiUrl = config('route.api_url');  
  56.   
  57.         switch ($this->currentDomain) {  
  58.             case $apiUrl:  
  59.                 // API路由  
  60.                 $router->group([  
  61.                     'domain' => $apiUrl,  
  62.                     'namespace' => $this->apiNamespace],  
  63.                     function ($router) {  
  64.                         require app_path('Http/routes-api.php');  
  65.                     }  
  66.                 );  
  67.   
  68.                 break;  
  69.             case $backendUrl:  
  70.                 // 后端路由  
  71.                 $router->group([  
  72.                     'domain' => $backendUrl,  
  73.                     'namespace' => $this->backendNamespace],  
  74.                     function ($router) {  
  75.                         require app_path('Http/routes-backend.php');  
  76.                     }  
  77.                 );  
  78.                 break;  
  79.             default:  
  80.                 // 前端路由  
  81.                 $router->group([  
  82.                     'domain' => $frontendUrl,  
  83.                     'namespace' => $this->frontendNamespace],  
  84.                     function ($router) {  
  85.                         require app_path('Http/routes-frontend.php');  
  86.                     }  
  87.                 );  
  88.   
  89.                 break;  
  90.         }  
  91.   
  92.     }  
  93. }  

完成后我们的路由也可以新建了  但要和上面的名称要一样

在路由中可以这样写(当然也可以自定义路由)例:


  1. Route::group(['middleware' => ['web']], function () {  
  2.   
  3.     Route::controller('/test', 'TestController');  
  4.     // 重置  
  5.     Route::get('user/password/reset/{token?}', [  
  6.         'as' => 'user.password.reset@token',  
  7.         'uses' => 'User\PasswordController@getReset'  
  8.     ]);  
  9. ]);  


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Laravel是一个流行的PHP Web开发框架,提供了一套简洁、优雅的语法和丰富的功能库,便于开发者构建高效、可维护的应用程序。对于后台开发来说,Laravel提供了一系列重要的特性和工具,使得开发过程更加快捷和高效。 首先,Laravel的MVC架构使得后台开发更加模块化和分层,便于代码的维护和扩展。通过Laravel的路由系统,开发者可以轻松地定义后台接口和路由,实现前后端分离,提高开发效率并降低系统的耦合度。 其次,Laravel提供了强大的数据库访问工具,包括Eloquent ORM和查询构建器,能够方便地操作数据库。开发者可以使用简洁的语法进行数据查询、插入、更新和删除操作,减少了繁琐的SQL语句编写,提高了开发效率。 此外,Laravel还提供了丰富的安全功能和中间件,保障后台系统的安全性。通过CSRF令牌和表单请求验证,可以防止恶意请求和跨站点脚本攻击。同时,Laravel提供了身份认证和授权的功能,方便实现用户角色管理和权限控制,保护后台系统中的敏感数据。 另外,Laravel还具备良好的社区支持和活跃的开发社区,有大量的扩展包和开源项目可供使用,可以快速集成常用的功能和模块,进一步提高后台开发的效率。 总之,Laravel 9作为后台开发的框架,提供了强大的功能和工具,帮助开发者快速构建高效、安全、可扩展的后台系统。无论是初学者还是有经验的开发者都可以通过学习和使用Laravel,快速上手并提高开发效率。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值