0

Bootstrap以下は、私のクラスで定義された関数です。Zend がルーティングとディスパッチを行う方法について、何か根本的なことが欠けているに違いありません。私が達成しようとしていることは簡単です。/foo/bar/*何らかの理由でディスパッチできないリクエストについては、 を試してください/index/foo/bar/。私が抱えている問題は、 がFooController存在するときですAction "foo" does not exist。基本的に、isDispatchableは常に false です。

public function run() {
        $front = Zend_Controller_Front::getInstance();
        $request = $front->getRequest();
        $dispatcher = $front->getDispatcher();
        //$controller = $dispatcher->getControllerClass($request);
        if (!$dispatcher->isDispatchable($request)) {
            $route = new Zend_Controller_Router_Route(
                ':action/*',
                array('controller' => 'index')
            );
            $router = $front->getRouter();
            $router->addRoute('FallBack', $route);
        }
        $front->dispatch();
    }
4

2 に答える 2

0

私があなたの考えを正しく理解しているなら、__call魔法の方法を使ってみませんか?? 次に$this->_redirect();、たとえばデフォルトのアクションに使用します

詳細はこちらhttp://php.net/manual/en/language.oop5.overloading.php

アップデート

480 行目で Zend/Controller/Action.php を開いた場合

public function __call($methodName, $args)
    {
        require_once 'Zend/Controller/Action/Exception.php';
        if ('Action' == substr($methodName, -6)) {
            $action = substr($methodName, 0, strlen($methodName) - 6);
            throw new Zend_Controller_Action_Exception(sprintf('Action "%s" does not exist and was not trapped in __call()', $action), 404);
        }

        throw new Zend_Controller_Action_Exception(sprintf('Method "%s" does not exist and was not trapped in __call()', $methodName), 500);
    }

私が意図したことは、このクラスを拡張し、 __call関数を正確にオーバーライドすることです

classs My_Controller_Action extends Zend_Controller_Action{
   public function __call($methodName, $args)
        {
            ///// do your magic here ......redirection or logging the request or what ever 
        }
}

コントローラーが新しく作成したクラスを拡張していることを確認してください

class FooController extends My_Controller_Action
{
   public function indexAction()
    {
        // action body
    }
}

したがって、存在しないアクションと呼ばれる方法__callが実行される場合、このアイデアは存在しないアクションに関するものであり、コントローラーが存在しない場合は機能しません

于 2010-04-27T19:00:34.313 に答える
0

したがって、これは機能しているように見えますが、単にすべてのパラメーターを削除するだけなので、最良の答えではありません。/index/[original uri]プラグイン内で転送をすぐに試してみるかもしれません:

class Bootstrap extends Zend_Application_Bootstrap_Bootstrap {
  protected function _initRoute() {
    $front = Zend_Controller_Front::getInstance();
    $routes = array(
      'FallBack' => new Zend_Controller_Router_Route(
        ':controller/:action/*',
        array('controller' => 'index', 'action' => 'index')
      )
    );
    $router = $front->getRouter();
    $router->removeDefaultRoutes();
    $router->addRoutes($routes);
    $front->setRouter($router);
    return $router;
  }

  protected function _initPlugin() {
    $front = Zend_Controller_Front::getInstance();
    $front->registerPlugin(new My_Controller_Plugin_FallBack());
  }
    }

class My_Controller_Plugin_FallBack extends Zend_Controller_Plugin_Abstract {
  public function preDispatch(Zend_Controller_Request_Abstract $request) {
    $front = Zend_Controller_Front::getInstance();
    $dispatcher = $front->getDispatcher();
    $router = $front->getRouter();
    if (($router->getCurrentRouteName() == 'FallBack') &&
        !$dispatcher->isDispatchable($request)) {
      $request->setActionName($request->getControllerName());
      $request->setControllerName('index');
    }
  }
}
于 2010-04-28T20:21:23.333 に答える