require 文件很麻烦,使用PSR-4搭配composer一次加载,终生受用。感受相似java中的import了,本身先记录一下最近理解的。php
用composer管理本身的包吧html
安装composerjava
这个很少赘述linux
英文版教程git
中文版教程github
PSR-4-autoloaderjson
|-projectwindows
|-src浏览器
|-View.phpapp
|-app
|-Tools.php
|-composer.json
上面路径的View.php在project/src/View.php 中,其余同理,View 和 Tools 只是为了作演示用的。
打开建立的composer.json文件输入,这里拿monolog作例子。
{
"require": {
"monolog/monolog": "1.2.*"
}
}
在目录所在的命令行中输入
#linux全局安装下使用该命令 composer install #windows下使用参考前面的composer教程 composer.phar install
加载完毕以后你的目录应该是这样的
|-project
|-src
|-View.php
|-app
|-Tools.php
|-vendor
|-composer/* composer目录下面的文件不在赘述
|-monolog/* 同理
|-autoload.php
|-composer.json
|-composer.lock
在project目录下建立一个index.php
#index.php <?php /** * Created by PhpStorm. * User: EasyChris<chris@afox.cc> * Date: 2017/1/22 * Time: 10:50 */ //引入autoload.php文件 require_once 'vendor/autoload.php'; //测试monlog $log = new MonologLogger('name'); $log->pushHandler(new MonologHandlerStreamHandler('app.log', MonologLogger::WARNING)); $log->addWarning('Foo'); echo 'success';
在浏览器里面访问该文件地址,一般应该是http://127.0.0.1/project/index.php
看到页面success
以后,而后再查看project文件夹下面是否是多了一个app.log文件。那么恭喜你成功使用了composer加载包,而且使用该加载的包输出了log日志。
编辑刚才的composer.json文件,添加autoload模块。
{ "require": { "monolog/monolog": "1.2.*" }, "autoload": { "psr-4": { "Acme": "src/", } } }
其中Acme:"src"
表示,将Acme这么空间名绑定到/project/src
这个目录下
而后修改project/src/View.php
文件
#View.php <?php /** * Created by PhpStorm. * User: EasyChris<chris@afox.cc> * Date: 2017/1/22 * Time: 11:06 */ //命名空间为Acme, namespace Acme; class View { public static function getView() { echo "get view"; } }
继续返回修改/project/index.php
#index.php <?php /** * Created by PhpStorm. * User: EasyChris<chris@afox.cc> * Date: 2017/1/22 * Time: 10:50 */ require_once 'vendor/autoload.php'; use AcmeView; View::getView();
修改完毕以后返回命令行运行
#使用这个命令会自动生成autoload的文件 vagrant@easychris:/var/www/public/test$ composer dump-autoload Generating autoload files
PS:须要注意一下!
#生成环境下使用 composer dump-atoload -o #这里的意思是composer dump-autoload --optimize,不是用的话会损失性能。
最后打开http://127.0.0.1/project/index.php
若是显示get view 那么,恭喜你配置成功了。
接下来你就能够继续在src
目录下面建立好比Tools.php
而后不须要作其余require,即可以直接使用了。很是的方便,能够本身尝试一下。
查看vender下的autoload.php文件你会看到,他实际上是return了一个ComposerAutoloaderInitaa62b39f628dda129dc5b4ebdfb2b2ae::getLoader();
#autoload.php <?php // autoload.php @generated by Composer require_once __DIR__ . '/composer/autoload_real.php'; return ComposerAutoloaderInitaa62b39f628dda129dc5b4ebdfb2b2ae::getLoader();
而这个getLoader()
方法作了以下几件事
1.找 ComposerClassLoader 若是不存在就是生成一个实例放在ComposerAutoloaderInitaa62b39f628dda129dc5b4ebdfb2b2ae 中2.将 composer cli 生成的各类 autoload_psr4, autoload_classmap, autoload_namespaces(psr-0) 全都注册到 ComposerClassLoader 中。3.直接 require 全部在 autoload_files 中的文件