1. 创建包
php artisan workbench vendor/package --resources
注: vendor:开发商名 package:包名
2.修改下包里composer.json中的authors
"authors": [
{
"name": "cicl",
"email": "[email protected]"
}
]
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
/Package
PackageServiceProvider.php
/config
/lang
/migrations
/views
/tests
/public
4、为本包添加独立路由文件,只需在PackageServiceProvider中的boot函数中添加如下代码,并在包的根目录创建routes.php文件
public function boot(){
$this->package('vendor/package');
include __DIR__.'/../../routes.php';
}
路由文件如下所示:
Route::get('test', function(){ return "this is test";});
5.接下来尝试使用Controller
新建路由如下:
Route::get('testtwo',array('as' => 'testtwo','uses' => 'Vendor\Package\Controllers\PackageController@getTest'));
6、在controllers 中新建RegistrationController.php文件,代码如下:
尝试打开页面,提示找不到控制器,Laravel默认是不自动查找任何目录的,需要开发者自己指定文件的存放目录,不过它也给出了建议路径,比如在使用artisan workbench的时候是不是生成了src/controllers目录呢,Ok,我们添加自动加载路径即可。
7、在包的根目录的composer.json的autoload下classmap字段增加"src/controllers",
如:
"classmap": [
"src/migrations",
"src/controllers"
],
并在项目根目录运行 php artisan dump-autoload,刷新页面就好了。
8、接下来我们要使用views文件!按照我们理解我们只需要修改controller中代码,如下:
public function getRegister()
{
return View::make('test');
}
这是测试视图的文件
刷新页面,发现并没有成功,在Laravel中,是不会自动索引包中的视图文件的,所以我们还需要做一点点工作!
9、在载入视图的时候指定他去包中寻找视图文件即可,修改controller中代码如下:
public function getRegister()
{
return View::make('package::test');
}
再次刷新页面,我们期待的页面出现了,
public迁移
php artisan asset:publish --bench="vendor/package"
创建数据库迁移
php artisan migrate:make create_users_table --bench="vendor/package"
执行数据库迁移
php artisan migrate --bench="vendor/package"