Composer的学习

来自http://blog.sina.com.cn/s/blog_6262a50e0101b5ut.html

简介

composer是PHP中的一个依赖关系管理工具。只要(按指定格式)声明项目所依赖的库,composer就可以为我们安装这些库。

依赖关系管理

composer不是包管理器。不错,它处理“包”或库,但他的管理基于单个项目,它把库安装到项目中的一个目录中(例如:vendor)。缺省情况下,composer从不在全局范围安装任何东西。因此,composer是一个依赖关系管理器。

这并不是种全新的思想,composer受到node的npm和ruby的bundler的启发。但对PHP来说,还没有这样的工具。

composer要解决的问题是:

l         我们有一个项目,依赖好几个库。

l         这些库中某些又依赖于别的库。

l         我们声明我们依赖的库

l         composer找到需要安装哪个包的哪个版本,并安装(这意味着composer把他们下载到我们的项目中)。

声明依赖关系

假定我们创建了一个项目,需要一个库做日志记录。我们决定使用monolog。为了把monolog加到项目中,我们只需要创建一个描述项目依赖关系的文件composer.json。

{
    "require": {
        "monolog/monolog": "1.0.*"
   }
}

这里只需简单地说明我们的项目需要某个monolog/monolog包,以1.0开始的任何版本都可以。

安装

本地下载

要获取composer,我们需要做两件事。第一件是安装composer(再说一遍,把它下载到我们的项目目录中):

$ curl –s https://getcomposer.org/installer | php

这个命令会检查PHP的几个设置然后把composer.phar下载到我们的工作目录。这个文件是composer程序。它是一个PHAR(PHP archive),PHAR是PHP的一种文档格式,可以在命令行运行。

通过--install-dir选项,可以把composer安装到指定目录中(可以是绝对路径,也可以是相对路径):

$curl –s https://getcomposer.org/installer | php -- --install-dir=bin

全局下载

这个文件可以放在任何地方。如果把它放在PATH指定的路径中,就可以全局访问了。在unix类的系统中上,可以把它变成可执行文件,运行时可以不指定php。

$ curl -s https://getcomposer.org/installer | php
$ sudo mv composer.phar /usr/local/bin/composer

然后,运行composer时只需运行composer。

使用composer

下一步,运行install命令来解析和下载依赖库:

php composer.phar install

这个命令会把monolog下载到vendor/monolog/monolog目录中。

自动加载

除了下载库之外,composer还准备了一个自动加载文件,可以自动加载它下载的库中的所有类。要使用自动加载,只要在代码的引导过程中加上:

require ‘vendor/autoload.php‘;

好了,开始使用monolog吧!要学习composer的更多知识,请阅读“基本用法”一章。

基本用法:http://docs.phpcomposer.com/01-basic-usage.html

来自http://blog.csdn.net/think2me/article/details/38456931

使用composer.json来加载和下载类库源码

我们已经找到了monolog的加载master路径了。那么我们怎么搞到我们的项目中的。我们需要借助于composer.json文件来帮我们,说到composer.json,我们就不得不说nodejs中的package.json,如果我们知道package.json。我们就完全能了解composer.json的作用了。它是一个代码依赖的约束文件,格式是json格式。通过这个文件我们用composer install 命令时,他会自动去下载里面的约束关系。

好。那我们把我们需要的monglog加进来,需要用require 字段:

{
    "require": {
        "monolog/monolog": "1.11.*@dev"
    }
}

你可以看到, require 需要一个 包名称 (例如 monolog/monolog) 映射到 包版本 (例如 1.11.*@dev) 的对象。

我们就写这一个最简单的require,我们保存composer.json。然后我们打开命令行工具,使用命令:composer install

$ composer install

命令执行完成后,就开始自动下载了,我们打开文件夹:

文件结构是:vendor文件夹+composer.lock+composer.json。我们过会说composer.lock是干嘛的有什么用。我们点击vendor进去:

里面是一个一个类库文件夹,有我们需要的mongolog,还有一个psr是在mongolog里面的composer.json里reqiure了,所以一起下载了。从这里可以看出用composer的好处了,就是一层一层的依赖关系都能加载进来,很强大很方便。

