我一直在读Slim v2,$ app被绑定到中间件类。我发现v3不是这样的情况?下面是我的中间件类,但我只是未定义:
<?php
namespace CrSrc\Middleware;
class Auth
{
/**
* Example middleware invokable class
*
* @param \Psr\Http\Message\ServerRequestInterface $request PSR7 request
* @param \Psr\Http\Message\ResponseInterface $response PSR7 response
* @param callable $next Next middleware
*
* @return \Psr\Http\Message\ResponseInterface
*/
public function __invoke($request, $response, $next)
{
// before
var_dump($this->getContainer()); // method undefined
var_dump($this->auth); exit; // method undefined
if (! $this->get('auth')->isAuthenticated()) {
// Not authenticated and must be authenticated to access this resource
return $response->withStatus(401);
}
// pass onto the next callable
$response = $next($request, $response);
// after
return $response;
}
}
在中间件中访问DI容器的正确方法是什么?我猜应该有办法吗?
答案 0 :(得分:25)
派对有点晚,但可能会帮助别人...... 在实例化中间件时必须注入容器
$container = $app->getContainer();
$app->add(new Auth($container));
您的中间件需要构造函数
<?php
namespace CrSrc\Middleware;
class Auth
{
private $container;
public function __construct($container) {
$this->container = $container
}
/**
* Example middleware invokable class
*
* @param \Psr\Http\Message\ServerRequestInterface $request PSR7 request
* @param \Psr\Http\Message\ResponseInterface $response PSR7 response
* @param callable $next Next middleware
*
* @return \Psr\Http\Message\ResponseInterface
*/
public function __invoke($request, $response, $next)
{
// $this->container has the DI
}
}
LE: 如果您将中间件作为类字符串
提供,那么容器会得到injected in the constructor,从而扩展初始答案。$app->add('Auth');
或
$app->add('Auth:similarToInvokeMethod')
答案 1 :(得分:-1)
据我了解代码,Slim(v3)的工作方式如下:
bindTo
。如果你传递一个解析为类的类/字符串,那么Slim会创建实例并将容器作为param传递给构造函数
<?php
$app->add(Auth);
否则(例如,如果你添加了之前创建的中间件实例),那么看起来你必须要处理所有必要的引用。