转自 http://blog.csdn.net/zzulp/article/details/18981029php
Composer是一个基于项目的依赖管理器,负责将PHP项目所依赖的包或库安装到项目所在的目录中,默认它不会安装任何数据到全局。它用于取代以前所使用的pear工具。
1 安装Composerredis
2 简单应用
咱们只须要声明一个项目所依赖的包或库便可,此后其余的事情就由Composer来处理了。所以使用Composer最重要的就是在项目目录中编写composer.json配置文件。例如你有一个项目,须要依赖monolog,能够这样写composer.json文件:
{
"require":
{
"monolog/monolog": "1.2.*"
}
}
有了此文件后,在项目目录中执行composer install,即会在项目目录的vendor/目录下建立其所依赖的库。
另外一方面,包含了composer.json的目录,也能够发布出去,让其余人经过composer进行安装。只须要在packagelist网站,把此包传上去便可。
3 配置文件说明json
Composer使用json做为其配置文件的格式。在工程的根目录下composer.json所定义的包称为root包。在配置文件中有以下的属性。数组
3.1 require
格式为: "require":{"vendor-name/package-name":"version", ...}
名字部分会做为vendor下的路径进行建立
版本支持精确的版本号,也支持范围如>=1.0; >=1.0,<2.0; ","做为逻辑与,而"!"做为逻辑或的意思。示例中使用了通配符*
版本也支持tag或branch名称。
相似的有require-dev,前者用于声明项目发布版本的依赖包,后者用于声明项目开发或测试中依赖的包。
3.2 autoloadcomposer
composer支持PSR-0,PSR-4,classmap及files包含以支持文件自动加载。PSR-4为推荐方式。curl
3.2.1 Files类型
格式:"autoload":{"files":["path/to/1.php","path/to/2.php",...]}
支持将数组中的文件进行自动加载,文件的路径相对于项目的根目录。缺点是麻烦,须要将全部文件都写进配置。
3.2.2 classmap类型
格式:"autoload":{"classmap": ["path/to/src1","path/to/src2",...]}
支持将数组中的路径下的文件进行自动加载。其很方便,但缺点是一旦增长了新文件,须要执行dump-autoload命令从新生成映射文件vendor/composer/autoload_classmap.php。
3.2.3 psr-0类型
格式:"autoload":{"psr-0":{
"name1\\space\\":["path/",...],
"name2\\space\\":["path2/",...],
}
}
支持将命名空间映射到路径。命名空间结尾的\\不可省略。当执行install或update时,加载信息会写入vendor/composer/autoload_namespace.php文件。若是但愿解析指定路径下的全部命名空间,则将命名空间置为空串便可。
须要注意的是对应name2\space\Foo类的类文件的路径为path2/name2/space/Foo.php
3.2.4 psr-4类型
格式:"autoload":{"psr-4":{
"name1\\space\\":["path/",...],
"name2\\space\\":["path2/",...],
}
}
支持将命名空间映射到路径。命名空间结尾的\\不可省略。当执行install或update时,加载信息会写入vendor/composer/autoload_psr4.php文件。若是但愿解析指定路径下的全部命名空间,则将命名空间置为空串便可。
须要注意的是对应name2\space\Foo类的类文件的路径为path2/space/Foo.php,name2不出如今路径中。
PSR-4和PSR-0最大的区别是对下划线(underscore)的定义不一样。PSR-4中,在类名中使用下划线没有任何特殊含义。而PSR-0则规定类名中的下划线_会被转化成目录分隔符。
3.3 name
格式:"name":"vendor/package"
若是要发布一个包,你须要指定包的名字信息。
3.4 version
格式:"version":"1.0.2"
若是要发布一个包,你须要指定包的版本号。版本号的格式为X.Y.Z或vX.Y.Z,其后能够加后缀如-dev,-patch,-alpha,-beta或-RC。除dev外,尾上还可加一个数字,如1.0.0-alpha3。
3.5 description
格式:"description":"your own description at here!"
若是要发布一个包,能够指定一个简短的介绍
3.5 type
格式:"type":"library"
说明包的类型,支持以下library,project,metapackage,composer-plugin,默认为library
3.6 keywords
格式:"keywords":["logging","database","redis"]
一个数组的关键字,用于搜索或过滤时使用。
3.7 homepage
可选的,说明项目的网站地址
3.8 time/license
说明项目的时间和License,时间格式为YY-MM-DD HH:MM:SS
3.9 authors
格式:"authors":[
{"name":"ss","email":"ss@ss.com","homepage":"","role":""},...
]
用于说明项目的做者信息,为可选的。
3.10 support
格式:"support":{"emial":"","issues":"","forum":"","wiki":"","irc":"" }
用于说明项目的支持信息
3.11 conflict
用于声明与本包有冲突的包的版本,使用相似于require。
3.12 replace
用于声明须要替换的包,使用相似于require
3.13 provided
用于说明本包实现了某个包的接口
3.14 suggest
格式:"suggest":{"vendor/package":"Some description!"}
用于说明可选的,用于加强功能的包及说明。
4 命令行工具
有了配置文件后,即可以使用composer命令来执行,有以下命令
init 进入交互式向导,在当前目录下生成composer.json文件
install 根据配置进行安装
选项 --prefer-source
--prefer-dist
--dry-run
--dev/--no-dev
-o 将psr0/4转换为classmap以提高性能
update [package-name ...] 根据配置升级指定的包
search [pattern] 从packagelist中搜索包
show [package-name] 显示包的信息
depends package 分析项目中包的依赖
validate 验证配置文件内容
status 检查代码是修改信息
self-update 升级composer自己
config 配置composer本地或全局选项,能够--list显示全部可配置项 格式为conifg [option] [key] [value...]
create-project vendor/package path version 在指定路径下下载一个项目,默认从packagelist上搜索
dump-autoload 当类映射中加入新类时,用于更新加载器
5 自动加载
对于composer管理的依赖,若是但愿自动加载只须要在文件中加入:require 'vendor/autoload.php'
拿上面的例子,使用依赖的类就十分简单了,使用packet-name\class-name就能够直接访问了。如
$log = new Monolog\Logger();
6 杂项ide
composer.lock文件用于记录各依赖的版本,若是使用了VCS,即此文件也须要进行提交。由于若是此文件存在,即composer会按照此文件中的版本进行下载,会忽略composer.json文件。若是须要更新版本,则须要修改composer.json,并执行update命令,此时会下载新版本,并更新composer.lock文件。工具