java如何使用poi-tl在word模板里渲染多张图片

1、poi-tl官网地址
http://deepoove.com/poi-tl/

2、引入poi-tl的依赖

java 复制代码
	  <dependency>
         <groupId>com.deepoove</groupId>
         <artifactId>poi-tl</artifactId>
         <version>1.12.1</version>
      </dependency>

3、定义word模板

释义: ?为开始标签,/为结束标签,@picture为渲染每一个图片

4、Java测试代码

java 复制代码
@RequestMapping("/test")
@RestController
public class TestController {
	private static final String PICTURE_PATH = "D:\\test\\picture\\";

	@GetMapping("/download")
    public void download(HttpServletResponse response) throws IOException {
    	//定义存储集合
        Map<String, Object> pictureMap= new HashMap<>();
		//创建并得到图片集合,设置图片大小
        List<Map<String, PictureRenderData>> pictureList = createPictureList(100, 100);
        pictureMap.put("pictureList", pictureList);
		//通过XWPFTemplate处理
        XWPFTemplate document = XWPFTemplate.compile(new ClassPathResource("templates/test.docx").getFile()).render(pictureMap);
		//返回数据设置
        setResponseHeader(response);
		//输出流并关闭
        OutputStream os = response.getOutputStream();
        document.write(os);
        os.close();
    }

	private List<Map<String, PictureRenderData>> createPictureList(int width, int height) {
        List<Map<String, PictureRenderData>> list = new ArrayList<>();
		
		//添加多张图片到集合
        list.add(createPictureMap("Banner (1).jpg", width, height));
        list.add(createPictureMap("Banner (10).jpg", width, height));
        list.add(createPictureMap("Banner (100).jpg", width, height));

        return list;
    }

	private Map<String, PictureRenderData> createPictureMap(String pictureName, int width, int height) {
        Map<String, PictureRenderData> map = new HashMap<>();
        //创建PictureRenderData对象并设置其大小
        //Pictures还有其他方法,如Pictures.ofStream()流处理,可根据自己的需求及文档替换
        map.put("picture", Pictures.ofLocal(PICTURE_PATH + pictureName).size(width, height).create());
        return map;
    }

	private void setResponseHeader(HttpServletResponse response) {
        response.reset();
        response.setContentType("application/octet-stream");
        response.setHeader("Content-disposition",
                "attachment;filename=picture_word_" + System.currentTimeMillis() + ".docx");
    }
}

5、测试结果

相关推荐
努力的小郑30 分钟前
今晚Cloudflare一哆嗦,我的加班计划全泡汤
前端·后端·程序员
百***618731 分钟前
springboot整合mybatis-plus(保姆教学) 及搭建项目
spring boot·后端·mybatis
q***615032 分钟前
eclipse配置Spring
java·spring·eclipse
Miraitowa_cheems1 小时前
LeetCode算法日记 - Day 106: 两个字符串的最小ASCII删除和
java·数据结构·算法·leetcode·深度优先
q***58191 小时前
Spring全家桶简介
java·后端·spring
武昌库里写JAVA1 小时前
微擎服务器配置要求,微擎云主机多少钱一年?
java·vue.js·spring boot·后端·sql
IUGEI1 小时前
深入解析HTTP长连接原理
java·网络·后端·网络协议·tcp/ip·http·https
q***64971 小时前
头歌答案--爬虫实战
java·前端·爬虫
凌波粒1 小时前
SpringMVC基础教程(4)--Ajax/拦截器/文件上传和下载
java·前端·spring·ajax