身份证一类读卡器读取的照片信息,保存在Access数据库中一般为OLE型字段,图片为BMP格式,因为是用其读卡器写入的,其数据类型为常二进制数据。
再用报表或EXCEL读取这些图片时,如果将该图片字段拖入单元格后,预览就看不到图片了。EXCEL如何读取这类图片网上有教程,这里不多说。如果你要用报表软件FineReport来展现这类图片该如何做呢?
思路是采用FineReport的自定义函数,使用java的jna调用本地的WltRS.dll,将数据库OLE字段中的长二进制数据转为.wlt文件,再调用本地方法将.wlt文件转为.bmp图片,最终自定义函数返回图片在FineReport中显示。
<!--[if !supportLists]-->1、<!--[endif]-->前提准备
本地库文件WltRS.dll保存在E:\bmp\WltRS.dll(位置可变,但ixu保证以自定义函数中的路径一致);eclipse项目中导入FINEREPORT的jar包。
<!--[if !supportLists]-->2、<!--[endif]-->实现自定义函数
自定义一个函数类BinaryImage.java,该类继承AbstractFunction,在run()方法中使用java的jna调用本地库文件WltRS.dll,最终返回图片。代码如下:
将编译后的BinaryImage.class、WltRS.class根据包名拷贝至报表工程如报表安装目录下的WebReport\WEB-INF\classes\com\FineReport\function\文件夹下。
3、使用自定义函数
将OLE类型字段的值显示为图片。启动设计器,点击服务器>函数管理器,新增自定义函数BINARYIMAGE,选择com.FineReport.function.BinaryImage类:

将身份证读卡器写入Access数据库OLE型字段的照片信息拖入单元格,双击,在数据列>高级>自定义显示中使用自定义函数转换成图片:
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/21472864/viewspace-2123712/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/21472864/viewspace-2123712/
本文介绍如何使用FineReport报表工具展示Access数据库中由身份证读卡器写入的OLE型字段照片信息。通过自定义函数BinaryImage,借助Java JNA技术调用本地DLL文件进行图片格式转换。
188

被折叠的 条评论
为什么被折叠?



