FastReport .Net支持多种格式导出报表,可以通过邮件发送,同样也可以通过FTP发送。在本文中,我想将重点转移到通过FTP报表传输到服务器。值得注意的是,并非运行每个报表以及通过FTP手动执行发送都是非常方便的,要是有大量的报表需要发送到服务器又该如何呢?
这个问题的解决方案:
直接使用FTP连接文件管理器发送所有报表文件,所有的报表应输出到所期望的格式;使用FastReport输出和发送报表,但通过应用程序代码来实现。很明显,第二种方式在导出所需格式报表方面更节省时间,除此之外,你完全可以实现过程自动化。例如,把所有报表都放到时间表或单击按钮服务器上。我将展示一个例子,你将看到如同通过FTP从应用程序代码中发送报表一样的简单操作。
创建窗体应用程序。放置窗体按钮。把库添加到使用:using FastReport;using FastReport.Export;using FastReport.Utils;
为按钮单击处理程序添加代码:
private void button1_Click(object sender, EventArgs e){Report report1 = new Report(); //Create new reportFastReport.Export.Pdf.PDFExport pdf = new FastReport.Export.Pdf.PDFExport(); //Create pdf export objectreport1.Load(Environment.CurrentDirectory+"\\text.frx"); //Load reportreport1.Prepare(); //Prepare report FastReport.Cloud.StorageClient.Ftp.FtpStorageClient ftp = new FastReport.Cloud.StorageClient.Ftp.FtpStorageClient(); //Create ftp client//ftp connection settingsftp.Server = "78.47.131.251/Reports";ftp.Username = "user";ftp.Password = "password";ftp.SaveReport(report1, pdf); //Send report}
首先,我们创建一个报表对象实例。
然后创建输出对象为PDF。接着,我们加载该报表,并进行构建(准备)。创建一个与FTP协同工作的客户端,你必须指定所有三个属性:服务器、用户和密码。不要忘记指定路径到所需文件夹,否则报表将会被直接保存在root中。
最后,像服务器发送报表,作为参数传输到报表本身并输出到PDF,FastReport将以PDF格式输出报表并以PDF格式发送通过FTP上传的文件。
启动应用程序,点击按钮,检查文件是否存在于服务器:
通过这个简单的程序,你可以以任意可用的格式发送多个报表,比如说HTML。所以你可以在本地计算机上设计报表并把它们分享到你的网站。