首先要看一下Laravel官方文档,这是最新4.2的文档,假设想看中文的话点击此处,基本一样。这个github上的库setup-laravel4-package,也是一步一步介绍怎样创建一个包。并关联相关资源。
这里以创建一个account包为例:
1、假设是首次使用php artisan workbench命令,须要配置app/config/workbench.php中的name和email,在生成包的时候会使用这些信息
2、在项目根文件夹使用。以下的命令生成最初始的包文件夹结构,当中--resources作用是生成相关的view、config和migrations等资源文件夹
php artisan workbench fstos/account --resources
包的根文件夹在workbench/fstos/account文件夹,其结构大概例如以下
/src /Fstos /Account AccountServiceProvider.php /config /lang /migrations /views /tests /public
3、将包的'Fstos\Account\AccountServiceProvider'增加到app/config/app.php中"providers"数组中,这样这个包会被载入到应用程序中
4、为本包加入独立路由文件,仅仅需在AccountServiceProvider中的boot函数中加入例如以下代码,并在包的根文件夹创建routes.php文件
public function boot() { $this->package('fstos/account'); include __DIR__.'/../../routes.php'; }
路由文件例如以下所看到的:
Route::get('account/register', function(){ return "account register router"; });
5、OK,如今在你的浏览器測试吧,出现了"account register router",接下来我们尝试使用controller
http://localhost/laravel/friends/public/account/register
6、改动routes例如以下所看到的:
Route::get('account/register', array('as' => 'account.register.get', 'uses' => 'Fstos\Account\RegistrationController@getRegister') );
7、在controllers 中新建RegistrationController.php文件,代码例如以下:
php namespace Fstos \Account ; use Illuminate \Routing \Controller as Controller ; use Illuminate \Support \Facades \View as View ; use Illuminate \Support \Facades \Config as Config ; class RegistrationController extends Controller { /** * Display the registration form. * * @return \Illuminate\Http\Response */ public function getRegister ( ) { return "yes,use controller with route in packages!" ; } /** * 暂用不到 */ protected function setupLayout ( ) { if ( ! is_null ( $this -> layout ) ) { $this -> layout = View : : make ( $this -> layout ) ; } } }
尝试刷新页面。啊哈,是不是报错了,找不到"Fstos\Account\RegistrationController",Laravel默认是不自己主动查找不论什么文件夹的。须要开发人员自己指定文件的存放文件夹,只是它也给出了建议路径,比方在使用artisan workbench的时候是不是生成了src/controllers文件夹呢。Ok,我们加入自己主动载入路径就可以
8、在包的根文件夹的composer.json的autoload下classmap字段添加"src/controllers"。并在项目根文件夹执行 php artisan dump-autoload,OKOK,我们刷新页面。哈哈出现啦
9、接下来我们要使用views文件!嗯嗯。依照我们理解我们仅仅须要改动controller中代码。是滴,例如以下:
public function getRegister() { return View::make('account.register'); // return "yes,use controller with route in packages!"; }
非常显然他訪问的是app/views/account/register.blade.php视图模板。我们创建这个文件并写入例如以下内容:
>
we are shown in views!
>
继续刷新页面吧!
哈哈哈,非常幸运,是这个规则~,只是我们创建一个包并不期望把包中视图放在app/views文件夹吧,是滴,必须得集成到包中。记得src下也有个views呢,好滴好滴。我们把文件放到包src/views/account/register.blade.php中。内容例如以下:
>
we are shown in views under workbench!
>
刷新页面吧。我擦。还是原来的页面。是不是Laravel优先加载app/views下的模板文件呢,我们删除app/views/account/。再次刷新页面。又失望了,再次出现了not found页面,在Laravel中。是不会自己主动索引包中的视图文件的,所以我们还须要做一点点工作!
10、在加载视图的时候指定他去包中寻找视图文件就可以。改动controller中代码例如以下:
public function getRegister() { return View::make('account::account.register'); // return "yes,use controller with route in packages!"; }
再次刷新页面,我们期待的页面出现了。我们看到controller中使用到了account这个命令空间(详细含义能够看下laravel官方文档),那么这个空间是在哪里指定的呢?
11、我们看下AccountServiceProvider.php文件里boot函数中$this->package('fstos/account');这一行代码,事实上指定了这个包的命令空间和其绑定的文件夹,神马,看不粗来,是滴,这个函数还有第二个(空间名)和第三个(文件夹)參数。只是这个两个參数都有默认值,命名空间的默认值就是account,文件夹默认值就是包根文件夹下的src文件夹,事实上就相当于例如以下写法:
$this->package('fstos/account',"account",__DIR__.'/../../');
Ok。你能够去尝试~
小插曲,从第7条往后写了两遍。第一遍保存的时候登录时间过长,保存丢失了,我勒个去,心中各种骂,想想数据备份是多么的重要~
这是我第一公布的位置:http://www.fstos.com/index.php/2014-05-26-09-01-36/81-laravel-packages