以前在这里也曾经有一些文章谈到了在asp中生成动态图表的问题,但那些文章中所谈到的一些方法都有某些方面的限制,如需要在客户端安装office2000或安装OWC,有些则可能在Intranet中使用时没什么问题,但在通过Internet访问的时候,就可能出现无法正常工作的现象(这主要和SQL Server的安全设置有关)。那么,我们如何来避免这些问题呢?有一个很好的方法,就是将在ASP中生成的图表转换成图片文件保存在服务器上,这样用户最终看到的是GIF图片格式的图表,我想现在的任何一种浏览器在观看GIF图片的时候都没什么问题吧。:)也许唯一可能的问题就是如何对这些生成的临时图片文件的处理问题,关于这个问题在最后我们会讨论。 下面我们会用一个具体的实例来说明这种方法。程序的测试环境为: NT4.0(SP5)+IIS4.0+SQL Server7.0+IE5.0,要运行下面的ASP程序,请将下面的代码Copy,保存到你的一个虚拟目录中,在这个虚拟目录中建立一个子目录tmp(你可能修改代码中的路径以符合自己的路径),在IIS中设置read权限即可,注意了,在NT上你必须设置此tmp目录对IUSR_servername用户至少有Change的权限。建立一个pubs的DSN指向SQL Server的pubs数据库。 以下是代码: chart.asp <% Function ExportChartToGIF(cspace) Dim fso Dim sFilePath Dim sFileName
最后说一下如何处理临时的图片文件 在ExportChartToGIF汉书中你可以看到如下的代码: Session("TC:" & sFilePath & sFileName) = sFilePath & sFileName 我们将产生的图片文件路径保存在session中,然后在Session_OnEnd中添加如下的代码: Set fsoTemp = CreateObject("Scripting.FileSystemObject") for each imagefile in Session.Contents if left(imagefile,3) = "TC:" then fsoTemp.DeleteFile mid(imagefile,4), True end if next set fsoTemp=nothing