Я работаю над веб-страницей, где у меня есть некоторые данные, визуализированные в таблицах html. Я хочу, чтобы пользователь мог получать данные в виде документа Excel, и для этой цели я использую PHPExcel. Данные хранятся в массиве массивов, array (первая строка массива (первый столбец, ..., последний столбец), ..., последняя строка массива (первый столбец, ..., последний столбец)). Итак, чтобы передать данные в datatoexcel.php, где создается файл Excel, я сериализую массив и отправляю его с помощью POST.
$functiondata = serialize($func[1]);
echo '<form action="datatoexcel.php" name="dataform" method="post">'.
'<input type=hidden name="functiondata" value="'.htmlspecialchars($functiondata).'">'.
'<input type="radio" name="format" value="xls" checked>xls'.
'<input type="radio" name="format" value="xlsx">xlsx'.
'</form>';
echo "<a href=\"#\" onclick=\"document['dataform'].submit()\">Export table data</a>";
Затем данные извлекаются из datatoexcel.php с помощью:
$serialized_func = $_POST['functiondata'];
$funcdata = unserialize($serialized_func);
Это отлично работает на локальном хосте, но когда я запускаю его на веб-сервере, $ funcdata, похоже, не имеет никаких данных. Localhost работает под управлением Windows 7 с Apache2 и PHP 5.2.17, а веб-сервер работает под управлением Linux RedHat 5.2 с Apache2 и PHP 5.2.6. PHPExcel работает на веб-сервере, я попытался создать жестко запрограммированный массив в datatoexcel.php, и документ Excel оказался в порядке.