我们注意到里面有个autoload.php找个我们也是在后面来说,它是一个自动加载类库,很强大,我们只需要加载找个文件,就能自动加载使用其他的类库了,不需要再手动加载。

3. composer.lock是干嘛的?

我们注意到了,composer install 的时候,系统自动帮我们新建一个composer.lock文件,那这个锁文件是干嘛的呢?

我们可以打开这个文件,看看里面写的是什么。打开后,我们发现这几乎和composer.json是一样的格式和数据,也是各种约束关系,require文件等。

在安装依赖后,Composer 将把安装时确切的版本号列表写入 composer.lock 文件。这将锁定改项目的特定版本。以后就会以这个版本为主,只要有这个文件在,就会忽略所有的composer.json文件。这是非常重要的,因为 install 命令将会检查锁文件是否存在,如果存在,它将下载conposer.lock指定的版本(忽略 composer.json 文件中的定义)。

如果不存在 composer.lock 文件,Composer 将读取 composer.json 并创建锁文件。

我们想想这样有什么作用呢?假设一个场景,多人开发,肯定会有人新的人开发完成将要后续开发,那么他肯定会去更新composer.json的依赖关系,那么其他人更新后,也会同样去更新,这样就乱了。他本来不想去更新,只想用原来的。所以有个这个composer.lock 文件,所有的人都会用一样的依赖关系版本。等全部都开发好了。再将这个composer.lock文件删掉就可以了。

这意味着如果你的requie的依赖更新了新的版本,你也不会获得任何更新。因为有composer.lock文件存在,此时要想更新你的依赖版本请使用 update 命令。这将获取最新匹配的版本(根据你的 composer.json 文件)并将新版本更新进锁文件composer.lock

如果我们确实需要更新依赖呢?我们可以使用 update 命令,它将重新生成lock文件

$ composer update

如果只想安装或更新一个依赖,你可以这样单独更新它:

$ composer update monolog/monolog [...]

4. 包版本的规则是啥

在前面的例子中,我们引入的 monolog 版本指定为 1.0.*。这表示任何从 1.0 开始的开发分支,它将会匹配 1.0.01.0.2或者 1.0.20

版本约束可以用几个不同的方法来指定。

名称 实例 描述
确切的版本号 1.0.2 你可以指定包的确切版本。
范围 >=1.0 >=1.0,<2.0>=1.0,<1.1|>=1.2 通过使用比较操作符可以指定有效的版本范围。 
有效的运算符:>>=<<=!=。 
你可以定义多个范围,用逗号隔开,这将被视为一个逻辑AND处理。一个管道符号|将作为逻辑OR处理。 
AND 的优先级高于 OR。
通配符 1.0. 你可以使用通配符来指定一种模式。1.0.*>=1.0,<1.1是等效的。
赋值运算符 ~1.2 这对于遵循语义化版本号的项目非常有用。~1.2相当于>=1.2,<2.0。想要了解更多,请阅读下一小节。

5. 下一个重要版本(波浪号运算符)

~ 最好用例子来解释: ~1.2 相当于 >=1.2,<2.0,而 ~1.2.3 相当于 >=1.2.3,<1.3。正如你所看到的这对于遵循 语义化版本号 的项目最有用。一个常见的用法是标记你所依赖的最低版本,像 ~1.2 (允许1.2以上的任何版本,但不包括2.0)。由于理论上直到2.0应该都没有向后兼容性问题,所以效果很好。你还会看到它的另一种用法,使用 ~ 指定最低版本,但允许版本号的最后一位数字上升。

默认情况下只有稳定的发行版才会被考虑在内。如果你也想获得 RC、beta、alpha 或 dev 版本,你可以使用 稳定标志。你可以对所有的包做 最小稳定性 设置,而不是每个依赖逐一设置。

6. 在我们自己的php项目中使用

既然代码库都下载好了。那么我们就应该可以使用了。前面说过,在vendor文件夹下面有一个autoload.php文件,这个文件有大大的用户,他是一个自动加载的文件,我们只要加载了它,那么我们就相当于讲其他的类库文件都加载了:

require ‘vendor/autoload.php‘;

我们在对的路径加载这一句就可以了。比如,我们在加载了这一句后,想调用mongolog,我们就可以直接用了,不需要另外加载它:

