项目实战—OFD文件转换成图片

引言:项目需要预览OFD文件,但前端对OFD文件支持太差,因此将OFD文件直接转换成PNG格式、Base64编码的数据并返回给前端

依赖

xml 复制代码
 <dependency>
    <groupId>org.ofdrw</groupId>
    <artifactId>ofdrw-converter</artifactId>
    <version>1.17.2</version>
    <!--  如果项目已经引入了log4j,则排除log4j        -->
    <exclusions>
        <exclusion>
            <groupId>org.apache.logging.log4j</groupId>
            <artifactId>log4j-slf4j-impl</artifactId>
        </exclusion>
    </exclusions>
</dependency>

接口

java 复制代码
/**
     * ofd文件转换成png图片

     * @return
     * @throws Exception
     */
    @GetMapping(value = "/getOfdToPng")
	public Result<List<String>> getOfdToPng() throws Exception {
        long start = System.currentTimeMillis();
        // 这里是minio访问url
        String ofdPath = "http://127.0.0.1:9000/ofd/42181c66_20240531_%E8%88%AA%E4%BD%B3%EF%BC%88%E6%8A%95%E6%A0%87%EF%BC%89%E5%AD%972024%E5%B9%B4%E7%AC%ACHJ000033%E5%8F%B7%E4%BF%9D%E5%87%BD.ofd?X-Amz-Algorithm=AWS4-HMAC-SHA256&X-Amz-Credential=minioadmin%2F20240612%2Fus-east-1%2Fs3%2Faws4_request&X-Amz-Date=20240612T080307Z&X-Amz-Expires=604800&X-Amz-SignedHeaders=host&versionId=null&X-Amz-Signature=30626032831f76333120327cba020c4aaffcf68c27912d629bf31c99d37b6aa9";
        InputStream isFromUrl = DocUtils.getIsFromUrl(ofdPath);
        List<String> list = new ArrayList<>();
        // 输入OFD文件路径
        // 输出图片路径
        try (OFDReader reader = new OFDReader(isFromUrl)) {
            // ppm 设置来指定图片生成的分辨率,数值越高图片越清晰,生成时间越慢
            ImageMaker imageMaker = new ImageMaker(reader,16);
            int pageSize = imageMaker.pageSize();
            for (int i = 0; i < pageSize; i++) {
                BufferedImage bufferedImage = imageMaker.makePage(i);
                ByteArrayOutputStream outputStream = new ByteArrayOutputStream();
                ImageIO.write(bufferedImage, "png", outputStream);
                byte[] imageBytes = outputStream.toByteArray();
                // 生成base64格式的图片
                String base64String = "data:image/png;base64," + Base64.getEncoder().encodeToString(imageBytes);
                outputStream.close();
                list.add(base64String);
            }

        } catch (IOException e) {
            e.printStackTrace();
        }finally {
            isFromUrl.close();
        }
        long end = System.currentTimeMillis();
        System.out.println("耗费时间:" + (end -start) * 1.0 / 1000);
        return Result.ok(list);
    }
	
	// 将远程url转换成InputStream 
	public static InputStream getIsFromUrl(String remoteUrl) throws Exception {
        byte[] fileBytes = null;
        InputStream inStream = null;
        ByteArrayOutputStream bOutStream = null;
        try {
            URL url = new URL(remoteUrl);
            HttpURLConnection httpConn = (HttpURLConnection) url.openConnection();
            httpConn.connect();
            inStream = httpConn.getInputStream();
            return inStream;
        } catch (UnknownHostException e) {
            String msg = MessageFormat.format("网络请求时发生UnknownHostException异常: {0}", e.getMessage());
            Exception ex = new Exception(msg);
            ex.initCause(e);
            throw ex;
        } catch (MalformedURLException e) {
            String msg = MessageFormat.format("网络请求时发生MalformedURLException异常: {0}", e.getMessage());
            Exception ex = new Exception(msg);
            ex.initCause(e);
            throw ex;
        } catch (IOException e) {
            String msg = MessageFormat.format("从远程Url中获取文件流时发生IOException异常: {0}", e.getMessage());
            Exception ex = new Exception(msg);
            ex.initCause(e);
            throw ex;
        }
    }

前端展示

请求接口

js 复制代码
getAction("/getOfdToPng").then(res =>{
         this.imgList = res.result
      })

因为是PNG格式、Base64编码的数据,可以直接使用img标签

html 复制代码
<div style="display:flex;justify-content:center;" v-for="img in imgList" :key="img">
     <img class="imgOfd" :src="img">
 </div>
相关推荐
叫我阿柒啊2 天前
从Java全栈到前端框架:一次真实的面试对话与技术解析
java·javascript·typescript·vue·springboot·react·前端开发
荣淘淘3 天前
互联网大厂求职面试记:谢飞机的搞笑答辩
java·jvm·spring·面试·springboot·线程池·多线程
叫我阿柒啊4 天前
从全栈开发到微服务架构:一位Java工程师的实战经验分享
java·ci/cd·kafka·mybatis·vue3·springboot·fullstack
原来是好奇心4 天前
Spring Boot 事务失效的八大原因及解决方案详解
spring·springboot·事务
mask哥4 天前
DP-观察者模式代码详解
java·观察者模式·微服务·设计模式·springboot·设计原则
叫我阿柒啊5 天前
从Java全栈到前端框架:一场真实面试的深度技术探索
java·redis·微服务·typescript·vue3·springboot·jwt
awei09165 天前
SpringBoot3中使用Caffeine缓存组件
java·缓存·springboot·springboot3
麦兜*5 天前
MongoDB 事务管理:多文档操作如何保证 ACID?
java·数据库·后端·mongodb·spring cloud·springboot
叫我阿柒啊6 天前
从Java全栈开发到微服务架构:一次真实的面试实录
java·微服务·vue3·springboot·前端开发·后端开发·项目经验