Download de arquivo através do AJAX POST
Estou tentando fornecer um download simples usando a solicitação AJAX POST. Um usuário clica em um<span>
e o download começa (ou uma caixa de diálogo de download aparece, dependendo do navegador). Eu implementei tudo isso, mas a resposta do AJAX não ativa nenhum comportamento de download do navegador e não sei por quê.
Aqui está meu código:
HTML / galho:
<span id="export_csv">csv - click me to download the file</span>
javascript:
<script type="text/javascript">
$(document).ready(function() {
$('#export_csv').click(function(){
var params = "some params";
$.ajax({
type: 'POST',
url: "{{path('ExportBundle_export', {'format': 'csv','report' : 'basic'})}}",
data: params
});
});
});
</script>
Código do controlador (symfony2, mas não importa aqui):
$response = new Response(file_get_contents($document->getPath()));
$response->setStatusCode(200);
$response->headers->set('Content-Type', $document->getMime());
$response->headers->set('Content-Description', 'Submissions Export');
$response->headers->set('Content-Disposition', 'attachment; filename='
. $filename . '.' . $format);
$response->headers->set('Content-Transfer-Encoding', 'binary');
$response->headers->set('Pragma', 'no-cache');
$response->headers->set('Expires', '0');
return $response;
Este é um exemplo de solicitação:
Request URL:http://myapp.local/app_dev.php/export/basic/csv
Request Method:POST
Status Code:200 OK
e cabeçalhos de resposta:
cache-control:private, must-revalidate
Connection:close
content-description:Submissions Export
content-disposition:attachment; filename=report_1363013244.csv
Content-Length:790
content-transfer-encoding:binary
Content-Type:text/csv; charset=UTF-8
Date:Mon, 11 Mar 2013 14:47:24 GMT
expires:0
pragma:no-cache
Server:Apache/2.2.22 (Ubuntu)
x-debug-token:513dee7c99fdb
X-Powered-By:PHP/5.3.10-1ubuntu3.5
Eu verifiqueiNetwork
na barra de ferramentas do Google Chrome firebug-alike e a resposta é exatamente igual ao arquivo. Talvez haja algo errado com meus cabeçalhos, mas eu os verifiquei duas vezes ...
PS 1
Eu gostaria de fazer isso usando AJAX (eu prefiro mais do que criar um formulário HTML).
PS 2
Eu tenho muitos parâmetros na camada do lado do cliente (javascript). Eu preciso de todos eles para estar disponível no controlador (script do lado do servidor). Ao usar o AJAX, eu simplesmente os passo nodata
chave.