Zend_Rest_Route Die Komponente Zend_Rest enthält eine RESTvolle Route für Zend_Controller_Router_Rewrite. Diese Route bietet ein standartisiertes Routing Schema das Routinganfragen durch Übersetzung der HTTP Methode und der URI zu einem Modul, Controller und einer Action. Die unten stehende Tabelle bietet eine Übersicht darüber wie Anfragemethoden und URI's geroutet werden. Verhalten von Zend_Rest_Route Methode URI Module_Controller::action GET /product/ratings/ Product_RatingsController::indexAction() GET /product/ratings/:id Product_RatingsController::getAction() POST /product/ratings Product_RatingsController::postAction() PUT /product/ratings/:id Product_RatingsController::putAction() DELETE /product/ratings/:id Product_RatingsController::deleteAction() POST /product/ratings/:id?_method="PUT" Product_RatingsController::putAction() POST /product/ratings/:id?_method="DELETE" Product_RatingsController::deleteAction()
Um Zend_Rest_Route für eine komplette Anwendung einzuschalten muss diese ohne Konfigurationsparameter erstellt und als Standardroute dem Frontcontroller hinzugefügt werden: getRouter()->addRoute('default', $restRoute); ]]> Wenn Zend_Rest_Route keinem gültigen Modul, Controller oder keiner Action entspricht gibt diese FALSE zurück und der Router versucht eine Entsprechung zu finden indem die nächste Route im Router verwendet wird. Um Zend_Rest_Route für spezielle Module einzuschalten muss diese mit einem Array von Modulnamen als 3tes Argument des Constructors erstellt werden: getRouter()->addRoute('rest', $restRoute); ]]> Um Zend_Rest_Route für spezielle Controller einzuschalten muss ein Array von Controllernamen als Wert für jedes Modul (Arrayelement) hinzugefügt werden. array('ratings') )); $front->getRouter()->addRoute('rest', $restRoute); ]]> Zend_Rest_Controller Um bei der Entwicklung von Controllern zu Hilfe zu sein die mit Zend_Rest_Route verwendet werden, müssen die Controller von Zend_Rest_Controller erweitert werden. Zend_Rest_Controller definiert die 5 am meisten benötigten Operationen für RESTvolle Ressourcen in der Form von abstrakten Actionmethoden. indexAction() - Sollte einen Index von Ressourcen empfangen und diese mit der View verknüpfen. getAction() - Sollte eine einzelne Ressource empfangen die von einer URI identifiziert wird und diese mit der Vew verknüpfen. postAction() - Sollte eine einzelne neue Ressource akzeptieren und dessen Status persistent machen. putAction() - Sollte eine einzelne Ressource akzeptieren die von einer URI identifiziert wird und dessen Status persistent machen. deleteAction() - Sollte eine einzelne Ressource löschen die von einer URI identifiziert wird.