基于XML的WEB系统报表精确打印实现

本文介绍了一种基于XML的WEB报表精确打印方法,该方法利用XML的特性实现了B/S架构下的客户端快速精确打印需求。通过实际案例展示了如何在.NET平台中应用此方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

基于XMLWEB系统报表精确打印实现

王春红 何志林

(运城学院计算机科学与技术系,山西 运城  044000

 

摘 要:XML及其相关技术日益渗透到计算机科学的各个层面。针对XML的特点,给出了一个利用XML有效解决B/S结构中客户端快速精确打印报表方法,并以所开发的运城市城建局建设工程交易中心招投标管理系统作为实例说明了这一方案在Microsoft ASP.net平台中的实现过程。该方案实现简单,可扩充性好,且易于维护。

关键字:XML    WEB打印    数据交换    WEB服务    WEB票据打印

Exact Report Printing of WEB System Based on XML

chunhong-wang   zhilin-he

Computer & Science Department of  YunCheng University

 

Abstract:  XML and its relevant technology have been found at all the levels of the computer science. By exploiting its features, a method of quick and exact report printing of sheet has been offered. This method has also been exemplified in the platform of Microsoft ASP.net by an example of bidding system designed for YunCheng Construction Trade of Center, Bureau of Urban Construction. The result shows that this method is simple, and easy to expand and maintain.

Keywords: XML  WEB Printing  Data Exchange  WEB Service  WEB Printing of Receipt

 


0引言

近年来,随着宽带网络的普及和推广,基于局域网的C/S结构的应该程序越来越不能满足企业信息化的需要,而基于浏览器的B/S结构的应用程序则越来越广泛。B/S结构的应用程序客户端免安装、免配置、免维护、免升级;服务器端则采用多层模式,将表示层、商业逻辑层和数据层分开,极大的提高了开发的效率和数据的安全性。目前基于B/S结构的应用程序已成为软件开发的主流。但是B/S结构也存在一些缺点,比如,灵活的Web报表打印实现,尤其是一些发票的精确套打更不容易实现!

现有的Web打印控制技术分成几种方案:主要有(1)自定义控件完成打印;(2)利用IE自带的WebBrowser控件实现打印;(3)利用第三方控件实现打印。利用IE打印过于简单,无法实现复杂的票据打印要求,利用第三方控件会往往需要付一定的费用,并且使系统安装部署复杂。自定义控件方式就是利用VBVC等工具生成COM组件,或者用.net生成.net组件,用定义好的打印格式来分析打印源文件从而实现打印。利用XML可以非常容易地定义打印目标的文本、表格等内容的格式,轻松实现各种复杂的打印需要。本文介绍一种在.net平台下基于XML技术构建.net打印组件从而实现WEB系统的精确打印。

1XML特性

XML以其良好的数据组织结构和可扩展的特性,成为描述各种复杂数据,特别是结构化数据的良好工具。另外,XML还允许为特定的应用制定特殊的数据。具有以下一些特点:

a) 严格的规范、清晰的语义

b) 数据的共享与重用

c) 良好的扩展性

d) 平台无关性

基于以上的特点,利于XML良好的扩展性和平台无关性完全可以自定义出我们所有需要的格式控制标签,根据服务器端定义的打印格式从客户端直接控制打印机打印,从而实现跨平台的通用报表打印。

2、系统原理

 利用XML强大的自定义功能,我们便能方便的自定义出我们所需要的格式控制标签,在服

务器端进行动态编码后通过WEB服务器传到客户端,然后在客户端进行格式解析,根据服务器端定义的打印格式从客户端直接控制打印机打印出我们需要的报表。如图1所示:

1系统原理设计

 

我们采用.NET frameworkwinform做一个打印控件,该控件可以直接嵌入到网页中实现打印功能,但嵌入到网页中的控件一般无法直接连接到数据库,因此只能采用XML文件进行中间数据交换格式,通过普通WEB服务器的默认80端口进行数据传输。当然,我们也可以采用使用SOAP传输数据的Web Service来直接从数据库提取数据,从原理上看,应该和我们采用的XML属于同种类技术。

由于现在的大部分数据库都支持XML格式的数据查询和转换,如SQL Server 2000Oracle 9iIBM DB2等大型关系型数据库。只需要通过简单的设置就能直接进行XML数据转换工作。如果数据库不能支持直接XML数据转换,也可以用JSPASPPHP等服务器端脚本程序进行脚本转换工作。

  客户端也不需要任何特殊的设置工作,仅需要安装一个大小为21M.NET framework分发包,然后直接打开网页就可以进行工作。也没有操作系统限制,从windows 98windows xp都能很好的支持。

  由于采用的是XML标准数据格式作为中间数据交换,因此本解决方案具有非常好伸缩性,例如,客户端的.NET控件可以采用JAVA APPLETACTIVX或者是VBVC等编写的客户端应用程序直接替换。服务器也可以任意选择采用IISAPACHEWEB服务器。数据库也可以采用任意一种数据库。包括SQL ServerOracle或者是Access等。

  由于采用的是普通WEB服务器传送数据,因此可以直接采用SSL安全套接字等已经成熟的WEB加密技术。同时还可以对XML进行数据算法加密,在客户端再进行解密,保证了传输的安全性。

