Composer is a dependency management tool for PHP. It allows developers to declare the libraries or packages their project depends on and manages (downloads, installs, updates) them for the project. Composer is similar to tools such as npm for Node.js, pip for Python, or bundler for Ruby.
Composer works by reading a configuration file called composer.json which lists the required packages and their versions. It then downloads the packages from repositories such as Packagist and installs them in the project’s vendor directory. This way, the required dependencies are easily manageable and can be updated or removed with ease. Additionally, Composer allows developers to define their own packages and publish them to repositories for others to use.
List of All Composer commands with their explanation
Here is a list of some of the most commonly used Composer commands and their explanations:
- composer init: Initializes a new Composer package in the current directory and prompts for package details such as name, description, author, and dependencies.
- composer install: Installs the dependencies listed in the- composer.lockfile or in the- composer.jsonfile if- composer.lockis not present.
- composer update: Updates the dependencies listed in the- composer.jsonfile to their latest compatible version and updates the- composer.lockfile.
- composer require: Adds a new dependency to the- composer.jsonfile and installs it.
- composer remove: Removes a dependency from the- composer.jsonfile and uninstalls it.
- composer show: Shows information about installed packages, including their version, dependencies, and installation location.
- composer dump-autoload: Regenerates the autoloader files based on the packages installed.
- composer validate: Validates the- composer.jsonfile to ensure it is a valid JSON file and has required fields.
- composer create-project: Creates a new project based on a specified package and installs its dependencies.
- composer config: Sets or gets configuration options for Composer.
- composer run-script: Runs a specified script from the- composer.jsonfile.
- composer self-update: Updates the Composer executable to the latest version.
- composer diagnose: Checks the system for common issues with Composer installation and configuration.
- composer archive: Creates a compressed archive of the current project.
- composer status: Shows the differences between the current codebase and the last installed packages.
How compose works?
Composer is a dependency management tool for PHP that simplifies the process of installing and updating the libraries and packages that your project depends on. It works by reading a configuration file named composer.json that lists the dependencies of your project and their required versions.
When you run composer install or composer update, Composer reads the composer.json file and downloads the necessary packages and their dependencies from the internet. It then installs them into the vendor directory of your project.
During this process, Composer also generates an autoload.php file that you can use to automatically load the classes and files of your dependencies. This makes it easy to include third-party libraries and components in your PHP projects.
In summary, Composer works by:
- Reading the composer.jsonfile to determine the dependencies of your project.
- Resolving the version constraints of each dependency.
- Downloading the required packages and their dependencies from online repositories.
- Installing the packages into the vendordirectory of your project.
- Generating an autoload.phpfile to enable automatic class loading.
Example of composer.json and explanation
{
    "name": "myproject/myproject",
    "description": "My project description",
    "type": "project",
    "require": {
        "php": "^7.4",
        "monolog/monolog": "^2.0"
    },
    "autoload": {
        "psr-4": {
            "MyProject\\": "src/"
        }
    },
    "scripts": {
        "test": "phpunit tests/",
        "build": [
            "phpunit --coverage-clover build/logs/clover.xml",
            "phpcs --standard=PSR2 src/",
            "phpmd src/ text cleancode,codesize,controversial,design,naming,unusedcode",
            "phpcpd src/"
        ]
    },
    "config": {
        "sort-packages": true
    }
}
Code language: JSON / JSON with Comments (json)- "name": "myproject/myproject": This line specifies the name of the project and follows the format- vendor/package. It should be unique, as it will be used to identify the package when it is installed or published.
- "description": "My project description": This line is an optional description of the project that provides some context and information about the purpose of the project.
- "type": "project": This line specifies the type of the project, which can be- "library",- "project",- "metapackage", or- "composer-plugin".
- "require": { "php": "^7.4", "monolog/monolog": "^2.0" }: This line specifies the dependencies required by the project. In this example, it requires PHP version 7.4 or higher and the Monolog logging library version 2.0 or higher.
- "autoload": { "psr-4": { "MyProject\\": "src/" } }: This line defines the autoloading rules for the project. In this example, it uses the PSR-4 autoloading standard and specifies that the- MyProjectnamespace should be mapped to the- srcdirectory.
- "scripts": { "test": "phpunit tests/", "build": [ "phpunit --coverage-clover build/logs/clover.xml", "phpcs --standard=PSR2 src/", "phpmd src/ text cleancode,codesize,controversial,design,naming,unusedcode", "phpcpd src/" ] }: This line defines custom scripts that can be run using the- composer run-scriptcommand. In this example, there are two scripts defined:- test, which runs the PHPUnit tests in the- testsdirectory, and- build, which runs several commands in sequence to build the project, including generating code coverage reports, checking code style with PHP_CodeSniffer, running PHP Mess Detector, and detecting duplicated code with PHP Copy/Paste Detector.
- "config": { "sort-packages": true }: This line specifies the configuration options for Composer. In this example, it enables sorting of the packages in the- composer.lockfile for consistency.
I’m a DevOps/SRE/DevSecOps/Cloud Expert passionate about sharing knowledge and experiences. I have worked at Cotocus. I share tech blog at DevOps School, travel stories at Holiday Landmark, stock market tips at Stocks Mantra, health and fitness guidance at My Medic Plus, product reviews at TrueReviewNow , and SEO strategies at Wizbrand.
Do you want to learn Quantum Computing?
Please find my social handles as below;
Rajesh Kumar Personal Website
Rajesh Kumar at YOUTUBE
Rajesh Kumar at INSTAGRAM
Rajesh Kumar at X
Rajesh Kumar at FACEBOOK
Rajesh Kumar at LINKEDIN
Rajesh Kumar at WIZBRAND
 
