This repository has been archived on 2023-08-20. You can view files and clone it, but cannot push or open issues or pull requests.
symfony/src/Symfony/Component/HttpFoundation
Christophe Coevoet 237b13c56c Merge branch '2.3' into 2.7
* 2.3:
  [Process] Fix stopping a process on Windows
  Added a test case for the Logger class.
  CS: general fixes
2015-12-05 18:37:09 +01:00
..
File Merge branch '2.3' into 2.7 2015-09-29 14:06:14 +02:00
Resources/stubs Merge branch '2.5' into 2.6 2014-12-22 17:44:09 +01:00
Session Merge branch '2.3' into 2.7 2015-12-05 12:06:38 +01:00
Tests Merge branch '2.3' into 2.7 2015-12-05 18:37:09 +01:00
.gitignore Added missing files .gitignore 2013-07-21 14:12:18 +02:00
AcceptHeader.php [2.3] CS And DocBlock Fixes 2014-12-22 16:58:09 +01:00
AcceptHeaderItem.php fixed types in phpdocs 2014-04-16 12:30:19 +02:00
ApacheRequest.php [HttpFoundation] do not use server variable PATH_INFO because it is already decoded and thus symfony is fragile to double encoding of the path 2013-04-12 17:03:10 +02:00
BinaryFileResponse.php fixes CS 2015-08-24 09:13:45 +02:00
CHANGELOG.md [HttpFoundation] implement different locking strategies for sessions 2014-10-02 20:16:41 +02:00
composer.json Merge branch '2.3' into 2.7 2015-10-30 13:10:21 -07:00
Cookie.php remove api tags from code 2015-09-28 19:11:22 +02:00
ExpressionRequestMatcher.php [HttpFoundation] added ExpressionRequestMatcher 2013-09-19 12:59:11 +02:00
FileBag.php remove api tags from code 2015-09-28 19:11:22 +02:00
HeaderBag.php Merge branch '2.3' into 2.7 2015-09-29 14:06:14 +02:00
IpUtils.php [HttpFoundation] Fixes /0 subnet handling in IpUtils 2015-10-19 13:54:29 +02:00
JsonResponse.php Windows and Intl fixes 2015-08-25 23:41:39 +02:00
LICENSE Updated copyright to 2015 2015-01-01 13:56:52 +01:00
ParameterBag.php Merge branch '2.3' into 2.7 2015-10-30 13:10:21 -07:00
phpunit.xml.dist Add missing exclusions from phpunit.xml.dist 2015-11-18 09:19:46 +01:00
README.md renamed composer.phar to composer to be consistent with the Symfony docs 2015-02-08 08:41:14 +01:00
RedirectResponse.php remove api tags from code 2015-09-28 19:11:22 +02:00
Request.php Merge branch '2.3' into 2.7 2015-10-18 22:23:18 +02:00
RequestMatcher.php Merge branch '2.3' into 2.7 2015-09-29 14:06:14 +02:00
RequestMatcherInterface.php remove api tags from code 2015-09-28 19:11:22 +02:00
RequestStack.php unified return null usages 2014-04-18 22:38:54 +02:00
Response.php Merge branch '2.3' into 2.7 2015-12-05 12:06:38 +01:00
ResponseHeaderBag.php Merge branch '2.3' into 2.7 2015-09-29 14:06:14 +02:00
ServerBag.php Handled bearer authorization header in REDIRECT_ form 2015-02-10 11:35:13 +08:00
StreamedResponse.php Merge branch '2.3' into 2.7 2015-09-29 14:06:14 +02:00

HttpFoundation Component

HttpFoundation defines an object-oriented layer for the HTTP specification.

It provides an abstraction for requests, responses, uploaded files, cookies, sessions, ...

In this example, we get a Request object from the current PHP global variables:

use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\HttpFoundation\Response;

$request = Request::createFromGlobals();
echo $request->getPathInfo();

You can also create a Request directly -- that's interesting for unit testing:

$request = Request::create('/?foo=bar', 'GET');
echo $request->getPathInfo();

And here is how to create and send a Response:

$response = new Response('Not Found', 404, array('Content-Type' => 'text/plain'));
$response->send();

The Request and the Response classes have many other methods that implement the HTTP specification.

Loading

If you are not using Composer but are using PHP 5.3.x, you must add the following to your autoloader:

// SessionHandlerInterface
if (!interface_exists('SessionHandlerInterface')) {
    $loader->registerPrefixFallback(__DIR__.'/../vendor/symfony/src/Symfony/Component/HttpFoundation/Resources/stubs');
}

Resources

You can run the unit tests with the following command:

$ cd path/to/Symfony/Component/HttpFoundation/
$ composer install
$ phpunit