3、系统实现

首先我们用VB.net设计一个XML打印控件,该控件可以从本地或WEB上的文件,甚至WEB Service加载XML格式的报表文件,然后根据XML报表中的定义,将报表中的线、框、文本提取出来形成一个PrintDocument打印文档进行预览或打印。

将生成的DLL控件复制到WEB系统所在的目录,并在需要打印的WEB页面上,用<Object>

标签将控件插入WEB页面,并通过JavaScriptWEB服务器动态生成的XML报表文件以参数方式传给打印控件,从而实现在WEB页面上的灵活精确打印!

下面以运城市城建局建设工程交易中心网络办公系统为例,介绍基于XML利用.Net打印控件实现招投标档案自定义报表的方法。首先我们利用ASP.NET构建WEB网络办公平台,实现基本的档案管理,招投标流程管理;图2所示为一工程报建界面!因本页面的资料需要打印存档,所以在该页面嵌入.Net报表打印控件,并通过JavaScript脚本将页面生成的工程报建表XML报表文件传给打印控件,单击打印按钮,就会打开工程报建表打印预览界面,如下图3所示。

 2

3

 

用于打印的XML报表格式如下:

<?xml version="1.0" encoding="utf-8" ?>

<root>

<Reportsetting>        /*报表页面设置*/

<landscape>true</landscape><papertype>A4</papertype>

<paperwidth>2100</paperwidth><paperheight>2970</paperheight>

< leftmargin>100</ leftmargin>< rightmargin>100</ rightmargin>

< topmargin>100</ topmargin>< bottommargin>100</ bottommargin>

</ Reportsetting >

<ReportDetail>         /*报表内容*/

<text x="380" y="65" fontname="黑体" fontsize="20"

fontcolor="black" b="true" i="false" u="true">    运城市建设工程报建表</text>

<text x="100" y="120" fontname="宋体" fontsize="12" fontcolor="black" b="true" i="false" u="true"> :2005-05-01  </text>     /*定义文本*/

...

<rect x = "90" y="160" width="980" height ="540" border ="2" bordercolor="black" />  /*定义矩型*/

...

<line x1="650" y1="460" x2="1070" y2 ="460" border ="1" bordercolor="Black" />  /*定义线*/

...

<data x="510" y="430" fontname="宋体" fontsize="12" fontcolor="Black" b="true" i="false" u="true">办公大楼</text>  /*定义打印数据*/

...

</ReportDetail >

</root>

 

读取XML报表并进行解析和打印控制函数

Private Sub PagePrint(ByVal sender As Object, ByVal ev As PrintPageEventArgs)

  Dim g As Graphics = ev.Graphics

  Dim LastPage As Boolean = False

  Dim pntElement As xmlPrint.PrintElement = Nothing  '声明打印解析类

   Dim node As XmlNode

   For Each node In doc("root")("ReportDetail").ChildNodes   

'载入XML报表文件,并解析报表内容

pntElement = xmlPrint.Parser.CreateElement(node)

'调用解析器生成相应的对象

    Try

      LastPage = pntElement.Draw(g)

'是否需要分页

      Catch ex As Exception

         Me.lblMsg.Text = ex.Message    

'是否需要分页

    End Try

 Next node

    ev.LastPage = LastPage

End Sub

 

报表中画线的实现函数部分代码如下:

 Public Class Line Inherits PntElement          

'XML报表解析类中画线函数

Public Sub New(ByVal Line As XmlNode)

_node = Line'传入的打印数据,即一个XMLNODE

End Sub

Public Overrides Function Draw(ByVal g As Graphics) As Boolean  '画线函数

Dim S as String

Dim slgBorder as Single

S=_node.Attributes("bordercolor").InnerText)

slgBorder = Single.Parse(

_node.Attributes("border").InnerText)

Dim pen As New

Pen(Color.FromName(S),sglBorder)  '定义画笔

Dim x1,x2,y1,y2 as Single  'XML中提取坐标


X1=Single.Parse(_node.Attributes("x1").InnerText)

X2=Single.Parse(_node.Attributes("x2").InnerText)

Y1=Single.Parse(_node.Attributes("y1").InnerText)

Y2=Single.Parse(_node.Attributes("y2").InnerText)

