PluginでZendFrameworkにRESTful viewを付ける
ZF 1を使用する.0の場合、MVCモードのviewテンプレートのデフォルトはphtmlであり、RESTインタフェースは顧客の要求に応じてAcceptプロトコルヘッダに異なるフォーマットの結果を返す必要があることが分かった.Framework全体を考察すると,Pluginで異なるViewテンプレートの選択を簡単に実現できることが分かった.Pluginのコードは次のとおりです.
indexでいいです.phpでは、次のように使用されます.
これによりRestful clientがAccept:text/xmlであると受信.pxmlテンプレートの内容.
<?php
/**
* Choose correct view for RESTful client
*
* @author lht
* @version
*/
final class Restful extends Zend_Controller_Plugin_Abstract {
public function preDispatch(Zend_Controller_Request_Abstract $request) {
$viewRenderer = Zend_Controller_Action_HelperBroker::getStaticHelper('viewRenderer');
if (preg_match('/text\/xml/i', $request->getHeader('Accept'))) {
$this->getResponse()->setHeader('Content-Type', 'text/xml; charset=utf-8');
$viewRenderer->setViewSuffix('pxml');
} elseif (preg_match('/application\/json/i', $request->getHeader('Accept'))) {
$this->getResponse()->setHeader('Content-Type', 'application/json; charset=utf-8');
$viewRenderer->setViewSuffix('pjson');
} elseif (preg_match('/text\/plain/i', $request->getHeader('Accept'))) {
$this->getResponse()->setHeader('Content-Type', 'text/plain; charset=utf-8');
$viewRenderer->setViewSuffix('ptxt');
}
}
}
indexでいいです.phpでは、次のように使用されます.
$controller = Zend_Controller_Front::getInstance();
$controller->setControllerDirectory('../application/default/controllers');
$controller->throwExceptions(false); // should be turned on in development time
$controller->registerPlugin(new Restful());
これによりRestful clientがAccept:text/xmlであると受信.pxmlテンプレートの内容.