ホームページ  >  記事  >  バックエンド開発  >  PHPからのCSVエクスポートに関する質問

PHPからのCSVエクスポートに関する質問

WBOY
WBOYオリジナル
2016-06-23 14:02:251018ブラウズ

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 ソース コードを表示します。
解決策: redfilie の後に die() または exit を追加すると解決します。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。