如何读取Access里的OLE类型的图片

编辑
文档创建者:印然 (67260 )     浏览次数:3050次     编辑次数:7次     最近更新:caixiaolan 于 2016-11-02     

目录:

1. 问题描述编辑

使用身份证读卡器读取照片信息保存在Access数据库的OLE型字段中,图片为bmp格式,因为是用其读卡器写入,数据类型为长二进制数据。
将该图片字段拖入单元格后,预览看不到图片,如何才能在FR里把这个图片展现出来呢?

2. 解决方案编辑

自定义函数,使用java的jna调用本地的WltRS.dll,将数据库OLE字段中的长二进制数据转为.wlt文件,再调用本地方法将.wlt文件转为.bmp图片,最终自定义函数返回图片在FR中显示。

3. 实现步骤编辑

3.1 前提准备
本地库文件WltRS.dll保存在E:\bmp\WltRS.dll(位置可变,但必须保证与自定义函数中的路径一致)
eclipse项目中导入FR的jar包。
3.2 实现自定义函数
我们自定义一个函数类BinaryImage.java,该类继承AbstractFunction,在run()方法中使用java的jna调用本地库文件WltRS.dll,最终返回图片。
代码如下:
package com.fr.function; import java.awt.image.BufferedImage; import java.io.BufferedOutputStream; import java.io.File; import java.io.FileOutputStream; import java.io.IOException; import javax.imageio.ImageIO; import com.fr.data.core.db.BinaryObject; import com.fr.script.AbstractFunction; import com.sun.jna.Library; import com.sun.jna.Native; public class BinaryImage extends AbstractFunction{ //加载dll,"E:\\bmp\\WltRS"是dll的文件完整路径,但不带后缀名,生成WltRS.class static WltRS wltrs = (WltRS) Native.loadLibrary("E:\\bmp\\WltRS", WltRS.class); static int index = 0; public Object run(Object[] args) { int current = index; //args[0] 是 BinaryObject对象,取为bo BinaryObject bo = (BinaryObject)args[0]; //将bo转换为.wlt文件,并保存在位置E:\bmp\;本地方法GetBmp的第一个参数是wlt文件的路径 getFile(bo.getBytes(), "E:\\bmp\\", current + ".wlt"); //读取.wlt为文件 File file = new File("E:\\bmp\\" + current + ".wlt"); //调用本地方法,在相同路径下生产.bmp wltrs.GetBmp("E:\\bmp\\" + current + ".wlt", 1); //读取并返回图片 File imagefile = new File("E:\\bmp\\" + current + ".bmp"); BufferedImage buffer = null; try { buffer = ImageIO.read(imagefile); } catch (IOException e) { e.printStackTrace(); } index = (++index)%300; return buffer; } // byte[]转换为file的方法 public static void getFile(byte[] bfile, String filePath, String fileName) { BufferedOutputStream bos = null; FileOutputStream fos = null; File file = null; try { File dir = new File(filePath); if(!dir.exists() && dir.isDirectory()){//判断文件目录是否存在 dir.mkdirs(); } file = new File(filePath+"\\"+fileName); fos = new FileOutputStream(file); bos = new BufferedOutputStream(fos); bos.write(bfile); } catch (Exception e) { e.printStackTrace(); } finally { if (bos != null) { try { bos.close(); } catch (IOException e1) { e1.printStackTrace(); } } if (fos != null) { try { fos.close(); } catch (IOException e1) { e1.printStackTrace(); } } } } } //用jna调用本地方法的必须步骤,具体含义不明 interface WltRS extends Library{ //定义要调用的本地方法 void GetBmp(String str, int i); }
将编译后的BinaryImage.class、WltRS.class根据包名拷贝至报表工程如报表安装目录下的WebReport\WEB-INF\classes\com\fr\function\文件夹下。
3.3 使用自定义函数
将OLE类型字段的值显示为图片
启动设计器,点击服务器>函数管理器,新增自定义函数BINARYIMAGE,选择com.fr.function.BinaryImage类:
222
将身份证读卡器写入Access数据库OLE型字段的照片信息拖入单元格,双击,在数据列>高级>自定义显示中使用自定义函数转换成图片:
222

附件列表


主题: 专题总结
如果您认为本文档还有待完善,请编辑

文档内容仅供参考,如果你需要获取更多帮助,付费/准付费客户请咨询帆软技术支持
关于技术问题,您还可以前往帆软社区,点击顶部搜索框旁边的提问按钮
若您还有其他非技术类问题,可以联系帆软传说哥(qq:1745114201

此页面有帮助吗?