There are several different ways to install Yii2, ranging from downloading the framework from source control (typically, from GitHub at https://github.com/yiisoft/yii2) to using a package manager such as Composer. With modern web applications, Composer is the preferred method to install Yii2 as it enables us to install, update, and manage all dependencies and extensions for our application in an automated fashion. Additionally, using Composer, we can ensure that Yii Framework 2 is kept up to date with the latest security and bug fixes. Composer can be installed by following the instructions on https://getcomposer.org. Typically, this process looks as follows:
Alternatively, if you don't have cURL available on your system, it can be installed through PHP itself:
Once installed, we should move Composer to a more centralized directory so that we can call it from any directory on our system. Installing Composer from a centralized directory rather than on a per-project basis has several advantages:
- It can be called anywhere from any project. When working with multiple projects, we can ensure that we use the same dependency manager each time and for every project.
- In a centralized directory, Composer only needs to be updated once rather than in every project we are working on.
- Dependency managers are rarely considered code that should be pushed to your DCVS repository. Keeping the
composer.phar
file out of your repository reduces the amount of code you need to commit and push and ensures that your source code remains isolated from your package manager code. - By installing Composer from a centralized directory, we can ensure that Composer is always available, which saves us a step each time we clone a project that depends on Composer.
A good directory to move Composer to is /usr/local/bin,
as shown in the following example:
Tip
Throughout this book, we'll be using Unix-style commands when referencing command-line arguments. Consequently, some commands may not work on Windows. If you decide to set up a Windows environment, you might need to use Composer-Setup.exe
(available at https://getcomposer.org/Composer-Setup.exe) to get Composer configured for your system. If you have any issues getting Composer to run on your system, ensure that you check out the Composer documentation available at https://getcomposer.org/doc/.
Alternatively, if you have Composer installed on your system already, ensure that you update it to the latest version by running this:
Tip
The commands that we use through this book are based on the assumption that you have sufficient privileges to run them. On Unix-like systems, you may need to preface some commands with sudo
in order to execute the command with a high permissions set. Alternatively if you are running these commands on Windows, you should ensure that you are running the listed commands in a command prompt that has elevated privileges. Ensure that you follow best practices when using sudo
and when using elevated command prompts in order to ensure your system stays secure.
Once Composer is installed, we'll need to install a global plugin called The Composer Asset Plugin (available at https://github.com/francoispluchino/composer-asset-plugin). This plugin enables Composer to manage asset files for us without the need to install additional software (these programs are Bower, an asset dependency manager created by Twitter, and Node Package Manager, or NPM, which is a JavaScript dependency manager).
Tip
Due to the GitHub API's rate limiting, during installation, Composer may ask you to enter your GitHub credentials. After entering your credentials, Composer will request a dedicated API key from GitHub that can be used for future installations. Ensure that you check out the Composer documentation at https://getcomposer.org/doc/ for more information.
With Composer installed, we can now instantiate our application. If we want to install an existing Yii2 package, we can simply run the following:
Using the Yii2 basic app as an example, this command will look like this:
After running the command, you should see output similar to the following:
Note
Your output may differ slightly due to the data cached on your system and versions of subpackages.
This command will install the Yii2 basic app to a folder called basic. When creating a new Yii2 project, you'll typically want to use the create-project command to clone "yii2-app-basic" and then develop your application from there as the basic app comes prepopulated with just about everything you need to start a new project. However, you can also create a Yii2 project from scratch that, while more complicated, gives you more control over your application's structure.
Let's take a look at the composer.json
file that was created when we ran the create-project
command:
While most of these items (such as the name, description, license, and require blocks) are rather self-explanatory, there are a few Yii2-specific items in here that we should take note of. The first section we want to look at is the "scripts"
section:
This script tells Composer that when the create-project
command is run, it should run the postCreateProject
static function. Looking at the the framework source code, we see that this file is referenced in the yii2-composer
package (refer to https://github.com/yiisoft/yii2-composer/blob/master/Installer.php#L232). This command then runs several post-project creation actions, namely setting the local disk permissions, generating a unique cookie validation key, and setting some asset installer paths for composer-asset-plugin.
Next, we have the "extra"
block:
This section tells Composer to use these options when it runs the postCreateProject
command. These preconfigured options give us a good starting point to create our applications.