s v9 现在是这样
的问题
点击一个下载文件的链接
先是跳转到一
个下载页面
然后点击下载 我想把
中间这一步省了
直接下载 查了网上有说
在phpcms v9 后台的
模型管理
下载字段 更改 是
否直接下载 还是函数获
取地址
我改了还
是不好用
你好!你所提出的三个问题.我没怎麼看懂.如果以第二个为主.我倒可以说说我的看法.一.如何把数据赋到excel中?
答:sorry.没怎麼明白.见谅.
二.导出为excel表?
答:有两种方法实现.1.phpexcel.(稍显复杂)
2.简单的(我讲这个.简单^_^)直接上代码.自己改一下名字
和字段名.就成.
<?php
error_reporting(0)
//屏蔽警告和NOTICE等所有提示.包括error
Header(
"Content-type:
application/octet-stream
")
Header(
"Accept-Ranges:
bytes
")
Header(
"Content-type:application/vnd.ms-excelcharset=Big5")
//此处写编码,如,UTF-8....
Header(
"Content-Disposition:attachmentfilename=abnormal_Report.xls
")
//自己写文件名
*.xls
require
"conn_mysql.php"
//连接mysql
$sql
=
"select
*
from
`netart`.`abnormal_records`
order
by
record_abtime
desc"
$result
=
mysql_query($sql,$conn)
echo
"<table
width='100%'
border='1'
>"
echo"<tr>"
echo
"<td
style='color:red'>
<font
size=4>
ID
</font></td>"
echo
"<td
style='color:red'>
<font
size=4>异常时间
</font></td>"
echo
"<td
style='color:red'>
<font
size=4>异常地点
</font></td>"
echo
"<td
style='color:red'>
<font
size=4>详细内容
</font></td>"
echo
"<td
style='color:red'>
<font
size=4>提交人
</font></td>"
echo
"<td
style='color:red'>
<font
size=4>提交时间
</font>
</td>"
echo
"</tr>"
while
($rs=mysql_fetch_array($result)){
echo
"<tr>"
echo
"<td
width='30'>
{$rs['record_id']}</td>"
//用width
控制表格的宽度.自己改变.
echo
"<td
width='150'>
{$rs['record_abtime']}</td>"
echo
"<td
width='80'>
{$rs['record_abplace']}</td>"
echo
"<td
width='700'>
{$rs['record_content']}
</td>"
echo
"<td
width='60'>
{$rs['record_username']}
</td>"
echo
"<td
width='120'>
{$rs['record_uptime']}
</td>"
echo
"</tr>"
}
echo
"</tbale>"
?>
//以上代码.自己去改一下名字.和字段名就可以运行了.
==========================================================================
下面的代码针对MSSQL:(基本跟
Mysql一样啦.只是改用了ODBC)
<?php
error_reporting(0)
Header(
"Content-type:
application/octet-stream")
Header(
"Accept-Ranges:
bytes
")
Header(
"Content-type:application/vnd.ms-excelcharset=Big5")
Header(
"Content-Disposition:attachmentfilename=Syslog_view.xls
")
require
"conn_mssql.php"
session_start()
$flag1=@$_SESSION['flag_1']
$flag2=@$_SESSION['flag_2']
$flag3=@$_SESSION['flag_3']
$content=@$_SESSION['content']
$ip=@$_SESSION['ip']
$content_2=@$_SESSION['content_2']
$ip_2=@$_SESSION['ip_2']
$time=@$_SESSION['time']
if($flag1==1)
{
$sql_s="select
SysLog.DateTime,SysLog.IP,SysLog.Message
from
NetPerfMon.dbo.SysLog
where
IP='$ip'
and
convert(varchar(10),DateTime,120)='$time'
order
by
DateTime
desc"}
if($flag2==2)
{
$sql_s="select
SysLog.DateTime,SysLog.IP,SysLog.Message
from
NetPerfMon.dbo.SysLog
where
IP='$ip'
and
convert(varchar(10),DateTime,120)='$time'
order
by
DateTime
desc"}
if($flag3==3)
{$sql_s="select
SysLog.DateTime,SysLog.IP,SysLog.Message
from
NetPerfMon.dbo.SysLog
where
IP='$ip'
and
Message
like
'%$content%'
and
convert(varchar(10),DateTime,120)='$time'
order
by
DateTime
desc"}
$res=odbc_do($link,$sql_s)
echo
"<table
width='100%'
border='1'>"
echo"<tr>"
echo
"<td
style='color:red'>
<font
size=4>
DateTime
</font></td>"
echo
"<td
style='color:red'>
<font
size=4>
Switch
IP
</font></td>"
echo
"<td
style='color:red'>
<font
size=4>
Content</font></td>"
echo
"</tr>"
while
($rs=odbc_fetch_array($res))
{
echo
"<tr>"
echo
"<td
width='130'>
{$rs['DateTime']}</td>"
echo
"<td
width='110'>
{$rs['IP']}</td>"
echo
"<td
width='800'>
{$rs['Message']}</td>"
echo
"</tr>"
}
echo
"</tbale>"
session_stop()
?>
三.压缩成文件下载到本地?
答:此处也没怎麼明白.因为,你做个按钮/链接至上面的代码.不就可以保存成excel到本地了..还要做什麼压缩呢.
综:回答完毕.希望能帮到你.
既然你只是想学习如何打包.
那我重点就回答你这一块,正好我刚刚用到
$filename = "./" . date ( 'YmdH' ) . ".zip" // 最终生成的文件名(含路径)// 生成文件
$zip = new ZipArchive () // 使用本类,linux需开启zlib,windows需取消php_zip.dll前的注释
if ($zip->open ( $filename, ZIPARCHIVE::CREATE ) !== TRUE) {
exit ( '无法打开文件,或者文件创建失败' )
}
//$fileNameArr 就是一个存储文件路径的数组 比如 array('/a/1.jpg,/a/2.jpg....')
foreach ( $fileNameArr as $val ) {
$zip->addFile ( $val, basename ( $val ) ) // 第二个参数是放在压缩包中的文件名称,如果文件可能会有重复,就需要注意一下
}
$zip->close () // 关闭
//下面是输出下载
header ( "Cache-Control: max-age=0" )
header ( "Content-Description: File Transfer" )
header ( 'Content-disposition: attachment filename=' . basename ( $filename ) ) // 文件名
header ( "Content-Type: application/zip" ) // zip格式的
header ( "Content-Transfer-Encoding: binary" ) // 告诉浏览器,这是二进制文件
header ( 'Content-Length: ' . filesize ( $filename ) ) // 告诉浏览器,文件大小
@readfile ( $filename )//输出文件
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)