When building your PHP web applications, it's important to keep your dependencies up-to-date and also to prevent installing Composer dependencies with known security vulnerabilities. This helps you to ensure that your application is secure and that you're benefiting from the latest features and bug fixes.
But it's really easy to fall behind on your dependency updates between general day-to-day development tasks. Thankfully, Composer provides us with a handy tool that you can use to get an overview of which packages you're using that have available updates.
In this Quickfire article, we're going to take a quick look at the composer outdated command to help you find outdated packages in your PHP project.
You can run the composer outdated command to find out which of your dependencies have available updates.
You can execute the command by running the following in your PHP project's root directory:
composer outdated
By default, the command will display the packages that have newer versions available, along with the current version that you're using. The dependencies are split into two separate categories:
If a minor or patch version of the dependency, Composer will display the new version in red. If a major version of the dependency is available, the new version will be displayed in yellow.
Here's an example of the output you might see when running the composer outdated command:
As we can see in the image, the composer outdated command has displayed the packages that have newer versions available.
So in our example above, we can see that the phpunit/phpunit dependency that we're requiring in our composer.json file is currently on 10.5.17 and has a major version upgrade to 11.3.1 available.
We can also see that we have some transitive dependencies that have major, minor, and patch upgrades available.
The composer outdated command has a few options that you can use to filter the output:
You can use the --all option to display all the dependencies in your project, including those that are up-to-date. This can be useful if you want to see all the dependencies in your project in one place and get an overview of which packages require updates and which are running the latest versions.
You can use it like so:
composer outdated --all
The output may look something like this:
If the version numbers are displayed in green, this means the version we currently have installed is the current up-to-date version. As an example, we can see that the jonpurvis/profanify dependency is up to date.
As a side note, I've actually got an article about how you can use Profanify in your PHP projects to prevent profanity in your code. You can check it out here: Profanify: Prevent Profanity in Your PHP Codebase
You can use the --direct option to only display the direct dependencies in your project.
This can be useful if you're only interested in seeing the packages that you've directly required in your composer.json file.
You can use it like so:
composer outdated --direct
The output may look something like this:
If you only want to see the packages that have a major version available, you can use the --major-only option.
You can use it like so:
composer outdated --major-only
If you only want to see the packages that have a minor version available, you can use the --minor-only option.
You can use it like so:
composer outdated --minor-only
If you only want to see the packages that have a patch version available, you can use the --patch-only option.
You can use it like so:
composer outdated --patch-only
Hopefully, this article has given you a quick overview of the composer outdated command and how you can use it to find outdated packages in your PHP project.
If you enjoyed reading this post, you might be interested in checking out my 220+ page ebook "Battle Ready Laravel" which covers similar topics in more depth.
Or, you might want to check out my other 440+ page ebook "Consuming APIs in Laravel" which teaches you how to use Laravel to consume APIs from other services.
If you're interested in getting updated each time I publish a new post, feel free to sign up for my newsletter.
Keep on building awesome stuff! ?
The above is the detailed content of Find Outdated Composer Dependencies Using \'composer outdated\'. For more information, please follow other related articles on the PHP Chinese website!