我想做的事 :
用户点击了一个网址(例如:BASE-URL / download / json).
代码从数据库中获取大量数据并将其流式传输到JSON文件中,并提示用户下载该文件.
我尝试了什么:
创建了一个大型(700 MB)JSON文件.
尝试用代码打开它,但是抛出了错误.
file_get_contents($file)
错误:
Allowed memory size of XXX bytes exhausted (tried to allocate YYY
bytes)
我在Symfony2工作.数据大小可达700MB.无法增加分配的内存.
我怎样才能做到这一点?如果需要任何进一步的信息,请评论.
解决方法:
在上述所有评论的帮助下,我能够实现我想要的目标.
这是相同的代码.
$response = new StreamedResponse();
$i = -999999;
$response->setCallback(function () {
while($i < 999999){
echo '{"G1ello":"hualala"}';
$i = $i + 1;
}
});
$filename = "Data.json";
$contentdisposition = $response->headers->makedisposition(ResponseHeaderBag::disPOSITION_ATTACHMENT, $filename);
$response->headers->set('Content-Type', 'application/json');
$response->headers->set('Content-disposition', $contentdisposition);
return $response;
它创建了一个我可以下载的大文件.正是我想要的.发布解决方案,以便它可以帮助有相同问题的人.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。