|
|
14 years ago | |
|---|---|---|
| .. | ||
| File | 14 years ago | |
| SessionStorage | 14 years ago | |
| ApacheRequest.php | 14 years ago | |
| Cookie.php | 14 years ago | |
| FileBag.php | 14 years ago | |
| HeaderBag.php | 14 years ago | |
| ParameterBag.php | 14 years ago | |
| README.md | 14 years ago | |
| RedirectResponse.php | 14 years ago | |
| Request.php | 14 years ago | |
| RequestMatcher.php | 14 years ago | |
| RequestMatcherInterface.php | 14 years ago | |
| Response.php | 14 years ago | |
| ResponseHeaderBag.php | 14 years ago | |
| ServerBag.php | 14 years ago | |
| Session.php | 14 years ago | |
| composer.json | 14 years ago | |
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.
Unit tests:
https://github.com/symfony/symfony/tree/master/tests/Symfony/Tests/Component/HttpFoundation