Codeigniter Export в Excel хорошо работает на локальном хосте, ошибки на сервере - PullRequest
0 голосов
/ 26 февраля 2012

Это код моего помощника export_to_excel:

function export_to_excel($query, $filename='exceloutput')
{
    $headers = ''; // just creating the var for field headers to append to below
    $data = ''; // just creating the var for field data to append to below

    $obj =& get_instance();

    $fields = $query->list_fields();

    if ($query->num_rows() == 0) {
        echo '<p>The table appears to have no data.</p>';
    } else {
        foreach ($fields as $field) {
           $headers .= $field . "\t";
        }

        foreach ($query->result() as $row) {
            $line = '';
            foreach($row as $value) {                                            
                if ((!isset($value)) OR ($value == "")) {
                    $value = "\t";
                } else {
                    $value = str_replace('"', '""', $value);
                    $value = '"' . $value . '"' . "\t";
                }
                $line .= $value;
            }
            $data .= trim($line)."\n";
        }

        $data = str_replace("\r","",$data);

        header("Content-type: application/x-msexcel; charset=utf-8");
        header("Content-Disposition: attachment; filename=$filename.xls");
        echo "$headers\n$data";
    }
}

Я получаю разные результаты на локальном хосте и на сервере. Когда я запускаю код в localhost, он без проблем выводит правильный результат, но когда я запускаю код на сервере, он дает тот же результат, что и в localhost, , но добавляет еще две строки (строки Excel), содержащие ошибку следующим образом:

<br />
<b>Fatal error</b>: ob_start()
[&lt a href='ref.outcontrol'&gt ref.outcontrol&lt/a&gt]:
Cannot use output buffering in output buffering display handlers in
<b>/home/username/public_html/Codeigniter_website/system/core/Exceptions.php</b>
on line <b>181</b><br />

Какие-нибудь решения?

Это почти большой проект, и это единственное различие, которое я видел между локальным и серверным.

1 Ответ

4 голосов
/ 26 февраля 2012

Решение состоит в том, чтобы убедиться, что вывод и синтаксический анализ прекращаются после требуемого вывода.

Это можно сделать, поставив exit; после echo "$headers\n$data";

...