laravel扩展包开发步骤总结

1. 创建包
1
php artisan workbench vendor/package --resources
注:  vendor:开发商名   package:包名
2.修改下包里composer.json中的authors
1
2
3
4
5
6
"authors": [
    {
        "name""cicl",
        "email""test@126.com"
    }
]
3. 为创建的包注册ServiceProvider
在项目根目录执行 php artisan dump-autoload
在app/config/app.php文件里的provides数组中添加该包,将Vendor\Package\PackageServiceProvider添加到providers数组.
为了方便我们的使用,我们在app/config/app.php的aliases中增加一个别名: 'Package' => 'Vendor\Package\Facades\Notification',
启动开发服务器: php artisan serve ,如果成功启动,如显示:Laravel development server started on http://localhost:8000,则扩展包的基础搭建就成功了。
基本的扩展包结构:
        /src/Vendor/PackagePackageServiceProvider.php/config/lang/migrations/views/tests/public

4、为本包添加独立路由文件,只需在PackageServiceProvider中的boot函数中添加如下代码,并在包的根目录创建routes.php文件

1
2
3
4
public function boot(){   
    $this->package('vendor/package');   
    include __DIR__.'/../../routes.php';
}

路由文件如下所示: 

1
Route::get('test',  function(){    return "this is test";});
现在,在浏览器里输入地址如:http://localhost:8000/test,就会输出“this is test”。
5.接下来尝试使用Controller
新建路由如下: 
1
Route::get('testtwo',array('as' => 'testtwo','uses' => 'Vendor\Package\Controllers\PackageController@getTest'));
6、在controllers 中新建RegistrationController.php文件,代码如下:
1
2
3
4
5
6
7
8
9
10
<?php
namespace Ccl\Lenon\Controllers;
use Illuminate\Routing\Controller;
use Illuminate\Support\Facades\View;
Class LenonController extends Controller {
     public function getTest() {
         return "控制器测试";
     }
}
尝试打开页面,提示找不到控制器,Laravel默认是不自动查找任何目录的,需要开发者自己指定文件的存放目录,不过它也给出了建议路径,比如在使用artisan workbench的时候是不是生成了src/controllers目录呢,Ok,我们添加自动加载路径即可。
7、在包的根目录的composer.json的autoload下classmap字段增加"src/controllers",如:
1
2
3
4
"classmap": [
       "src/migrations",
       "src/controllers"
],
并在项目根目录运行 php artisan dump-autoload,刷新页面就好了。

8、接下来我们要使用views文件!按照我们理解我们只需要修改controller中代码,如下: 

1
2
3
4
public function getRegister()   
    return View::make('test');
}
在包src/views/ 下创建 test.blade.php文件,并在文件中写入相关页面代码,例: <h1>这是测试视图的文件</h1>
刷新页面,发现并没有成功,在Laravel中,是不会自动索引包中的视图文件的,所以我们还需要做一点点工作!

9、在载入视图的时候指定他去包中寻找视图文件即可,修改controller中代码如下:

1
2
3
4
public function getRegister()   
{
    return View::make('package::test');   
}

再次刷新页面,我们期待的页面出现了,

public迁移     
1
php artisan asset:publish --bench="vendor/package"
创建数据库迁移
1
php artisan migrate:make create_users_table --bench="vendor/package"

执行数据库迁移

1
php artisan migrate --bench="vendor/package"

转载于:https://www.cnblogs.com/bainiu/p/7681176.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/253122.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

洛谷 P1340 兽径管理

题目描述 约翰农场的牛群希望能够在 N 个(1<N<200) 草地之间任意移动。草地的编号由 1到 N。草地之间有树林隔开。牛群希望能够选择草地间的路径&#xff0c;使牛群能够从任一 片草地移动到任一片其它草地。 牛群可在路径上双向通行。 牛群并不能创造路径&#xff0c;但是…

功放关键规格参数检查

编号规格备注1功放类型(开环/闭环)影响电性能指标2工作电压(V)影响IC的稳定性3最大耐压(V)影响IC的稳定性4最小负载(ohm)稳定性&#xff0c;过流&#xff0c;输出功率&#xff0c;散热5输出功率过流&#xff0c;输出功率&#xff0c;散热6输出方式(SE/BTL/PBTL)输出功率&#x…

不踩雷不将就 京东智能产品30天无忧退

剁手节已经来临&#xff0c;铺天盖地的促销信息让人应接不暇&#xff0c;恰好又是换季&#xff0c;确实需要买买买一波了。各种满减活动让人眼花缭乱&#xff0c;这波堪称全年最大力度的促销活动&#xff0c;令人是又喜又怕。倘若之前踩过雷的朋友&#xff0c;必然现在会谨慎许…

Linux进程间通信——使用信号量

//转自http://blog.csdn.net/ljianhui/article/details/10243617 这篇文章将讲述别一种进程间通信的机制——信号量。注意请不要把它与之前所说的信号混淆起来&#xff0c;信号与信号量是不同的两种事物。有关信号的更多内容&#xff0c;可以阅读我的另一篇文章&#xff1a;L…

麦克风阵列音频检查方法和标准

为确保产品能够符合算法要求&#xff0c;务必提前做好相关设计&#xff0c;尽量确保各项指标满足如下标准。 音频评测工作&#xff0c;主要集中在研发设计阶段&#xff1b;针对产品形态的不同&#xff0c;测试可分为裸板测试和整机测 试&#xff0c;下表为不同阶段需要测试的…

Linux下git的使用——将已有项目放到github上

