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 函数返回项目根目录的完整路径 。


 


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


 




 


 


 


 


 




  • 2019-12-27 08:40:55

    align-self和align-items的区别

    align-items在伸缩容器上使用它,伸缩容器内部所有的元素都一致地受制于align-items的值。 但是有些时候,我们希望伸缩容器内部某个元素在侧轴上的排列方式有所差异。此时就不能使用 align-items,因为align-items作用于整体。我们希望作用于部分。这就是align-self的发挥场地。

  • 2019-12-29 15:01:37

    修改laravel分页的样式

    首先获取到数据,paginate方法 能够自动判定当前页面正确的数量限制和偏移数。默认情况下,当前页数由HTTP 请求所带的 ?page 参数来决定。当然,该值由 Laravel 自动检测,并自动插入由分页器生成的链接。

  • 2019-12-29 15:05:57

    php 数组分页 array_slice()函数用法

    今天用到一个函数,非常好用,分享给大家 array_slice() -从数组中取出一段 也就是说用这个函数可以和sql语句一样实现分页,原理是将查询出的数组,取出从指定下标开始到指定长度的数组

  • 2019-12-30 10:17:21

    router-link传递参数,query

    在vue-router中,有两大对象被挂载到了实例this; $route(只读、具备信息的对象); $router(具备功能的函数) 查询字符串: 去哪里 ? <router-link :to="{name:'detail',query:{id:1}}"> xxx </router-link>

  • 2019-12-30 16:48:41

    vue provide/inject详解和用法

    父子组件交互方式多种,props、vuex、 、 emit、localStorage还有就是这个provide/inject了。它适合层级比较深的组件,比如子,子孙,子孙后代的组件有好几个用到父组件的某个属性,就可以用到这个provide/inject,它可以避免写大量繁琐的传值代码 我这里为什么要使用它? 我一个知识库详情父组件中包含了大量的子组件,每个子组件都需要父组件的知识库ID,这时候我不想写大量props,就用到provide/inject进行传值了