从zend框架中的mssql db下载blob(type:image)

时间:2011-01-05 14:57:52

标签: php sql-server zend-framework zend-server

我该怎么办?我曾尝试使用file_put_contents(),但它创建了一个损坏的文件。

我现在正在尝试使用正确的标头设置视图以使其正常工作。

<?php   
    header('Content-Type: image/jpeg');
    header('Content-Transfer-Encoding: base64');
    echo $this->dokument->Dokument;

这是我的控制器的内容:

public function imageAction()
{   
    $id = $this->_getParam('id'); 

    $dokumentTabell = new Ordre_Model_Table_OrdreDokument();
    $dokument = $dokumentTabell->find($id)->current();
    $this->view->dokument = $dokument;

    // disable layout and view
    $this->view->layout()->disableLayout();
}

根据此处的第一个答案编辑后,它会显示以下错误消息:PHP致命错误:在... \ application \ modules \ ordre \ controllers \ OrdreController中的非对象上调用成员函数setHttpResponseCode()第45行的.php

第45行是这样的:

     ->setHttpResponseCode(200)

其余代码:

public function imageAction()
{   
$id = $this->_getParam('id'); 

$dokumentTabell = new Ordre_Model_Table_OrdreDokument();
$dokument = $dokumentTabell->find($id)->current();
$this->view->dokument = $dokument;
$filename = $dokument->Name.".".$dokument->FileExtension;
// disable layout and view
$this->view->layout()->disableLayout();
$this->_helper->viewRenderer->setNoRender(true);

$this->getResponse()
     ->clearAllHeaders()
     ->clearBody()
     ->setHttpResponseCode(200)
     ->setHeader('Content-Type', 'image/jpeg')
     ->setHeader('Content-Length', strlen($dokument->Dokument))
     ->setHeader(
        'Content-Disposition',
        "attachment;filename=\"{$filename}\""
     )
     ->setHeader('Last-Modified', $dokument->SistEndret)
     ->setBody($dokument->Dokument);
}

如果我删除第44行: - &gt; clearBody(),则代码“有效”。我得到的文件名称正确,大小合适。

1 个答案:

答案 0 :(得分:0)

在我看来,视图永远不应该输出标题..对我来说,感觉更像是控制器的事情。此外,在控制器中,您可以访问响应对象,该对象具有设置标头的方法。

此外,是$dokument->Dokument base64编码的吗?否则,只需跳过该标题。

我可能会做类似的事情:

public function imageAction()
{   
    $id = $this->_getParam('id'); 

    $dokumentTabell = new Ordre_Model_Table_OrdreDokument();
    $dokument = $dokumentTabell->find($id)->current();
    $this->view->dokument = $dokument;

    // disable layout and view
    $this->_helper->Layout()->disableLayout();
    $this->_helper->ViewRenderer->setNeverRender();

    $this->getResponse()
         ->clearAllHeaders()
         ->clearBody()
         ->setHttpResponseCode(200)
         ->setHeader('Content-Type', 'image/jpeg')
         ->setHeader('Content-Length', strlen($dokument->Dokument))
         ->setHeader(
            'Content-Disposition',
            "attachment;filename=\"{$dokument->filename}\""
         )
         ->setHeader('Last-Modified', $dokument->lastModified)
         ->setBody($dokument->Dokument);
}