Існує кілька попереджень щодо прямого доступу до об'єкта запиту таким чином \Drupal::request
:
* Note: The use of this wrapper in particular is especially discouraged. Most
* code should not need to access the request directly. Doing so means it
* will only function when handling an HTTP request, and will require special
* modification or wrapping when run from a command line tool, from certain
* queue processors, or from automated tests.
*
* If code must access the request, it is considerably better to register
* an object with the Service Container and give it a setRequest() method
* that is configured to run when the service is created. That way, the
* correct request object can always be provided by the container and the
* service can still be unit tested.
Будь-який контролер форми, що розширюється, \Drupal\Core\Form\FormBase
автоматично вводить цю залежність, і до неї можна отримати доступ, використовуючи:
$this->getRequest()->getSchemeAndHttpHost()
Я думаю (але не перевіряв), що звичайний контролер сторінки, що розширюється, \Drupal\Core\Controller\ControllerBase
може надавати request_stack
послугу, змінивши \Drupal\Core\Controller\ControllerBase::create
функцію, а потім встановивши $request
властивість у конструкторі. Це описано дуже добре для форм, і той самий процес повинен застосовуватися і до контролерів сторінок: https://www.drupal.org/docs/8/api/services-and-dependency-injection/dependency-injection-for-a- форма .