composer.md 3.66 KB
Newer Older
1 2 3
Composer
========

4 5
Yii2 uses Composer as its package manager. Composer is a PHP utility that can automatically handle the installation of needed libraries and
extensions, thereby keeping those third-party resources up to date while absolving you of the need to manually manage the project's dependencies.
6 7 8 9

Installing Composer
-------------------

10 11
In order to install Composer, check the official guide for your operating system:

12
* [Linux](http://getcomposer.org/doc/00-intro.md#installation-nix)
13 14 15 16 17 18 19
* [Windows](http://getcomposer.org/doc/00-intro.md#installation-windows)

All of the details can be found in the guide, but you'll either download Composer directly from [http://getcomposer.org/](http://getcomposer.org/), or run the following command:

```
curl -s http://getcomposer.org/installer | php
```
20 21 22 23

Adding more packages to your project
------------------------------------

24 25
The act of [installing a Yii application](installation.md) creates the `composer.json` file in the root directory of your project.
In this file you list the packages that your application requires. For Yii sites, the most important part of the file is the `require` section:
26

27
```json
28 29 30
{
    "require": {
        "Michelf/php-markdown": ">=1.3",
31
        "ezyang/htmlpurifier": ">=4.6.0"
32 33 34 35
    }
}
```

36 37 38 39
Within the `require` section, you specify the name and version of each required package.
The above example says that a version greater than or equal to 1.3 of Michaelf's PHP-Markdown package is required,
as is version 4.5 or greater of Ezyang's HTMLPurifier.
For details of this syntax, see the [official Composer documentation](http://getcomposer.org).
40

41
The full list of available Composer-supported PHP packages can be found at [packagist](http://packagist.org/).
42

43 44
Once you have edited the `composer.json`, you can invoke Composer to install the identified dependencies.
For the first installation of the dependencies, use this command:
45 46

```
47
php composer.phar install --prefer-dist
48 49
```

50 51 52
This must be executed within your Yii project's directory, where the `composer.json` file can be found.
Depending upon your operating system and setup, you may need to provide paths to the PHP executable and
to the `composer.phar` script.
53 54

For an existing installation, you can have Composer update the dependencies using:
55 56

```
57
php composer.phar update --prefer-dist
58 59
```

60 61
Again, you may need to provide specific path references.

62 63
In both cases, after some waiting, the required packages will be installed and ready to use in your Yii application.
No additional configuration of those packages will be required.
64 65


66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84
Using a specifc version of a package
------------------------------------

Yii always comes with the latest version of a required library that it is compatible with but allows you to use an
older version if you need to.
A good example for this is jQuery which has [dropped old IE browser support](http://jquery.com/browser-support/) in version 2.x.
When installing Yii via composer the installed jQuery version will be the latest 2.x release. When you want to use jQuery 1.10
because of IE browser support you can adjust your composer.json by requiring a specific version of jQuery like this:

```json
{
    "require": {
        ...
        "yiisoft/jquery": "1.10.*"
    }
}
```


85 86 87 88 89 90 91 92 93 94 95 96
FAQ
---

### Getting "You must enable the openssl extension to download files via https"

If you're using WAMP check [this answer at StackOverflow](http://stackoverflow.com/a/14265815/1106908).

### Getting "Failed to clone <URL here>, git was not found, check that it is installed and in your Path env."

Either install git or try adding `--prefer-dist` to the end of `install` or `update` command.


97 98 99 100
See also
--------

- [Official Composer documentation](http://getcomposer.org).