Форум программистов, компьютерный форум, киберфорум
PHP для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.83/6: Рейтинг темы: голосов - 6, средняя оценка - 4.83
1 / 1 / 2
Регистрация: 20.10.2011
Сообщений: 154

Readfile и архив

19.04.2016, 06:01. Показов 1197. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Товарищи, такая проблема - Нужно возвращать пользователю файлы отчетов. Выгрузка, грубо говоря, счета, общей накладной и накладной по складам.
При формировании счета (в PDF) и общей накладной (xls) проблем не возникает. Вот такая конструкция возвращает все корректно:
PHP
1
2
3
4
5
6
7
8
9
10
11
ob_end_clean();
header('Content-Description: File Transfer');
header('Content-Type: application/octet-stream');
header('Content-Disposition: attachment; filename=' . $ORDER . '.xls');
header('Content-Transfer-Encoding: binary');
header('Expires: 0');
 header('Cache-Control: must-revalidate');
header('Pragma: public');
            // читаем файл и отправляем его пользователю
readfile($uploadFolder . $ORDER . '.xls');
unlink($_SERVER['DOCUMENT_ROOT'] . 'upload/'. $ORDER . '.xls');
То же самое с pdf.
Однако, накладная по складам состоит из нескольких файлов, их я формирую в архив. Архив на сервере лежит нормальный, открывается корректно. Но readfile возвращает битый трехкилобайтный архив. В чем может быть беда?
З.Ы. вот код, который возвращает архив:
PHP
1
2
3
4
5
6
7
8
9
10
$zip->close();
ob_end_clean();
header('Content-Description: File Transfer');
header('Content-Type: application/octet-stream');
header('Content-Disposition: attachment; filename="stores.zip"');
header('Content-Transfer-Encoding: binary');
header('Expires: 0');
header('Cache-Control: must-revalidate');
header('Pragma: public');
readfile($uploadFolder . 'stores.zip');
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
19.04.2016, 06:01
Ответы с готовыми решениями:

Упаковка в архив (с использованием пароля на архив) и отправка по почте
Помогите с написанием макроса, который будет упаковывать книгу в архив (книга по-умолчанию сохраняется в одну и ту же директорию),...

Как открыть архив DB? Не база данных, а архив с документами
Подскажите, как можно открыть файл .DB? Файл запаролен и не открывается ни парадоксом, ни дельфи. ТОчно уверен, что это архив.