g.DrawLine(pen,x1,y1,x2,y)    '<SPAN style="FONT-SIZE: 9pt; COLOR: green; FONT-FAMILY: 新宋体; mso-font-kerning: 0pt; mso-hansi-font-family: 'Times New

 
本DataGridView打印控件和.NET打印控件5.6版(含报表模板设计组件)2014年6月22日修改完成,完全免费,在.NET2.0及以上环境下都可以使用(VB打印、C#打印都是可以的),有帮助文档与使用实例。 与上一版本的5.5版相比,新控件5.6版的主要更改如下: 1、增加了一个新打印组件SimpleReport组件,该组件与DGVPrint组件一样在运行时可进行打印参数设置,但比DGVPrint组件功能更强大,可以自动管理多个打印方案,在打印预览时可以自由在各个打印方案之间切换;可以在打印参数设置窗口中动态定义多表头,还可以像EasyReport组件一样设置和使用参数变量(具体使用效果参见实例程序); 2、解决了EasyReport组件在插入变量参数时,变量参数未排序导致查找不方便的问题; 3、在打印预览界面添加了简单的双面打印功能。(打印预览界面工具栏中的“打印\双面打印”菜单); 4、其他一些完善,比如DGVPrint组件中设置的行高无效等问题。 本控件特色: 1、强大的DataGridView打印功能,不仅可以以多种形式(普通打印、分栏打印、跨页打印、工资条打印打印DGV表格,基本上能完全按DGV控件本身设置的格式如字体、字号、背景颜色、前景颜色、单元格对齐方式等打印出来,文字图像都可以打印,而且是完全根据表格当前的显示顺序进行打印的,基本上做到了所见即所得的打印。 2、报表设计功能。报表模板设计组件EasyReport与WebEasyReport组件可以设计普通报表、分组报表、套打模板等,分别以DataGridView为数据源。控件的位置以毫米为计量单位,定位准确,很适合套打单据设计。 3、强大的图表打印功能。5.2版控件新增了一个Chartlet的组件,使用非常方便,可以生成柱形图、饼图、折线图等多种图形,而且可以设置2D或3D效果,既可以在打印控件中打印出来,也可以在Graphics对象中显示。 4、分组汇总打印DataGridVeiw功能,每组还可以自动换新页打印,还可以自动增加行号。 5、强大的文本打印输出功能,控件提供多个文本打印重载函数,打印文本时,如果需要,控件会自动换行和换页打印输出。还增加了以指定行间距及字符间距打印文本的功能,可以用固定行距,也可以用单倍或多倍行距打印文本。 6、强大的绘图功能,基本上.NET的GDI+的绘图函数(如直线、矩形、路径、多边形、曲线等)都有,只有个别函数的名称有点区别。 7、支持同一文档多种版面格式打印(类似于Word中的节的功能):对同一份文档,不同的页面可以设置不同的格式(纸张大小、纸张方向、页边距),只需要在新增一页时在NewPage方法中指定要使用的页面格式即可,使用非常简单。 8、报表文件保存功能。本控件允许将当前打印预览的内容保存为报表文件,以后使用本控件重新打开该报表文件即可重现原来保存报表时的打印内容。 9、Excel导出功能,可以将DataGridView和GridView导出为Excel文件,5.2版控件还增加了不依赖Office的导出Excel功能,而且速度非常快,5.4版还增加了合并单元格的导出功能。 10、打印DataGridView时的打印方案保存与读取功能。可以将当前打印参数保存为打印方案文件,或者从保存的打印方案文件中读取打印参数。 11、水印打印功能。根据需要,可以在页面中打印或不打印以半透明空心文字打印水印。 12、强大的容器控件打印功能(DrawPanel函数)。借助该函数,您只需要在您的容器控件中设计好要打印的内容及打印内容的相对位置,控件轻松帮你打印出来(如果超过一页,控件会自动换页续打)。 13、特殊文字效果打印功能。控件具有打印浮雕文字、阴影文字、空心文字、块文字的功能。 14、页眉页脚中既可打印文字,也可打印图像,或者即打印图像又打印输出文字。 15、图像与图标打印输出功能。 16、多表头(跨行跨列的复杂表头)打印功能,多表头组件支持多表头显示与打印、单元格内容的合并显示、打印与导出。 17、自定义纸张支持功能。 18、纸张背景图片设置打印功能。 19、.NET4.0支持功能(是单独的一个文件)。 20、直接打印窗口中的TreeView控件功能。 21、打印窗口中的ListView功能。 22、RichTextBox控件的RTF文本打印功能。 23、斜线表头打印功能(5.4版新增)。 24、二维码打印功能(5.5版本增加)。 25、5.6版新增的SimpleReport组件允许您在一个方案文件中管理多个打印方案,在打印预览时能自由在各个打印方案之间切换。 我将持续改进该控件,并将不断推出控件的新版本,要查看或下载控件的升级版本,请登陆网站:http://myyouping.download.csdn.n
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值