2021-05-21 08:49:41 +02:00

174 lines
4.8 KiB
Markdown
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

# Http-Response
Die Response-Klassen dienen dazu eine gültige Response zu erstellen und an den Client zu senden.
Für die unterschiedliche Response-Arten gibt es mehrere Klassen um die Anwendung zu erleichtern:
* `Response` Universelle Klasse
* `FileResponse` Zum Senden von Dateien
* `JsonResponse` Zum Senden von JSON-Inhalten (z.B. für AJAX-Requests)
* `RedirectResponse` Zum Umleiten des Clients auf eine andere URL
## Response Klasse
Die Klasse `Response` wird für alle Response-Arten benutzt, für die keine spezielle Klasse existiert.
#### Beispiel
```php
use Xentral\Components\Http\Response;
$response = new Response('This is my response body.');
$response->setContentType('text/html', 'utf-8');
$response->addHeader('Cache-Control', 'no-cache');
$response->send();
```
### Überblick
1. Response erstellen
2. Eigene Header anfügen oder überschreiben
3. Response-Body setzen
4. Response an Client senden
### Response erstellen
```php
use Xentral\Components\Http\Response;
$response = new Response(
'This is my response Content.',
Response::HTTP_CREATED, //alle HTTP status Codes sind als Konstante verfügbar
['Cache-Control' => ['no-cache']],
'1.0',
'Created'
);
```
Erzeugt folgende Response:
```http request
HTTP/1.0 201 Created
Cache-Control: no-cache
Content-Type: text/html; charset=utf-8
Content-Length: 28
This is my response Content.
```
### Header hinzufügen/ändern
#### `addHeader`
Mit `addHeader('Header-Name', 'Value')` wird ein neuer Header bzw.
ein weiterer Wert zu einem bestehenden Header hinzugefügt.
**Hinweis:** Bei einigen Headern wie z.B. `Content-Type`, `Content-Length`, `Content-Disposition` und `Date` kann nur
ein Wert zugewiesen werden. Bei der Übergabe von mehreren Werten wird ein `InvalidArgumentException` geworfen.
#### `setHeader`
Mit `setHeader('Header-Name', ['Value1', 'value2])` wird ein neuer Header gesetzt und dabei ein
bestehender Header überschrieben. Hier können mehrere Werte in einem `array` übergeben werden.
### Response-Body setzen
Mit `setContent('Mein Inhalt als String')` wird der Response-Body gesetzt.
**Hinweis:** `setContent` berechnet und setzt zusätzlich den `Content-Length` Header. Wird `null` als Parameter
übergeben, so wird der `Content-Length` Header entfernt.
### Response an Client senden
Mit `send()` wird die Response abgeschickt. Vor dem Senden wird die Response noch modifiziert:
- Falls noch nicht vorhanden wird der `Date` Header gesetzt.
- Falls der Response-Body `null` ist, werden der `Content-Type`- und `Content-Length` Header entfernt.
## RedirectResponse Klasse
Die RedirectResponse-Klasse vereinfacht das Umleiten auf andere Seiten.
#### Beispiel
```php
use Xentral\Components\Http\Response;
use Xentral\Components\Http\RedirectResponse;
$redirect = RedirectResponse::createFromUrl('index.php?module=auftrag&action=list');
$redirect->setStatusCode(Response::HTTP_MOVED_PERMANENTLY);
$redirect->send();
```
Im Beispiel wird der Statuscode geändert. Per default ist `302 Found` als HTTP Status gesetzt.
## JsonResponse Klasse
Die JsonResponse Klasse vereinfacht das Erstellen von JSON-formatierten Antworten.
#### Beispiel
```php
use Xentral\Components\Http\JsonResponse;
$data = [
'data' => [
'id' => '1234',
'typ' => 'herr',
'name' => 'Max Mustermann',
]
];
$response = new JsonResponse($data);
```
Erzeugt folgende Response:
```http request
HTTP/1.1 200 OK
Content-Type: application/json; charset=utf-8
Content-Length: 59
{"data":{"id":"1234","typ":"herr","name":"Max Mustermann"}}
```
Als FileResponse kann ein `array` oder ein `JsonSerializable`-Objekt übergeben werden.
## FileResponse Klasse
Die FileResponse Klasse vereinfacht das Erstellen von Datei-Downloads.
### `FileResponse::createFromFile()`
Im folgenden Beispiel enthält `/tmp/file.txt` den Text `Hallo Welt`.
```php
use Xentral\Components\Http\FileResponse;
$fileResponse = FileResponse::createFromFile('/tmp/file.txt', 'download.txt');
```
Erzeugt folgende Response:
```http request
HTTP/1.1 200 OK
Content-Disposition: attachment; filename*="download.txt"; filename="download.txt"
Content-Type: text/plain; charset=utf-8
Content-Length: 20
Hallo Welt
```
Es wird versucht den Content-Type anhand des Mimetyps der Datei zu ermitteln. Falls die Erkennung fehlschlägt wird
der Content-Type auf `application/octet-stream` gesetzt. Der Content-Type kann mit `$response->setContentType()`
überschrieben werden.
### `FileResponse::createForcedDownload()`
Erzwingt den Download des Response-Contents. Das ist bei PDF's und Bildern besonders nützlich.
Diese werden im Browser oft im Viewer geöffnet anstatt heruntergeladen zu werden.
`createForcedDownload` setzt den Content-Type `application/force-download`, dadurch erhält der User
den "Speichern unter"-Dialog.