Fs.readFile()
кириллицу выводит в консоль кракозябрами. С латиницей проблем нет. let fs = require('fs'); fs.readFile('1txt.txt','utf-8', (err,...

9
Hello Kitty
 Аватар для WhiteMind
690 / 562 / 402
Регистрация: 12.02.2016
Сообщений: 1,436
Записей в блоге: 1
19.04.2016, 06:28
PHP
1
2
3
4
5
6
7
8
9
10
11
$zip->close();
ob_end_clean();
header('Content-Description: File Transfer');
header('Content-Type: application/octet-stream');
header('Content-Disposition: attachment; filename="stores.zip"');
header('Content-Transfer-Encoding: binary');
header('Expires: 0');
header('Cache-Control: must-revalidate');
header('Pragma: public');
header('Content-Length: ' . filesize( $uploadFolder . 'stores.zip' ));
readfile($uploadFolder . 'stores.zip');
0
1 / 1 / 2
Регистрация: 20.10.2011
Сообщений: 154
19.04.2016, 08:07  [ТС]
не помогло

Добавлено через 1 минуту
архив битый. При попытке напрямую по ссылке обратиться к файлу - открывается текстовая страница index.html (с отвалившимися стилями). При прямом обращении к pdf и xls - файлы корректно скачиваются

Добавлено через 8 минут
В смысле, что архив битый приходит. На сервере лежит корректный файл
0
Hello Kitty
 Аватар для WhiteMind
690 / 562 / 402
Регистрация: 12.02.2016
Сообщений: 1,436
Записей в блоге: 1
19.04.2016, 08:21
покажите весь код.
потому как данный код валиден.
Цитата Сообщение от WhiteMind Посмотреть сообщение
PHP
1
2
3
4
5
6
7
8
9
header('Content-Description: File Transfer');
header('Content-Type: application/octet-stream');
header('Content-Disposition: attachment; filename="stores.zip"');
header('Content-Transfer-Encoding: binary');
header('Expires: 0');
header('Cache-Control: must-revalidate');
header('Pragma: public');
header('Content-Length: ' . filesize( $uploadFolder . 'stores.zip' ));
readfile($uploadFolder . 'stores.zip');
0
1 / 1 / 2
Регистрация: 20.10.2011
Сообщений: 154
19.04.2016, 08:38  [ТС]
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
<?  
loadExtClass('PHPExcel');
loadClass('Basket');
loadClass('Product');
loadClass('Store');
 
$BASKET = Basket::getBasketList($BASKET_ID);
PHPExcel::init();
$zip = new ZipArchive();
 
$upload = '*dir*';
$fileName = 'stores_'.$ORDER.'_'.time().'.zip';
//$zip->open($upload.'stores.zip', ZIPARCHIVE::CREATE);
if ($zip->open($_SERVER['DOCUMENT_ROOT'] . '/upload/' . $fileName, ZipArchive::CREATE)!==TRUE) {
each(array)xit("Невозможно открыть файл\n");
}
 
$IDS = array();
 
foreach($BASKET as $item)
    $IDS[] = $item['ID_PRODUCT'];
$IDS = implode(',', $IDS);
 
$DB = SQL::get_instance();
 
$res = $DB->query(
    'select max(s.ID), s.NAME
    from gxvg_storage as s
    LEFT JOIN gxvg_prod2stor as p2s ON p2s.ID_STOR = s.ID
    LEFT JOIN gxvg_products as p ON p2s.ID_PROD = p.ID
    WHERE p2s.QUANTITY > 0 AND p.ID IN ('. $IDS .')
    GROUP BY s.NAME'
);
 
$result = $res->fetchAll();
 
$names = array();
foreach ($result as $key => $value) {
    $products = Basket::getBasketListByStore($value['max(s.ID)'], $BASKET_ID);
 
    $xls = new PHPExcel();
    // Устанавливаем индекс активного листа
    $xls->setActiveSheetIndex(0);
    // Получаем активный лист
    $sheet = $xls->getActiveSheet();
    // Подписываем лист
    $sheet->setTitle('Товарный чек');
    $sheet->setCellValue("A1", 'Товарный чек №' . $ORDER . ' ('.$value['NAME'].')');
 
    $sheet->getStyle('A1')->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_CENTER);
 
    $sheet->mergeCells('A1:H1');
 
    $sheet->setCellValue("A3", '№');
    $sheet->setCellValue("B3", 'Наименование');
    $sheet->setCellValue("C3", 'Артикул');
    $sheet->setCellValue("D3", 'Штрихкод');
    $sheet->setCellValue("E3", 'Количество');
    $sheet->setCellValue("F3", 'Остаток по сайту');
    $sheet->getStyle('C')->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_RIGHT);
 
    $sheet->getStyle('A3:G3')->getFont()->setBold(true);
 
    $i = 4;
    $j = 1;
 
    foreach ($products as $item) {
        $sheet->setCellValue("A$i", $j++);
        $sheet->setCellValue("B$i", $item['PRODUCT_NAME']);
        $sheet->setCellValue("C$i", $item['ARTICLE']);
        $sheet->setCellValue("D$i", $item['BARCODE']);
        $sheet->setCellValue("E$i", $item['QUANTITY']);
        $sheet->setCellValue("F$i", $item['TOTAL_QUANTITY']);
        $i++;
    }
    $sheet->getColumnDimension('A')->setAutoSize(true);
    $sheet->getColumnDimension('B')->setAutoSize(true);
    $sheet->getColumnDimension('C')->setAutoSize(true);
    $sheet->getColumnDimension('D')->setAutoSize(true);
    $sheet->getColumnDimension('E')->setAutoSize(true);
    $sheet->getColumnDimension('F')->setAutoSize(true);
    $objWriter = new PHPExcel_Writer_Excel5($xls);
    $objWriter->save($_SERVER['DOCUMENT_ROOT'] . '/upload/'. $ORDER . '_' . $value['NAME'] . '.xls');
 
    $zip->addFile($_SERVER['DOCUMENT_ROOT'] . '/upload/'. $ORDER . '_' . $value['NAME'] . '.xls', $ORDER . '_' . $value['NAME'] . '.xls');
    $names[] = $ORDER . '_' . $value['NAME'];
}
 
