基于 Laravel Route 的 ThinkSNS+ Component
这里是传送门:
《ThinkSNS+ 基于 Laravel master 分支,从 1 到 0,再到 0.1【ThinkSNS+研发日记系列一】》
《基于 Laravel 开发 ThinkSNS+ 中前端的抉择(webpack/Vue)踩坑日记【ThinkSNS+研发日记系列二】》
在前面,我介绍了拓展类型,分别有 plus-compnent 和 plus-plugin 两个,这里重点讲以下如何实现 plus-component 的。
plus-component 是什么
就如同名字一样,plus 代表的是 ThinlSNS+ 程序,用 - 分割 后面的 component 就是「包」或者我们理解成应用。在这里的「应用」指的是通过实现 API 或者 web 的功能。所以产生了这个类型。
但是 plus-component 不只是应用,也可以是简单的功能拓展,例如medz/plus-storage-quniu就是拓展的七牛云储存。
composer 插件的建立
既然涉及到路由,最开始的想法,其实是 /routes 目录下生成文件,包的路由文件复制到这里来。后来,发现了问题不足。
最后想到,plus-component 的实现,不一定是基于路由的应用,也有可能是简单的拓展。我们看下中间插件的接口类:
<?php namespace Zhiyi\Component\Installer\PlusInstallPlugin; use Closure; use Illuminate\Console\Command; use Illuminate\Console\OutputStyle; interface InstallerInterface{public function setCommand(Command $command, OutputStyle $output);/*** Get the component info.** @return void|\Zhiyi\Component\Installer\PlusInstallPlugin\ComponentInfoInterface** @author Seven Du <shiweidu@outlook.com>* @homepage http://medz.cn*/public function getComponentInfo();/*** 应用安装.** @param Closure $next** @author Seven Du <shiweidu@outlook.com>* @homepage http://medz.cn*/public function install(Closure $next);/*** 应用升级.** @param Closure $next** @author Seven Du <shiweidu@outlook.com>* @homepage http://medz.cn*/public function update(Closure $next);/*** 应用卸载.** @param Closure $next** @author Seven Du <shiweidu@outlook.com>* @homepage http://medz.cn*/public function uninstall(Closure $next);/*** 静态资源.** @return string 静态资源目录** @author Seven Du <shiweidu@outlook.com>* @homepage http://medz.cn*/public function resource();/*** 路由配置.** @return string 路由配置文件列表** @author Seven Du <shiweidu@outlook.com>* @homepage http://medz.cn*/public function router();}
其中 router 成了非必需项。
转而,拥有了三个 hook 方法 install、update 和 uninstall 方法,这三个分别对应的是安装,升级,卸载。
而设计中,plus-component 中间插件会在 Laravel 的 /config/component.php 中增加如下配置:
'medz/plus-component-example' => array ('installed' => false,'installer' => 'Medz\\Component\\ZhiyiPlus\\PlusComponentExample\\Installer\\Installer',),
中间插件的 composer.json 配置
其实很简单,看到上面添加到 /config/component.php 的代码了, installer 项哪里来的呢?看下包的配置:
{"name": "medz/plus-component-example","type": "plus-component","require": {"zhiyicx/plus-install-plugin": "^1.1"},"autoload": {"psr-4": {"Medz\\Component\\ZhiyiPlus\\PlusComponentExample\\": "src/"}},"extra": {"installer-class": "Medz\\Component\\ZhiyiPlus\\PlusComponentExample\\Installer\\Installer"} }
就是最后的 extra.installer-class 配置的,这里是完整的 class name,这样,在 composer 插件执行的时候读取这个额外的配置,并写入到 Laravel 的配置文件中。
install/update/uninstall
在 ThinkSNS+ 中有 php artisan component [install|update|unstall] vendor/name 这样一个命令,主要是用作 包的安装,升级,卸载。
实际运行如下:
php artisan component install medz/plus-component-example
通过这样的方式安装包,而这个命令会读取 /config/component.php 的配置,从而得到 installer ,这样,在运行不同的参数的时候后,调用 install,uodate,uninstall 等 需求 hook 达到目的。
router
在最上面的接口类中你也看到了,有一个 router 方法,这个方法返回类型有两个 void|string,所以, void 代表没有路由,string 就表示包路由文件的绝对地址。
在 php artisan component 命令执行的时候,对应的添加 /config/component_routes.php 里面的配置。
在 /app/Providers/RouteServiceProvider.php 中如下:
protected function mapVendorRoutes(){$files = config('component_routes', []);foreach ($files as $file) {include_once $file;}}
可能你会误会,为什么只是 include 进来呢?是的,这里的代码其实是参照 Route::group 来的,而在包里面的文件,可以正常的使用 Route::* 进行路由配置。
resource
既然可以基于路由,那就必然会存在静态资源的问题,在接口类中也有这样的规定:
/*** 静态资源.** @return string 静态资源目录** @author Seven Du <shiweidu@outlook.com>* @homepage http://medz.cn*/public function resource();
这里返回在包中静态资源存储的目录,执行安装或者升级命令的时候复制到 /public/vendor/name 目录下来达到静态资源发布的功能。
更高级的封装
这里其实是只模式封装,在 ThinkSNS+ 的 php artisan component 其实还有一个 --link 参数,做什么用的?其实不难理解,就是吧静态资源由原来的复制变成创建软链。这在开发过程中很有用。
下期预告:下一篇文章,会简单的讲以下 ThinkSNS+ 自封装的命令实现。
开源代码仓库:
GitHub:https://github.com/zhiyicx/thinksns-plus(点击星,每日关注开发动态。)
转载于:https://www.cnblogs.com/thinkSNS/p/thinksns.html
基于 Laravel Route 的 ThinkSNS+ Component相关推荐
- 基于 Laravel、Vue.js开发的全新社交系统----ThinkSNS+
2019独角兽企业重金招聘Python工程师标准>>> ThinkSNS(简称TS)始于2008年,一款全平台综合性社交系统,为国内外大中小企业和创业者提供社会化软件研发及技术解决方 ...
- vue php聊天室,实时聊天室:基于Laravel+Pusher+Vue通过事件广播实现
之前有说过要整理出一篇事件广播的教程,今天终于有时间把这篇文章给写了出来,本次的教程是基于Laravel+Pusher+Vue,以事件广播作为核心技术,让你可以快速搭建起一个实时聊天室应用,话不多说, ...
- pusher 创建新应用_基于 Laravel + Pusher + Vue 通过事件广播构建实时聊天室应用
基于 Laravel + Pusher + Vue 通过事件广播构建实时聊天室应用 由 学院君 创建于2年前, 最后更新于 3个月前 版本号 #3 前言:学院君之前有说过要整理出一篇事件广播手把手教程 ...
- larvel 中的api.php_Laravel API 系列教程(一): 基于 Laravel 5.5 构建 测试 RESTful API...
Laravel API 系列教程(一): 基于 Laravel 5.5 构建 & 测试 RESTful API 由 学院君 创建于2年前, 最后更新于 9个月前 版本号 #3 171702 v ...
- Scaffold php,scaffold: 基于 Laravel 的后台脚手架 Scaffold for laravel
zgldh/Scaffold 基于 Laravel 5.5, Vue 2, ElementUI 2, vueAdmin-template 制作的后台脚手架. 预制功能: 用户,角色,权限体系 文件上传 ...
- 基于 Laravel 5 构建的、支持模块化和多语言的 CMS —— AsgardCMS
1.简介 AsgardCMS 是基于 Laravel 5 构建的.支持模块化和多语言的CMS. 官网:https://asgardcms.com/ Github:https://github.com/ ...
- laravel 除了主页 都是404 webconfig_基于Laravel,开箱即用,这个PHP后台管理系统好看又省心...
提到 PHP 的后台管理系统,大家可能首先会想到的是 FastAdmin 或者 ThinkAdmin 这种老牌的开源项目,它们都是 Gitee 的 GVP 项目,很受 PHP 开发者们的欢迎.今天 G ...
- php校园开源,基于 Laravel 5.5 开发的开源校园管理系统 —— Unifiedtransform
基于 Laravel 5.5 开发的开源校园管理系统 -- Unifiedtransform 由 学院君 创建于1年前, 最后更新于 1年前 版本号 #1 9405 views 3 likes 1 c ...
- derhams to php,基于laravel belongsTo使用详解
前提:订单表(order)和用户表(user) 表结构: order CREATE TABLE `order` ( `id` char(16) COLLATE utf8mb4_unicode_ci N ...
最新文章
- pythreejs is needed for plotting with pythreejs backend
- 16款优秀的Vue UI组件库推荐
- 免费指纹浏览器破解方法之开源代码
- HotSpot 自动内存管理笔记与实战
- 10.14 ssh:安全地远程登录主机
- Object类有哪些公用方法?
- windows7黑屏修复_如何在Windows 10更新后修复黑屏
- MySQL优化之——触发器
- 实验五:编写、调试具有多个段的程序
- gcc/g++ 静态动态库 混链接.
- Spring的单例模式底层实现
- 【Java系列】八大排序算法
- RGB HSV CMYK LAB颜色空间
- 撤销 git rebase
- 构造虚假栈帧 | 花式栈溢出
- 23考研| 你来了,准硕士!!!
- MATLAB矩阵行列
- IE浏览器故障及其解决方法
- 公网异地远程访问家中/公司的群晖NAS
- Flink1.11 读取kafka数据写入hive,未完待续
热门文章
- 最大信息熵增益_机器学习笔记(三)——搞懂决策树必备的信息增益
- 工业机器人电柜布线_协作并联,重新注解并联机器人
- 获取当前经纬度php腾讯地图,PHP腾讯地图经纬度转百度地图经纬度
- php鼠标经过显示文本,CSS_HTML和CSS做网页实例教程:鼠标滑过文字改变,关于HTML+CSS的实例效果很多, - phpStudy...
- sudoers 用户权限配置_Linux 用户注意!针对Sudo 被曝漏洞,厂商已发布最新版本...
- java线程代码实现_Java 多线程代码实现讲解
- 【信息抽取】如何使用BERT进行关系抽取
- 【tensorflow速成】Tensorflow图像分类从模型自定义到测试
- 全球及中国生物技术产业创新发展模式及十四五应用方向研究报告2021-2027年
- 全球及中国陶瓷脐轮行业投资份额及需求前景调研报告2021-2027年版