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
Fabien Potencier 2314328b16 Merge branch '2.4'
* 2.4:
  fixed types in phpdocs
  fixed types in phpdocs

Conflicts:
	src/Symfony/Component/Security/Core/Encoder/BasePasswordEncoder.php
	src/Symfony/Component/Security/Http/RememberMe/TokenBasedRememberMeServices.php
	src/Symfony/Component/Serializer/Encoder/JsonEncoder.php
	src/Symfony/Component/Serializer/Normalizer/GetSetMethodNormalizer.php
	src/Symfony/Component/Validator/Mapping/ClassMetadata.php
	src/Symfony/Component/Validator/Mapping/ElementMetadata.php
	src/Symfony/Component/Validator/Mapping/MemberMetadata.php
	src/Symfony/Component/Validator/MetadataFactoryInterface.php
2014-04-16 12:36:21 +02:00
..
File Merge branch '2.3' into 2.4 2014-04-16 12:34:31 +02:00
Resources/stubs fixed types in phpdocs 2014-04-16 12:30:19 +02:00
Session fixed types in phpdocs 2014-04-16 12:34:42 +02:00
Tests Merge branch '2.4' 2014-04-16 10:08:40 +02:00
.gitignore Added missing files .gitignore 2013-07-21 14:12:18 +02:00
AcceptHeader.php fixed types in phpdocs 2014-04-16 12:30:19 +02: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 Merge branch '2.3' into 2.4 2014-04-16 10:02:57 +02:00
CHANGELOG.md [HttpFoundation] Add ability to change JSON encoding options 2014-01-07 13:28:26 +01:00
composer.json Merge branch '2.4' 2014-03-26 12:51:10 +01:00
Cookie.php fixed types in phpdocs 2014-04-16 12:30:19 +02:00
ExpressionRequestMatcher.php [HttpFoundation] added ExpressionRequestMatcher 2013-09-19 12:59:11 +02:00
FileBag.php [HttpFoundation] fixed typo 2014-01-28 16:07:56 +01:00
HeaderBag.php Merge branch '2.3' into 2.4 2014-04-16 12:34:31 +02:00
IpUtils.php fixed types in phpdocs 2014-04-16 12:30:19 +02:00
JsonResponse.php made types consistent with those defined in Hack 2014-04-16 10:09:01 +02:00
LICENSE update year on licenses 2014-01-07 08:19:25 -05:00
ParameterBag.php Merge branch '2.3' into 2.4 2014-04-16 12:34:31 +02:00
phpunit.xml.dist made usage of Composer autoloader for subtree-split unit tests 2012-11-09 14:10:06 +01:00
README.md updated the composer install command to reflect changes in Composer 2013-09-18 09:27:26 +02:00
RedirectResponse.php made {@inheritdoc} annotations consistent across the board 2014-04-16 09:04:20 +02:00
Request.php Merge branch '2.3' into 2.4 2014-04-16 12:34:31 +02:00
RequestMatcher.php fixed CS 2013-07-01 14:24:43 +02:00
RequestMatcherInterface.php fixed types in phpdocs 2014-04-16 12:30:19 +02:00
RequestStack.php [HttpKernel] made request stack feature BC 2013-09-17 18:23:22 +02:00
Response.php Merge branch '2.3' into 2.4 2014-04-16 12:34:31 +02:00
ResponseHeaderBag.php [HttpFoundation] Fixed messed up headers 2013-02-26 10:42:13 +01:00
ServerBag.php Merge branch '2.2' into 2.3 (closes #8955) 2013-09-07 18:30:19 +02:00
StreamedResponse.php made types consistent with those defined in Hack 2014-04-16 10:04:32 +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.phar install
$ phpunit