$zip->close();
ob_end_clean();
header('Content-Description: File Transfer');
header('Content-Type: application/octet-stream');
header('Content-Disposition: attachment; filename="stores.zip"');
header('Content-Transfer-Encoding: binary');
header('Expires: 0');
header('Cache-Control: must-revalidate');
header('Pragma: public'); 
readfile($upload . 'stores.zip');
?>
0
Эксперт PHP
 Аватар для Kerry_Jr
3106 / 2591 / 1219
Регистрация: 14.05.2014
Сообщений: 7,236
Записей в блоге: 1
19.04.2016, 08:44
Цитата Сообщение от Fresh_MaN Посмотреть сообщение
PHP
1
$upload = '*dir*';
Эта папка так и должна называться? Проверяйте путь к файлу и имя файла.
0
Hello Kitty
 Аватар для WhiteMind
690 / 562 / 402
Регистрация: 12.02.2016
Сообщений: 1,436
Записей в блоге: 1
19.04.2016, 08:48
PHP
1
2
3
if ($zip->open($_SERVER['DOCUMENT_ROOT'] . '/upload/' . $fileName, ZipArchive::CREATE)!==TRUE) {
each(array)xit("Невозможно открыть файл\n");
}
?
0
1 / 1 / 2
Регистрация: 20.10.2011
Сообщений: 154
19.04.2016, 08:52  [ТС]
PHP
1
2
if ($zip->open($_SERVER['DOCUMENT_ROOT'] . '/upload/' . $fileName, ZipArchive::CREATE)!==TRUE) {
                exit("Невозможно открыть\n");
при копировании ошибка
Цитата Сообщение от Kerry_Jr Посмотреть сообщение
Эта папка так и должна называться? Проверяйте путь к файлу и имя файла.
Путь корректен, просто заменил адрес. При отправке pdf файла с этим же $upload все корректно выгружается
0
Эксперт PHP
 Аватар для Kerry_Jr
3106 / 2591 / 1219
Регистрация: 14.05.2014
Сообщений: 7,236
Записей в блоге: 1
19.04.2016, 09:05
Цитата Сообщение от Fresh_MaN Посмотреть сообщение
PHP
1
$fileName = 'stores_'.$ORDER.'_'.time().'.zip';
Цитата Сообщение от Fresh_MaN Посмотреть сообщение
PHP
1
readfile($upload . 'stores.zip');
Это как понимать?
0
Hello Kitty
 Аватар для WhiteMind
690 / 562 / 402
Регистрация: 12.02.2016
Сообщений: 1,436
Записей в блоге: 1
19.04.2016, 09:09
что покажет
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
<?  
loadExtClass('PHPExcel');
loadClass('Basket');
loadClass('Product');
loadClass('Store');
 
$BASKET = Basket::getBasketList($BASKET_ID);
PHPExcel::init();
$zip = new ZipArchive();
 
$upload = '*dir*';
$fileName = 'stores_'.$ORDER.'_'.time().'.zip';
//$zip->open($upload.'stores.zip', ZIPARCHIVE::CREATE);
//if ($zip->open($_SERVER['DOCUMENT_ROOT'] . '/upload/' . $fileName, ZipArchive::CREATE)!==TRUE) {
$uploadTmpFileName = 'sk-se-wq-qw-sa-stores.zip';
if ($zip->open( $uploadTmpFileName , ZipArchive::CREATE)!==TRUE) {
    exit("Невозможно открыть файл\n");
}
 
$IDS = array();
 
foreach($BASKET as $item)
    $IDS[] = $item['ID_PRODUCT'];
$IDS = implode(',', $IDS);
 
$DB = SQL::get_instance();
 
$res = $DB->query(
    'select max(s.ID), s.NAME
    from gxvg_storage as s
    LEFT JOIN gxvg_prod2stor as p2s ON p2s.ID_STOR = s.ID
    LEFT JOIN gxvg_products as p ON p2s.ID_PROD = p.ID
    WHERE p2s.QUANTITY > 0 AND p.ID IN ('. $IDS .')
    GROUP BY s.NAME'
);
 
$result = $res->fetchAll();
 
$names = array();
foreach ($result as $key => $value) {
    $products = Basket::getBasketListByStore($value['max(s.ID)'], $BASKET_ID);
 
    $xls = new PHPExcel();
    // Устанавливаем индекс активного листа
    $xls->setActiveSheetIndex(0);
    // Получаем активный лист
    $sheet = $xls->getActiveSheet();
    // Подписываем лист
    $sheet->setTitle('Товарный чек');
    $sheet->setCellValue("A1", 'Товарный чек №' . $ORDER . ' ('.$value['NAME'].')');
 
    $sheet->getStyle('A1')->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_CENTER);
 
    $sheet->mergeCells('A1:H1');
 
    $sheet->setCellValue("A3", '№');
    $sheet->setCellValue("B3", 'Наименование');
    $sheet->setCellValue("C3", 'Артикул');
    $sheet->setCellValue("D3", 'Штрихкод');
    $sheet->setCellValue("E3", 'Количество');
    $sheet->setCellValue("F3", 'Остаток по сайту');
    $sheet->getStyle('C')->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_RIGHT);
 
    $sheet->getStyle('A3:G3')->getFont()->setBold(true);
 
    $i = 4;
    $j = 1;
 
    foreach ($products as $item) {
        $sheet->setCellValue("A$i", $j++);
        $sheet->setCellValue("B$i", $item['PRODUCT_NAME']);
        $sheet->setCellValue("C$i", $item['ARTICLE']);
        $sheet->setCellValue("D$i", $item['BARCODE']);
        $sheet->setCellValue("E$i", $item['QUANTITY']);
        $sheet->setCellValue("F$i", $item['TOTAL_QUANTITY']);
        $i++;
    }
    $sheet->getColumnDimension('A')->setAutoSize(true);
    $sheet->getColumnDimension('B')->setAutoSize(true);
    $sheet->getColumnDimension('C')->setAutoSize(true);
    $sheet->getColumnDimension('D')->setAutoSize(true);
    $sheet->getColumnDimension('E')->setAutoSize(true);
    $sheet->getColumnDimension('F')->setAutoSize(true);
    $objWriter = new PHPExcel_Writer_Excel5($xls);
    $objWriter->save($_SERVER['DOCUMENT_ROOT'] . '/upload/'. $ORDER . '_' . $value['NAME'] . '.xls');
 
    $zip->addFile($_SERVER['DOCUMENT_ROOT'] . '/upload/'. $ORDER . '_' . $value['NAME'] . '.xls', $ORDER . '_' . $value['NAME'] . '.xls');
    $names[] = $ORDER . '_' . $value['NAME'];
}
 
