关于php导出csv的问题 在线等,问下大家是否知道,php在下载csv文件时文件中为什么出现html源码 xls文件却是正常的 解决方案 » 免费领取超大流量手机卡,每月29元包185G流量+100分钟通话, 中国电信官方发货 我将php生成的csv文件放在页面,点击可下载,打开下载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 code{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 code php生成的a.csv文件可以肯定是对的,但通过a页面下载,把a页面的html源码也输出到csv文件中了比较郁闷! 目测你最后一个table 没闭合。 header("Content-Type:text/csv"); header("Content-Type:text/xls");怎么发送两个content-type头 嗯 对因为我要下载的东西有 xls 格式 也有csv格式我查了下,找到问题了,问题出在 readfile("/tj/".$filename);这一句,读取完了文件给一个die(); 抑制页面输出,否则,导出的excel 会出现请求页面的html源码;解决办法:在redfilie这一句后加一个die()或者exit; 即可解决! 新手求助 php 获取目录下的子目录文件? 菜鸟问题 为什么mysql数据库里有的表是没有myi和myd文件? Google自定义搜索结果页面全角字符乱码 用正则取相应的值,在线等 PHP CURL代理如何直接发送gzip数据给用户 帝国备份王2008开源版下载 (MYSQL专用备份工具) 为什么现在php开发人员那么难招? 请问开发一个聊天室系统要多少MONEY啊? 老看大家说phpmyadmin可以导出和导入mysql数据库, 我却没找到, 谁能告诉我? 关于替换斜杠的正则,求解。 请教一下,用PHP如何生成50万个不重复的8位阿拉伯数字?
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 code
{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 code
比较郁闷!
header("Content-Type:text/xls");怎么发送两个content-type头
我查了下,找到问题了,问题出在 readfile("/tj/".$filename);这一句,
读取完了文件给一个die(); 抑制页面输出,否则,导出的excel 会出现请求页面的html源码;
解决办法:在redfilie这一句后加一个die()或者exit; 即可解决!