[PHP] Modernes Beispiel für 403 und 404 Handling in TYPO3

[PHP] Modernes Beispiel für 403 und 404 Handling in TYPO3

Wenn ihr ein individuelles 403 oder 404 Handling in TYPO3 9 oder neuer benötigt, werdet ihr eventuell hier fündig. So möchte man eventuell einen 404 Status ausliefern, aber die falsche URL behalten? Oder ihr benötigt eine Weiterleitung auf eine Login-Seite wenn man versucht eine geschützte Seite im Frontend aufzurufen?

config.yaml:

base: 'https://%env(HOST)%/' baseVariants: { } errorHandling: - errorCode: '403' errorHandler: PHP errorPhpClassFQCN: Vendor\Sitepackage\PageHandler\NotAuthorized - errorCode: '404' errorHandler: PHP errorPhpClassFQCN: Vendor\Sitepackage\PageHandler\NotFound

NotAuthorized.php:

<?php declare(strict_types=1); namespace Vendor\Sitepackage\PageHandler; use Psr\Http\Message\ResponseInterface; use Psr\Http\Message\ServerRequestInterface; use TYPO3\CMS\Core\Error\PageErrorHandler\PageErrorHandlerInterface; use TYPO3\CMS\Core\Http\RedirectResponse; use TYPO3\CMS\Core\Http\Uri; use TYPO3\CMS\Core\Site\Entity\Site; use TYPO3\CMS\Core\Site\Entity\SiteLanguage; use TYPO3\CMS\Core\Site\SiteFinder; use TYPO3\CMS\Core\Utility\GeneralUtility; /** * Class NotAuthorized * to show a login page (in fitting language) and redirect to page after login * @noinspection PhpUnused */ class NotAuthorized implements PageErrorHandlerInterface { /** * @var int */ protected $pageLoginUid = 167; /** * @var ServerRequestInterface */ protected $request = null; /** * @param ServerRequestInterface $request * @param string $message * @param array $reasons * @return ResponseInterface */ public function handlePageError( ServerRequestInterface $request, string $message, array $reasons = [] ): ResponseInterface { $this->request = $request; return new RedirectResponse($this->getLoginUrl(), 302); } /** * @return string */ protected function getLoginUrl(): string { /** @var Site $site */ $siteFinder = GeneralUtility::makeInstance(SiteFinder::class); $site = $siteFinder->getSiteByPageId($this->pageLoginUid); /** @var Uri $uri */ $uri = $site->getRouter()->generateUri( $this->pageLoginUid, [ '_language' => $this->getLanguageIdentifier(), 'redirect_url' => $this->request->getUri()->__toString() ] ); return $uri->__toString(); } /** * @return int */ protected function getLanguageIdentifier(): int { /** @var SiteLanguage $language */ $language = $this->request->getAttribute('language'); return $language->getLanguageId(); } }

NotFound.php:

<?php declare(strict_types=1); namespace Vendor\Sitepackage\PageHandler; use Psr\Http\Message\ResponseInterface; use Psr\Http\Message\ServerRequestInterface; use TYPO3\CMS\Core\Error\PageErrorHandler\PageErrorHandlerInterface; use TYPO3\CMS\Core\Http\HtmlResponse; use TYPO3\CMS\Core\Http\RequestFactory; use TYPO3\CMS\Core\Http\Uri; use TYPO3\CMS\Core\Site\Entity\Site; use TYPO3\CMS\Core\Site\Entity\SiteLanguage; use TYPO3\CMS\Core\Utility\GeneralUtility; /** * Class NotFound * to show a 404 page (in fitting language) * @noinspection PhpUnused */ class NotFound implements PageErrorHandlerInterface { /** * @var int */ protected $pageNotFoundUid = 133525; /** * @var ServerRequestInterface */ protected $request = null; /** * @param ServerRequestInterface $request * @param string $message * @param array $reasons * @return ResponseInterface * @throws RequestFailedException */ public function handlePageError( ServerRequestInterface $request, string $message, array $reasons = [] ): ResponseInterface { $this->request = $request; return new HtmlResponse($this->getPageNotFoundContent(), 404); } /** * @return string * @throws RequestFailedException */ protected function getPageNotFoundContent(): string { $url = $this->getPageNotFoundUrl(); $requestFactory = GeneralUtility::makeInstance(RequestFactory::class); /** @var ResponseInterface $response */ $response = $requestFactory->request($url, 'GET'); if ($response->getStatusCode() === 200) { if (strpos($response->getHeaderLine('Content-Type'), 'text/html') === 0) { return $response->getBody()->getContents(); } } throw new \LogicException('Could not read content of ' . $url, 1594134183); } /** * @return string */ protected function getPageNotFoundUrl(): string { /** @var Site $site */ $site = $this->request->getAttribute('site'); /** @var Uri $uri */ $uri = $site->getRouter()->generateUri($this->pageNotFoundUid, ['_language' => $this->getLanguageIdentifier()]); return $uri->__toString(); } /** * @return int */ protected function getLanguageIdentifier(): int { /** @var SiteLanguage $language */ $language = $this->request->getAttribute('language'); return $language->getLanguageId(); } }

TYPO3: Unbenutzte Dateien im fileadmin finden

Ihr wollt unbenutzte oder verwaiste Dateien im fileadmin oder einer anderen Storage löschen? Leider gibt es hier nichts direkt vom Core. Aber ein kleiner Command in eurem Sitepackage hilft schnell...

Zum Beitrag

TYPO3: Redakteure mit individuellen user_upload Folder

Vielleicht kennt ihr die Kundenanforderung? Redakteure sollen Videos über den Button "Add media by URL" hinzufügen können. Aber die Dateien sollen sich dann nicht in fileadmin/user_upload/ sondern in...

Zum Beitrag

TYPO3: Seiten im Mixed Mode finden

Mixed Mode bezeichnet man in TYPO3 übersetzte Seiten, auf denen sich Seiteninhalte befinden, die nur zum Teil eine Relation auf entsprechende Seiteninhalte in der Hauptsprache haben. Dies wird im...

Zum Beitrag

Extbase Extensions: An Erweiterbarkeit denken mit data, site und language

Heute mal eine kleine Bitte an die TYPO3-Extension-Autoren da draußen: Achtet auf Erweiterbarkeit eurer Extensions. Dies fördert dann auch die Verbreitung der entsprechenden Plugins.

Zum Beitrag

SQL: Zeige alle Tabellen absteigend nach Größe sortiert

Ich brauche in letzter Zeit häufiger den SQL-Befehl, um herauszufinden, welche Tabellen in der TYPO3-Datenbank am größten sind. Ich habe das Snippet einmal veröffentlicht.

Zum Beitrag

TYPO3 12 mit CKEditor 5: Stile als Einfachauswahl

Wenn man im RTE in TYPO3 einen Link setzt, kann es sein, dass man zwischen verschiedenen Link-Klassen auswählen muss, um beispielsweise Buttons im Frontend zu erzeugen. Neu ist in TYPO3 12 dass man...

Zum Beitrag