How to Install and Use the Symfony ComponentsEdit this page
Warning: You are browsing the documentation for Symfony 5.1, which is no longer maintained.
Read the updated version of this page for Symfony 6.2 (the current stable version).
If you're starting a new project (or already have a project) that will use one or more components, the easiest way to integrate everything is with Composer. Composer is smart enough to download the component(s) that you need and take care of autoloading so that you can begin using the libraries immediately.
This article will take you through using The Finder Component, though this applies to using any component.
1. If you're creating a new project, create a new empty directory for it.
2. Open a terminal, step into this directory and use Composer to grab the library.
$ composer require symfony/finder
symfony/finder is written at the top of the documentation for
whatever component you want.
Install Composer if you don't have it already present on your system.
Depending on how you install, you may end up with a
file in your directory. In that case, no worries! Your command line in that
php composer.phar require symfony/finder.
3. Write your code!
Once Composer has downloaded the component(s), all you need to do is include
vendor/autoload.php file that was generated by Composer. This file
takes care of autoloading all of the libraries so that you can use them
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20
// Project structure example: // my_project/ // data/ // ... # Some project data // src/ // my_script.php # Main entry point // vendor/ // autoload.php # Autoloader generated by Composer // ... # Packages downloaded by Composer // File example: src/my_script.php // Autoloader relative path to this PHP file require_once __DIR__.'/../vendor/autoload.php'; use Symfony\Component\Finder\Finder; $finder = new Finder(); $finder->in('../data/'); // rest of your PHP code...
Now, the component is installed and autoloaded. Read the specific component's documentation to find out more about how to use it.
And have fun!