PHP が csv ファイルをダウンロードするときに、html ソース コードがファイルに表示される理由を誰かが知っているかどうかオンラインで待っています xls ファイルは正常です
あなたの不十分な説明に基づいています、悪い答えしかできません?? コードに問題があります
php で生成された csv ファイルをページに配置し、クリックしてダウンロードし、開いたら html コードが表示されます。内容の最後にわかりますか!
生成時にそこに表示されます
コードを確認する必要があります
if ($opt == '') { if (!in_array($userid, $okuser)) { echo "你没有权限浏览此页面"; exit; } else { $web_folder = "/tj/"; $log_folder = "/tj/"; } $logFile = array(); if (is_dir($log_folder)) { if ($dh = opendir($log_folder)) { while (($file = readdir($dh)) != false) { if ($file != "." && $file != "..") { $logFile[$file] = $file . "&ver=" . mt_rand(); } } } } arsort($logFile); $smarty->assign("logfile",$logFile); $smarty->assign("web_folder",$web_folder); } elseif($opt == 'download'){ if (!in_array($userid, $okuser)) { echo "你没有权限浏览此页面"; exit; } $filename = $cgi->filename; header("Content-Type:text/csv"); header("Content-Type:text/xls"); header("Content-Disposition:attachment;filename=".$filename); readfile("/tj/".$filename); } else { echo "你没有权限浏览此页面"; exit; }これは php コードです
{if $opt == ''}{include file="menus.htm"}<div>统计表:</div><br/><br/><br/><TABLE style='width:90%' border="0" cellpadding="2"><tr> <td> 下载链接 </td></tr><TR> <TD> {foreach from=$logfile key=k item=v} <li><a href="mylog?filename={$v}&opt=download" target="_blank">{$k}</a></li> {/foreach} </TD></TR></TABLE><br/><TABLE style='width:90%' border="0"</TABLE>{include file="foot.htm"}{/if}{if $opt=='download'}{/if}これは HTML コードです
php によって生成された a.csv ファイルは間違いなく正しいですが、ページを通じてダウンロードされる場合は、 a ページのhtmlソースコードもcsvファイルに出力されます
かなり憂鬱です!
目視検査: 最後のテーブルが閉じられていません。
私が投稿した問題は解決されました。この問題はまれに発生するようです。
header("Content-Type:text/csv");
header("Content-Type:text/xls");
2 つのコンテンツ タイプ ヘッダーを送信する方法
そうですね、ダウンロードしたいからです。 xls 形式には csv 形式もあります
問題は
readfile("/tj/".$filename);という文にあります。ファイルを読み取った後、それを die() に渡して、ページ出力を抑制します。そうしないと、エクスポートされた Excel が表示されます。要求されたページの HTML ソース コードを表示します。