本地已经有一个项目了&#xff0c;需要将该项目放到github上&#xff0c;怎么操作&#xff1f; 步骤&#xff1a; 本地安装git&#xff0c;有github账号是前提。 &#xff08;1&#xff09;先在github创建一个空的仓库&#xff0c;并复制链接地址。使用https&#xff0c;以.git…

SVG格式图片转成HTML中SVG的Path路径

AI图标制作完成之后&#xff0c;保存的svg文件包含许多AI的信息&#xff0c;如果要在HTML中使用&#xff0c;我们需要在svg文件中提取/修改信息&#xff0c;重新保存。 1、在AI中已经完成图标&#xff0c;要保存SVG文件&#xff0c;点击“文件(File)”-“另存为(Save As)”&…

11-5 笔记

函数&#xff1a; 函数在调用的时候&#xff0c;会形成一个私有作用域&#xff0c;内部的变量不会被外面访问&#xff0c;这种保护机制叫闭包。这就意味着函数调用完毕&#xff0c;这个函数形成的栈内存会被销毁。 函数归属谁跟它在哪调用没有关系&#xff0c;跟在哪定义有关。…

linux下socket连接下的心跳机制

1&#xff0c;在长连接下&#xff0c;有可能很长一段时间都没有数据往来。 理论上说&#xff0c;这个连接是一直保持连接的&#xff0c;但是实际情况中&#xff0c;如果中间节点出现什么故障是难以知道的。 有的节点&#xff08;防火墙&#xff09;会自动把一定时间之内没有数…

大力智能台灯与飞利浦台灯 智能调光功能体验

目前市面上绝大部分智能台灯几乎都宣称有自动调光功能&#xff0c;即台灯随环境光变化自动调节LED光的亮度&#xff0c;或者台灯在固定环境光下&#xff0c;一旦开启了自动调光模式LED灯将自动调光至一个最适合读写作业的亮度&#xff1b; 下面对比体验了大力台灯T6 和 飞利浦…

php-验证码

<html><body> <h2>用户注册&#xff1a;</h2> <br> <form action"a.php" method"post"> 账 号&#xff1a;<input type"text" name"zh" id""> <br> 密 码&#xff1a;&l…

Linux内核Socket参数调优

可调优的内核变量存在两种主要接口&#xff1a;sysctl命令和/proc文件系统&#xff0c;proc中与进程无关的所有信息都被移植到sysfs中。IPV4协议栈的sysctl参数主要是sysctl.net.core、sysctl.net.ipv4&#xff0c;对应的/proc文件系统是/proc/sys/net/ipv4和/proc/sys/net/cor…

Mango 的组织重构

为了提高敏捷性&#xff0c;企业应将自己划分为一些负责业务战略计划价值中心&#xff0c;承担端到端的责任&#xff0c;并完全获取有关客户需求的信息。企业需要为员工营造可交叉协作的空间&#xff0c;可以学习和使用自组织的改进圈、实践社群&#xff08;CoP&#xff0c;Com…

vue.js单页面应用实例

一&#xff1a;npm的安装由于新版的node.js已经集成了npm的环境&#xff0c;所以只需去官网下载node.js并安装&#xff0c;安装完成后使用cmd检测是否成功。测试node的版本号&#xff1a;node -v测试npm的版本号&#xff1a;npm -v以上提示代表安装成功二&#xff1a;vue.js环境…

大屏拼接控制器的发展历程与现状分析

【中国数字视听网讯】在大屏幕拼接系统中&#xff0c;我们很容易将焦点聚集在拼接单元上&#xff0c;殊不知幕后还有一个英雄在默默的支持&#xff0c;这个英雄就是是拼接控制器。拼接控制器的优劣直接决定着整个大屏幕显示系统效果的好与坏&#xff0c;也决定了整套显示系统的…

AA级与AAA级台灯 重要指标对比

读写作业台灯&#xff0c;按照国家标准&#xff08;GB/T 9473-2017 读写作业台灯性能要求 &#xff09;台灯只有两个等级 即为A级和AA级&#xff1a; 但是大家在各个购物网站挑选台灯尤其是挑选孩子学习用的读写台灯时&#xff0c;会发现很多厂家宣称台 灯为AAA级&#xff0c…

windbg调试相关命令

windbg查找函数:x exe!main*条件断点打印字符&#xff1a;bp 7199a2b0 ".printf \"message:%ma\", poi(esp8);.echo;g"//搜索内存:s -a 0000000000780000 L8000000 "This is a test2"!address,可以查看进程的堆布局&#xff0c;堆属性。!addre…

零基础学python,看完这篇文章,你的python基础就差不多了!干货【1】

2019独角兽企业重金招聘Python工程师标准>>> Python基础语法和面向对象&#xff08;下一篇分享面向对象&#xff09; Python基础语法 1. 认识Python 1.1 Python 简介 Python 的创始人为吉多范罗苏姆&#xff08;Guido van Rossum&#xff09;。 Python 的设计目标&a…

消费类电子认证测试资料清单

消费类电子上市前必须取得相关认证&#xff0c;其中最常见的有3C、SRRC和CTA等强制性认证&#xff0c;还有类似TUV和Rohs等自愿性认证&#xff0c;现将常见认证测试资料清单小结如下&#xff1a; CCC测试认证&#xff1a; 测试项&#xff1a;EMC、安规和随机等。 SRRC核准&am…

SVG 相关整理

1. 中文参考手册&#xff1a; http://www.runoob.com/svg/svg-reference.html SVG HTML5 资源教程 http://www.html5tricks.com/tag/svg/ 2.SVG 入门到精通 http://www.w3cplus.com/blog/tags/411.html 3.SVG开发包整理 http://www.oschina.net/project/tag/420/svg http://www…