barkar@mail.ru
18.06.2014 - 09:27
Добрый день уважаемые форумчане!
Возник вопрос передачи ссылки на скачивания файла?
Есть плагин PHPExcel преобразование данных в MSExcel формат, на странице есть кнопка при нажатии на которую данные уходят AJAX->JSON в файл например phpexcel.php там происходит выборка данных с BD согласно пришедшим данным, затем идет преобразование $data_from_DB классом PHPExcel. Есть метод в этом классе который позволяет сохранить файл без его создания php://output, собственно вот и сам вопрос как передать его в родительский файл на котором была нажата кнопка.
Извините если где ошибся в формулировке!
T1grOK
18.06.2014 - 09:44
PHPExcel также позволяет сохранить результат в файл.
_____________
Mysql, Postgresql, Redis, Memcached, Unit Testing, CI, Kohana, Yii, Phalcon, Zend Framework, Joomla, Open Cart, Ymaps, VK Api
barkar@mail.ru
18.06.2014 - 09:50
Так это я знаю и умею, а именно нужно передать ссылку на поток созданный в буфере то-есть Excel (без создания файла).
T1grOK
18.06.2014 - 09:58
Ну так создайте ссылку на скрипт, который генерирует excell.
_____________
Mysql, Postgresql, Redis, Memcached, Unit Testing, CI, Kohana, Yii, Phalcon, Zend Framework, Joomla, Open Cart, Ymaps, VK Api
barkar@mail.ru
18.06.2014 - 10:02
Не знаю как!
Int_20h
18.06.2014 - 12:01
Может не до конца понимаю задачу, но я схожую проблему решаю так.
Файл 1: Скрипт, который создает несколько Excel отчетов. Когда он заказчивает свою работы выводит в конце <a href="2.php">Ссылка на скачивание отчетов</a>
Файл 2: Файл 2.php содержит:
<?
$zip = new ZipArchive;
define('DIR','reports_not_finished');
$filename = DIR.'/'.time().'.zip';
$res = $zip->open($filename, ZipArchive::OVERWRITE);
$fls = scandir(DIR);
foreach ($fls as $current_file)
{
if (stristr($current_file, '.xlsx') !== FALSE) $zip->addFile(DIR.'/'.$current_file, $current_file);
}
$zip->close();
header('Content-Description: File Transfer');
header('Content-Type: application/octet-stream');
header('Content-Disposition: attachment; filename="NotFinished_'.date('d-m-Y-H-i').'.zip"');
header('Content-Transfer-Encoding: binary');
header('Expires: 0');
header('Cache-Control: must-revalidate, post-check=0, pre-check=0');
header('Pragma: public');
header('Content-Length: ' . filesize($filename));
ob_clean();
flush();
readfile($filename);
unlink($filename);
?>
Вроде задача решена. Так ли уж нужно возвращать Excel в предыдущий php?
Быстрый ответ:
Powered by dgreen
Здесь расположена полная версия этой страницы.