$log = new Monolog\Logger(‘name‘);
$log->pushHandler(new Monolog\Handler\StreamHandler(‘app.log‘, Monolog\Logger::WARNING));

$log->addWarning(‘Foo‘);

很方便。

7. composer的其他用法

一般我们使用composer.json来下载第三方类库,用require ‘vendor/autoload.php‘;使用它。当然composer的使用远远不止于此

我们可以直接敲入用composer命令,就会出现一个composer的命令list:

   ______ 
  / ____/___  ____ ___  ____  ____  ________  _____ 
/ /   / __ \/ __ `__ \/ __ \/ __ \/ ___/ _ \/ ___/ 
/ /___/ /_/ / / / / / / /_/ / /_/ (__  )  __/ / 
\____/\____/_/ /_/ /_/ .___/\____/____/\___/_/ 
                    /_/ 
Composer version 0209bd31a0ac3aeb2a68fc81e2d03c71072bef33

Usage: 
  [options] command [arguments]

Options: 
  –help           -h Display this help message. 
  –quiet          -q Do not output any message. 
  –verbose        -v Increase verbosity of messages. 
  –version        -V Display this application version. 
  –ansi              Force ANSI output. 
  –no-ansi           Disable ANSI output. 
  –no-interaction -n Do not ask any interactive question. 
  –profile           Display timing and memory usage information 
  –working-dir    -d If specified, use the given directory as working directory 
.

Available commands: 
  about            Short information about Composer 
  archive          Create an archive of this composer package 
  config           Set config options 
  create-project   Create new project from a package into given directory. 
  depends          Shows which packages depend on the given package 
  diagnose         Diagnoses the system to identify common errors. 
  dump-autoload    Dumps the autoloader 
  dumpautoload     Dumps the autoloader 
  help             Displays help for a command 
  init             Creates a basic composer.json file in current directory. 
  install          Installs the project dependencies from the composer.lock file 
if present, or falls back on the composer.json. 
  list             Lists commands 
  require          Adds required packages to your composer.json and installs the 
m 
  run-script       Run the scripts defined in composer.json. 
  search           Search for packages 
  self-update      Updates composer.phar to the latest version. 
  selfupdate       Updates composer.phar to the latest version. 
  show             Show information about packages 
  status           Show a list of locally modified packages 
  update           Updates your dependencies to the latest version according to 
composer.json, and updates the composer.lock file. 
  validate         Validates a composer.json

这里面有很多命令,我们可以一个个的尝试下看看。最常用的就是create-project命令了,我们常见的框架symfony 和 Laravel 框架就是这种方式的:

composer create-project laravel/laravel your-project-name 2.1.2
composer create-project symfony/framework-standard-edition  your-project-name  2.1.2

8. composer的一些常用的命令:

 

composer list 列出所有可用的命令
composer init 初始化composer.json文件(就不劳我们自己费力创建啦),会要求输入一些信息来描述我们当前的项目,还会要求输入依赖包
composer install 读取composer.json内容,解析依赖关系,安装依赖包到vendor目录下
composer update 更新最新的依赖关系到compsoer.lock文件,解析最新的依赖关系并且写入composer.lock文件
composer search packagename 搜索包,packagename替换为你想查找的包名称
composer require packagename 添加对packagename的依赖,packagename可修改为你想要的包名称
composer show packagename
composer self-update 更新 composer.phar文件自身
composer command --help 以上所有命令都可以添加--help选项查看帮助信息
时间: 2024-08-04 21:27:14

Composer的学习的相关文章

php composer的学习之路(一)

composer的介绍请看这里  http://docs.phpcomposer.com/00-intro.html composer的安装过程我就不介绍了,windows系统下跟其他安装没区别,一直下一步就行了. 安装完后我们去查看有没有安装成功 运行cmd,打开命令窗口,输入composer -v,出现一下内容证明安装成功: 否则会提示错误信息. 之后我们需要将它配置成国内镜像输入这个命令即可:composer config -g repo.packagist composer https:

composer安装学习

Packagist 镜像 网站地址 http://www.phpcomposer.com/ 请各位使用本镜像的同学注意: 本镜像已经依照 composer 官方的数据源安全策略完全升级并支持 https 协议!请各位同学 按照下面所示的两个方法将 http://packagist.phpcomposer.com 修改为https://packagist.phpcomposer.com 还没安装 composer 吗?请往下看如何安装 composer . 用法: 有两种方式启用本镜像服务: 系统

Yii2的相关学习记录,安装Yii2(一)

原先学习过Yii1的相关知识,但是也是半懂不懂的,但稍微的结构是了解的.现在利用晚上的时间学习下Yii2的使用,这里记录下,以免自己以后忘记. 目前已看一部分Yii2的权威指南,虽然Yiiframework中文网站的权威,跟英文版本比较有些章节缺失内容,但也能大体了解,用的某功能时再仔细看.顺便看了慕课网上的“与Yii框架不得不说的故事”,讲的也不错的. 还有比较重要的是需要FQ用google,毕竟是国外的框架,中文的内容比较少,大部分解答都能在谷歌中搜索到,这里可以用XX-Net,具体的如何用

Win7 中安装 Composer (PHP)

Win7 中安装 Composer (PHP) 国内有些网络不能访问美国的Composer官网,可访问 Composer 中文网 学习. 目标 可以在任何目录下的项目中执行 php composer.phar install 命令. 第一步:下载 点击这里下载最新的文件: composer.phar 第二步:配置 PATH环境变量 包含 composer.phar 所在位置 包含 php 所在位置 根据中国资源镜像页面来配置. 第三步:使用 cd project-folder/ php comp

php composer包管理器

Composer是 PHP 用来管理依赖(dependency)关系的工具.你可以在自己的项目中声明所依赖的外部工具库(libraries),Composer 会帮你安装这些依赖的库文件. 下载地址:http://docs.phpcomposer.com/download/ 我使用的win7,直接下载Composer-Setup.exe全局安装 1.创建自己的项目目录? D:\phppro? 创建composer.json文件内容如下: { "require": { } } 2.命令行

composer Failed to decode zlib stream 无法解码zlib流

Win7 中安装 Composer (PHP) 国内有些网络不能访问美国的Composer官网,可访问 Composer 中文网 学习. 目标 可以在任何目录下的项目中执行 PHP composer.phar install 命令. 第一步:下载 点击这里下载最新的文件: composer.phar 第二步:配置 PATH环境变量 包含 composer.phar 所在位置 包含 php 所在位置 根据中国资源镜像页面来配置. 以 laravel 项目的 composer.json 配置文件为例

Php学习之依赖管理工具composer详解

本文和大家分享的主要是php中依赖管理工具composer相关用法,一起来看看吧,希望对大家学习php有所帮助. 什么是依赖管理工具 当你引用某个第三方库时,如果这个库使用到了另外一个或若干个第三方库,再或许另外一个第三方库又有其他的依赖,这样的话手动维护你需要下载安装N个包.用来解决由此产生的问题的工具就叫做依赖管理工具. 有哪些常见的依赖管理工具 Java的maven.gradle,NodeJs的npm,IOS的CocoaPods,PHP的composer 大部分编程语言都会有自己的常用依赖

Composer学习

学习Composer Composer 是 PHP 的一个依赖管理工具.它允许你申明项目所依赖的代码库,它会在你的项目中为你安装他们. 1.安装Composer,根据Composer中文网有详细教程.Composer.phar是Composer的二进制文件,帮助用户在命令行执行操作. a) 局部安装:在二进制文件目录打开CMD,执行php composer.phar -v命令: b) 全局安装:执行echo @php "%~dp0composer.phar" %*>compose

Yii2学习笔记1--Yii2的基本介绍和Composer安装

一.Yii的基本介绍 Yii 是一个高性能的,以快速,安全,专业著称 , 适用于开发 WEB2.0 应用的 PHP 框架 .自带了丰富的功能 ,包括 MVC,DAO/ActiveRecord,I18N/L10N,缓存,身份验证和基于角色的访问控制,脚手架,测试等,可显著缩短开发时间. 二.Yii1.1和Yii2 没有Yii1.1的经验,并不妨碍对Yii2.0的学习.因为对ThinkPHP3.2.3较熟悉,可以两者对比着学(感觉很类似). 三.Windows 系统用Composer安装Yii2 ①