我正在研究一个在 Module.php 中调用并附加到引导程序的 ACL。
显然,ACL 限制了对站点某些区域的访问,这就需要重定向。但是,当尝试使用控制器插件进行重定向时,它不起作用,因为插件似乎需要控制器。
从控制器外部重定向到外部的最佳方法是什么?vanilla header() 函数不适合,因为我需要使用已定义的路由。
任何帮助都会很棒!
干杯-
我正在研究一个在 Module.php 中调用并附加到引导程序的 ACL。
显然,ACL 限制了对站点某些区域的访问,这就需要重定向。但是,当尝试使用控制器插件进行重定向时,它不起作用,因为插件似乎需要控制器。
从控制器外部重定向到外部的最佳方法是什么?vanilla header() 函数不适合,因为我需要使用已定义的路由。
任何帮助都会很棒!
干杯-
通常,您希望通过返回响应来缩短调度过程。期间route
或dispatch
您可以返回响应以停止通常的代码流停止并直接完成结果。在 ACL 检查的情况下,您很可能希望尽早返回该响应并重定向到用户的登录页面。
您要么在控制器中构造响应,要么检查插件的返回值并在响应时重定向。注意第二种方法类似于PRG 插件的工作方式。
第一种方法的示例:
use Zend\Mvc\Controller\AbstractActionController;
class MyController extends AbstractActionController
{
public function fooAction()
{
if (!$this->aclAllowsAccess()) {
// Use redirect plugin to redirect
return $this->redirect('user/login');
}
// normal code flow
}
}
像 PRG 插件这样的例子可以工作:
use Zend\Mvc\Controller\AbstractActionController;
use Zend\Http\Response;
class MyController extends AbstractActionController
{
public function fooAction()
{
$result = $this->aclCheck();
if ($result instanceof Response) {
// Use return value to short-circuit
return $result
}
// normal code flow
}
}
然后插件可能看起来像这样(在第二种情况下):
use Zend\Mvc\Controller\Plugin\AbstractPlugin;
class AclCheck extends AbstractPlugin
{
public function __invoke()
{
// Check the ACL
if (false === $result) {
$controller = $this->getController();
$redirector = $controller->getPluginManager()->get('Redirect');
$response = $redirector->toRoute('user/login');
return $response;
}
}
}
在您的问题中,您说:
[...] 它不起作用,因为插件似乎需要控制器。
当您想$this->getController()
在插件中执行此操作时,这可能是控制器插件内部的问题。您必须扩展Zend\Mvc\Controller\Plugin\AbstractPlugin
或实现Zend\Mvc\Controller\Plugin\PluginInterface
以确保您的 ACL 插件与控制器一起注入。
如果您不希望这样做,则可以直接返回您自己创建的响应。它不太灵活,您在已经有响应对象的情况下创建响应对象(导致两个响应可能发生冲突),但插件代码将更改如下:
use Zend\Mvc\Controller\Plugin\AbstractPlugin;
use Zend\Http\PhpEnvironment\Response;
class AclCheck extends AbstractPlugin
{
public function __invoke()
{
// Check the ACL
if (false === $result) {
$response = new Response;
$response->setStatusCode(302);
$response->getHeaders()
->addHeaderLine('Location', '/user/login');
return $response;
}
}
}