laravel多路由配置,也可以做根据域名都动态路由

2019-12-01 08:04:30

在用laravel 框架开发大型应用的时候,由于 laravel 默认是只有一个路由文件,如果把项目所有模块的路由放在一个路由文件下,那么该路由文件就显得很臃肿,以至于后期难以维护,解决方案是根据不同模块配置不同路由文件。


首先说下这里的环境:wamp + composer + laravel5.5 。


wamp 环境子行百度下载安装即可,记得最后要添加到 系统 path。


下面简单说下composer 安装,我这里采用 composer.exe 安装 ,下载地址:https://getcomposer.org/download/ 。然后下一步安装,最后添加到系统path。


 




 


上面步骤完了后,进入到composer 安装lalravel 的过程。


至于laravel 安装可以参考:https://blog.csdn.net/zhang_referee/article/details/82915367。


 


配置:composer 中国镜像。


下面是采用全局配置:


composer config -g repo.packagist composer https://packagist.phpcomposer.com


更多配置方式可参考:https://pkg.phpcomposer.com/。


 




下面是已下载的laravel 项目代码。




 


添加虚拟站点,测试能跑通


 




 


 




运行结果:




 


接下来配置多文件路由:


  首先需要创建一个目标路由文件:文件名和路径无所谓,但为了规范起见,个人建议放在routes 文件夹下。我这里创建market这个路由。




 


然后打开 : app/Providers/RouteServiceProvider.php ,找到 mapApiRoutes() 方法,加入类似以下的代码:


    //新建路由

         Route::group([

            'middleware' => 'web',

            'namespace'  => $this->namespace,

            'prefix'     => 'market',

        ], function ($router) {

            require base_path('routes/market.php');

        });

 


类似如下:


 




 


其中,


  middware 表示中间件,这里填写了默认的web ,如果有需要替换之即可。


  namespace 这里默认即可。


  prefix 是指路由前缀,这个是直接体现在url 上的。


  require base_path('routes/market.php')  是指 引入项目根目录完整路劲routes文件夹下的market.php 这个文件。base_path 函数返回项目根目录的完整路径 。


 


完了后,保存即可,然后到浏览器访问测试:


 




 


 


 


 


 




  • 2020-04-08 22:46:28

    Element的操作方法

    Element 是一个通用性非常强的基类,所有 Document 对象下的对象都继承自它。这个接口描述了所有相同种类的元素所普遍具有的方法和属性。一些接口继承自 Element 并且增加了一些额外功能的接口描述了具体的行为。例如, HTMLElement 接口是所有 HTML 元素的基本接口,而 SVGElement 接口是所有 SVG 元素的基础。大多数功能是在这个类的更深层级(hierarchy)的接口中被进一步制定的。

  • 2020-04-12 17:42:43

    Node.js设置CORS跨域请求中多域名白名单的方法

    在Node.js中,res的响应头Header中的 Access-Control-Allow-Origin 属性不能匹配除 (*) 以外的正则表达式的,域名之间不能也用逗号分隔。也就是说, Access-Control-Allow-Origin 的属性值只允许设置为单个确定域名字符串或者 (*)。

  • 2020-04-14 09:40:59

    CSS3实现文字描边的2种方法

    首先想到去看CSS3有没有什么属性可以实现,后来被我找到了text-stroke     该属性是一个复合属性,可以设置文字宽度和文字描边颜色      该属性使用很简单:text-stroke:1px #f00;(1px是文字宽度,#ff是文字描边颜色)

  • 2020-04-14 09:42:47

    用 TypeScript 编写 npm 模块

    自从开始使用 Node.js 已经一年多,写的代码越多,越是觉得自己提高的越慢。想来应该有没有将单一功能的代码封装在一个独立模块,而导致代码稍微多一点就维护困难的原因。

  • 2020-04-14 09:46:25

    TypeScript 入门教程

    TypeScript 是 JavaScript 的超集,扩展了 JavaScript 的语法,因此现有的 JavaScript 代码可与 TypeScript 一起工作无需任何修改,TypeScript 通过类型注解提供编译时的静态类型检查。 TypeScript 可处理已有的 JavaScript 代码,并只对其中的 TypeScript 代码进行编译。

  • 2020-04-14 09:51:03

    package.json 字段说明

    package.json 有很多字段,也有很多官方字段,我们需要知道他们的具体是做什么的才能很好的运用