Um JSON mit dem Zend auszuliefern, könnte man auf die harte Tour, Header selbst setzen, Daten enkodieren und layouts deaktvieren oder man nutzt Funktionalitäten, die das Framework schon bietet. Um zum Beispiel JSON direkt zu senden, bedient man sich Zend_Controller_Action_Helper_Json:
class TestController extends Zend_Controller_Action
{
public function indexAction()
{
$data = array(
'test' => true
);
/**
* Call Zend_Controller_Action_Helper_Json::direct
*/
$this->_helper->json($data);
}
}
Über die Url ../test erhalten wir die Ausgabe in JSON inklusive dem korrekten Content-type application/json.
Nachteil dieses Aufruf ist, dass die dispatch loop sofort unterbrochen wird und somit eventuelle Erweiterungen durch Plugins nicht mehr aufgerufen werden.
Besser ist es, den ContextSwitch Action-Helfer zu benutzen, welcher XML und JSON unterstützt, layouts deaktiviert und Header enstrechend setzt:
class TestController extends Zend_Controller_Action
{
public function init()
{
$this->_helper
->contextSwitch()
->addActionContext('index', 'json')
->initContext();
}
public function indexAction()
{
$this->view->test = true;
}
}
Die JSON-Ausgabe ist nun über die Url ../test?format=json erreichbar.
Um sich den format-Parameter zu sparen, kann man für alle actions im Controller das json-Format erzwingen:
public function init()
{
/**
* Force json format
*/
$this->_request->setParam('format', 'json');
...
}
Zum weiterlesen: Zend ContextSwitch
0 Kommentare
Trackbacks/Pingbacks