İstek nesnesine doğrudan bu şekilde erişme konusunda bazı uyarılar vardır \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
Otomatik olarak uzanan herhangi bir form denetleyicisine bu bağımlılık enjekte edilir ve aşağıdakiler kullanılarak erişilebilir:
$this->getRequest()->getSchemeAndHttpHost()
Genişleyen normal bir sayfa denetleyicisinin , işlevi geçersiz kılarak ve ardından yapıcıda bir özellik ayarlayarak hizmeti \Drupal\Core\Controller\ControllerBase
sağlayabileceğini düşünüyorum (ancak test etmedim) . Bu, formlar için gerçekten iyi tanımlanmıştır ve aynı işlem sayfa denetleyicileri için de geçerlidir: https://www.drupal.org/docs/8/api/services-and-dependency-injection/dependency-injection-for-a- oluştururlar .request_stack
\Drupal\Core\Controller\ControllerBase::create
$request