$zip->close();
ob_end_clean();
header('Content-Description: File Transfer');
header('Content-Type: application/octet-stream');
header('Content-Disposition: attachment; filename="stores.zip"');
header('Content-Transfer-Encoding: binary');
header('Expires: 0');
header('Cache-Control: must-revalidate');
header('Pragma: public'); 
//readfile($upload . 'stores.zip');
readfile( $uploadTmpFileName );
?>
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
19.04.2016, 09:09
Помогаю со студенческими работами здесь

ReadFile
Помогите разобраться пожалйста с функцией чтения ReadFile(). В API не селен,хочу считать данные с com порта 3g модема, чтобы понять, что...

readfile
define('id',(int)$_GET); if (!readfile('art/'.id.'.inc')) die 'Ошибка!'; /* Тут выдаётся ошибка &quot;Parse error: syntax error, unexpected...

ReadFile
Добрый день. Читаю readfile`ом из файла данные и потом отсылаю в компорт. Проблема в том,что доходя до конца файла, readfile не...

ReadFile()
Доброго вечера! Помогите разобраться почему не читает файл. Файл создал правой кнопкой мыши, txt формат, в файле записано несколько цифр,...

ReadFile в Delphi
Народ помогите разобратся/наити ошибку...%-) procedure TForm1.OpenFile1Click(Sender: TObject); var hFile:Thandle; s:string;...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru