Я работаю на веб-странице, где у меня есть некоторые данные, отображаемые в html-таблицах. Я хочу, чтобы пользователь мог извлекать данные в виде документа Excel, и я использую PHPExcel для этой цели. Данные хранятся в массиве массивов, массив (первая строка первого массива (первый столбец, ..., последний столбец), ..., массив последней строки (первый столбец, ..., последний столбец)). Поэтому, чтобы передать данные в datatoexcel.php, где был создан файл excel, я сериализую массив и отправляю его с помощью POST.PHP сериализуемый, работающий на localhost, но не на веб-сервере
$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 оказался прекрасным.
делает $ func [1] возвращает то, что ожидается? Появляются ли какие-либо ошибки? Если ошибки не отображаются, уверены ли вы, что error_reporting - E_ALL, а не @ (оператор подавления ошибок)? – Sejanus