composer 应用

443 查看

Namespace

1.非限定名称或不包含前缀的类名称.
如 $a = new foo();
如果当前命名空间是 app,则 foo 为appfoo
如果当前没有命名空间,代码是全局的.则 foo 被解析为全局 foo

2.限定名称或包含前缀的名称.
如 $a = new userfoo();
如果当前命名空间为 app,则 foo 被解析为 appuserfoo();
如果使用 foo 的代码是全局的,不包含在任何命名空间中的代码,foo 会被解析为 userfoo。

3.完全限定名称
如 $a = new userfoo();
在这种情况下,foo 就是 userfoo();

访问任意全局类、函数或常量,都可以使用完全限定名称,例如 strlen() 或 Exception 或 INI_ALL。

composer

1.classmap
命名空间和文件路径的映射

{
    "autoload": {
        "classmap": ["src/", "lib/", "Something.php"]
    }
}

它会扫描指定目录下以. php 或. inc 结尾的文件中的 class,生成 class 到指定 file path 的映射.
并加入新生成的 vendor/composer/autoload_classmap.php 文件中

<?php
return [
  'App\\Console\\Kernel' => $baseDir . '/app/Console/Kernel.php'
];
?>

2.files

{
    "autoload": {
        "files": ["src/MyLibrary/functions.php"]
    }
}

用于全局性的helper 目录下函数
它会生成一个 array,包含这些配置中指定的 files,再写入新生成的 vendor/composer/autoload_files.php 文件中,以供 autoloader 直接进行加载

3.psr-4

"autoload": {
        "psr-4": {
            "App\\": "app/"
        }
    }

key 和 value 就定义出了 namespace 以及到相应 path 的映射
注册命名空间到对应的路径下的 src 目录下,不指向 src 也可以.
然后根据命名空间去目录下寻找文件.
$a = new AppFoo();
会去 app目录下找 foo.php 文件

加入后执行 composer install 或 composer dump-autoload

项目实践

1.项目目录

2.composer.json

{
  "require": {
    "predis/predis": "1.1.0"
  },
  "autoload": {
    "psr-4": {
      "App\\": "app/",
      "Third\\":"third/"
    },
    "files":[
      "helper/constants.php",
      "helper/funs.php"
    ]
  }
}

执行 composer install 或 composer dumpautoload
会在vendor/composer 里对应的加载方式文件中生成映射

psr-4

return array(
    'Third\\' => array($baseDir . '/third'),
    'Predis\\' => array($vendorDir . '/predis/predis/src'),
    'App\\' => array($baseDir . '/app'),
);

files

return array(
    'da551be15a8db089a9deb0b11a4f158d' => $baseDir . '/helper/constants.php',
    'cebcf5f3197b00af0a0ca1ae69808ce5' => $baseDir . '/helper/funs.php',
);

使用,在 index.php 中

require dirname(__FILE__)."/vendor/autoload.php";

echo Predis\Client::VERSION;
$app = new App\Pay();
$app->index();