java后台将html转换为图片

方法一:利用springboot的freemark生成 要考虑样式兼容问题
1.pom引入对应的包

<!-- html生成图片-->
		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-freemarker</artifactId>
		</dependency>
		<dependency>
			<groupId>com.openhtmltopdf</groupId>
			<artifactId>openhtmltopdf-core</artifactId>
			<version>0.0.1-RC9</version>
		</dependency>
		<repositories>
		<repository>
			<id>mvnrepository</id>
			<name>mvnrepository</name>
			<url>https://mvnrepository.com</url>
		</repository>
	</repositories>

2.对应的模板 后缀名.ft 文件

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8"/>
    <title>海报</title>
</head>
<body style="width: 500px; height: 800px;margin: 0;padding: 0;">
<span>${msg}</span>
<img src="${img}" alt="" />
<div style="width: 100px;height: 100px;border-radius: 50%;background: rgba(255, 0, 0, 0.2);">大幅度发</div>
</body>
</html>

3.工具类

public class FreemarkerUtils {
    private static String getTemplate(String template, Map<String,Object> map) throws IOException, TemplateException {
        Configuration cfg = new Configuration(Configuration.VERSION_2_3_25);
        String templatePath = FreemarkerUtils.class.getResource("/").getPath()+"/templates";
        cfg.setDirectoryForTemplateLoading(new File(templatePath));
        cfg.setDefaultEncoding("UTF-8");
        cfg.setTemplateExceptionHandler(TemplateExceptionHandler.RETHROW_HANDLER);
        cfg.setLogTemplateExceptions(false);
        Template temp = cfg.getTemplate(template);
        StringWriter stringWriter = new StringWriter();
        temp.process(map, stringWriter);
        stringWriter.flush();
        stringWriter.close();
        String resutl = stringWriter.getBuffer().toString();
        return resutl;
    }

    public static void turnImage(String template, Map<String,Object> map, HttpServletResponse response) throws Exception {
        String html = getTemplate(template, map);

        byte[] bytes=html.getBytes();
        ByteArrayInputStream bin=new ByteArrayInputStream(bytes);
        DocumentBuilderFactory factory=DocumentBuilderFactory.newInstance();
        DocumentBuilder builder=factory.newDocumentBuilder();
        Document document=builder.parse(bin);
        Java2DRenderer renderer = new Java2DRenderer(document,600,800);
        BufferedImage img = renderer.getImage();
        response.setContentType("image/jpeg");
        response.setDateHeader("expries", -1);
        response.setHeader("Cache-Control", "no-cache");
        response.setHeader("Pragma", "no-cache");
        //输出在页面
       // ImageIO.write(img, "jpg", response.getOutputStream());
       //指定下载路径
        File file=new File("D:\\zhifu\\测试.jpg");
        try {
            ImageIO.write(img, "jpg", file);
        }catch (Exception e){
            e.printStackTrace();
        }

    }
}

测试方法

  public void test(HttpServletResponse response) {
        try {
            Map<String,Object> map=new HashMap<>(16);
            map.put("msg","html--生成图片测试22222");
            map.put("img","https://upload-images.jianshu.io/upload_images/912344-3054132dd6939004.png?imageMogr2/auto-orient/strip|imageView2/1/w/300/h/240");
            FreemarkerUtils.turnImage("demo.ftl",map,response);
        } catch (Exception e) {
           e.printStackTrace();
        }
    }

第二种 将页面代码生成html在进行转化

public class PictureHtml {
    public static void main(final String[] args) throws Exception {
//html页面中需要灵活变动的值
        String headurl = "";//图片的路径不能是带有参数的 不然解析不了
        String proUrl = "";
        String qrCodeUrl = "";
        String proName="犀牛皮特质皮鞋";
        String proPrice="1000.00";
        String userName="测试";
        String html =
                "<!DOCTYPE html>\n" +
                "<html lang=\"en\">\n" +
                "<head>\n" +
                "    <meta charset=\"UTF-8\"/>\n" +
                "    <meta name=\"viewport\" content=\"width=device-width, initial-scale=1.0\"/>\n" +
                "    <title>分享</title>\n" +
                "    <style>\n" +
                "        body {\n" +
                "            font-size: 0;\n" +
                "            padding: 0;\n" +
                "            margin: 0;\n" +
                "        }\n" +
                "\n" +
                "        div {\n" +
                "            box-sizing: border-box;\n" +
                "        }\n" +
                "\n" +
                "        .main {\n" +
                "            width: 654px;\n" +
                "            margin: 0 auto;\n" +
                "            padding: 28px;\n" +
                "            text-align: center;\n" +
                "            background: green;\n" +
                "        }\n" +
                "\n" +
                "        .top{\n" +
                "            display: inline-block;\n" +
                "            max-width: 100%;\n" +
                "            margin: 0 auto 20px;\n" +
                "            position: relative;\n" +
                "            padding-left: 56px;\n" +
                "            font-size: 28px;\n" +
                "            line-height: 48px;\n" +
                "            color: #666;\n" +
                "        }\n" +
                "\n" +
                "        .oneOver {\n" +
                "            overflow: hidden;\n" +
                "            text-overflow: ellipsis;\n" +
                "            white-space: nowrap;\n" +
                "        }\n" +
                "\n" +
                "        .head{\n" +
                "            height: 48px;\n" +
                "            width: 48px;\n" +
                "            border-radius: 50%;\n" +
                "            overflow: hidden;\n" +
                "            border: solid 1px #E6E6E6;\n" +
                "            position: absolute;\n" +
                "            left: 0;\n" +
                "            top: 0;\n" +
                "            overflow: hidden;\n" +
                "        }\n" +
                "\n" +
                "        .head img {\n" +
                "            width: 100%;\n" +
                "            height: 100%;\n" +
                "        }\n" +
                "\n" +
                "        .pro_pic{\n" +
                "            width: 400px;\n" +
                "            height: 400px;\n" +
                "            margin: 0 auto 24px;\n" +
                "        }\n" +
                "\n" +
                "        .pro_pic_{\n" +
                "            width: 100%;\n" +
                "            height: 100%;\n" +
                "        }\n" +
                "\n" +
                "        .money{\n" +
                "            font-size: 40px;\n" +
                "            font-weight: bold;\n" +
                "            padding-bottom: 16px;\n" +
                "        }\n" +
                "\n" +
                "        .name{\n" +
                "            font-size: 28px;\n" +
                "            line-height: 40px;\n" +
                "            font-weight: bold;\n" +
                "            padding-bottom: 34px;\n" +
                "        }\n" +
                "\n" +
                "        .code{\n" +
                "            height: 175px;\n" +
                "            width: 175px;\n" +
                "            margin: 0 auto 20px;\n" +
                "            border: solid 1px #E6E6E6;\n" +
                "            border-radius: 50%;\n" +
                "            overflow: hidden;\n" +
                "        }\n" +
                "\n" +
                "        .code_pic{\n" +
                "            height: 175px;\n" +
                "            width: 175px;\n" +
                "        }\n" +
                "\n" +
                "        .desc{\n" +
                "            font-size: 24px;\n" +
                "            line-height: 34px;\n" +
                "            color: #999;\n" +
                "        }\n" +
                "    </style>\n" +
                "</head>\n" +
                "<body>\n" +
                "    <div class=\"main\" id=\"main\">\n" +
                "        <div class=\"top oneOver\">\n" +
                "            <div class=\"head\">\n" +
                "                <img class=\"persion_pic\" src=\""+headurl+"\"/>\n" +
                "            </div>\n" +
                "            "+userName+",为您安利好物\n" +
                "        </div>\n" +
                "        <div class=\"pro_pic\">\n" +
                "            <img class=\"pro_pic_\" src=\""+proUrl+"\"/>\n" +
                "        </div>\n" +
                "        <div class=\"money\">¥"+proPrice+"</div>\n" +
                "        <div class=\"name\">"+proName+"</div>\n" +
                "        <div class=\"code\">\n" +
                "            <img class=\"code_pic\" src=\""+qrCodeUrl+"\"/>\n" +
                "        </div>\n" +
                "        <div class=\"desc\">识别小程序码,查看商品详情</div>\n" +
                "    </div>\n" +
                "</body>\n" +
                "</html>";
//string转为inputstream流
        ByteArrayInputStream byteArrayInputStream = new ByteArrayInputStream(html.getBytes());
        File targetFile = ResourceUtils.getFile(ResourceUtils.CLASSPATH_URL_PREFIX+"share1.html");
//inputstream流转为file
        FileUtils.copyInputStreamToFile(byteArrayInputStream, targetFile);
//通过openhtmltopdf工具生成图片
        final Java2DRenderer renderer = new Java2DRenderer(targetFile, 740, 1000);
        final BufferedImage img = renderer.getImage();
        final FSImageWriter imageWriter = new FSImageWriter();
        imageWriter.setWriteCompressionQuality(1.0f);
        imageWriter.write(img, "D:\\zhifu\\ccc.jpg");//输出路径
        System.out.println("Done with rendering");
    }
}
  • 1
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 9
    评论
### 回答1: 在 Java 后台程序中,你可以使用 HTTP POST 请求来接收多个图片文件和文字信息。 具体来说,你需要使用一个表单来包含你的文字信息和文件输入字段,然后使用 Java 的 Servlet 或者 Spring MVC 框架来处理 HTTP POST 请求。 例如,你可以使用如下的 HTML 表单来提交文字信息和文件: ```html <form action="/upload" method="post" enctype="multipart/form-data"> <input type="text" name="textField" value="some text"> <input type="file" name="fileField1" multiple> <input type="file" name="fileField2" multiple> <button type="submit">Submit</button> </form> ``` 然后,在 Java 后台程序中,你可以使用如下的代码来处理这个 HTTP POST 请求: ```java @PostMapping("/upload") public void handleFileUpload(@RequestParam("textField") String text, @RequestParam("fileField1") MultipartFile file1, @RequestParam("fileField2") MultipartFile file2) { // 获取文字信息 String textField = text; // 获取文件内容 byte[] file1Content = file1.getBytes(); byte[] file2Content = file2.getBytes(); // 处理文字信息和文件内容 ... } ``` 在上面的代码中,`@PostMapping("/upload")` 注解用来处理 HTTP POST 请求,`@RequestParam` 注解用来获取表单中的文字信息和文件内容。 注意:为了使用 `MultipartFile` 类来处理文件内容,你需要在你的后台程序中添加对 `commons-fileupload` 和 `commons-io` 包的依赖。 ### 回答2: 在Java后台接收多个图片文件和文字信息可以使用Multipart/form-data格式进行传输。 首先,客户端需要使用表单提交方式将图片文件和文字信息一起发送到Java后台。表单的enctype属性需要设置为"multipart/form-data",这样可以保证图片文件能够正确地通过HTTP协议传输。 然后,在Java后台,可以使用一些常用的框架如SpringMVC或Servlet来处理接收到的请求。这些框架都提供了对Multipart/form-data格式进行解析的功能。 在SpringMVC中,可以使用@RequestParam注解来接收单个文件,并使用@RequestPart注解来接收多个文件。示例代码如下: ```java @PostMapping("/upload") public String handleFileUpload(@RequestParam("file") MultipartFile file, @RequestPart("files") MultipartFile[] files, @RequestParam("text") String text) { // 处理接收到的文件和文字信息 // ... return "success"; } ``` 在Servlet中,可以通过HttpServletRequest的getPart方法来获取上传的文件对象,通过getParameter方法来获取文字信息。示例代码如下: ```java protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { // 获取文件上传的对象 Part filePart = request.getPart("file"); Collection<Part> fileParts = request.getParts("files"); // 获取文字信息 String text = request.getParameter("text"); // 处理接收到的文件和文字信息 // ... } ``` 在处理接收到的文件和文字信息时,可以根据实际需求进行操作,例如将文件保存到磁盘上的指定位置,或者将文字信息存储到数据库中等。相关的操作可以使用Java IO或者持久化框架来完成。 总之,通过使用Multipart/form-data格式,Java后台可以接收并处理多个图片文件和文字信息。 ### 回答3: 在Java后端,可以使用MultipartHttpServletRequest来接收多个图片文件和文字信息。 首先,前端可以使用HTML的<form>标签并设置enctype为"multipart/form-data"来实现文件上传。然后在Java后端,可以使用HttpServletRequest来接收请求,然后将其转换为MultipartHttpServletRequest对象。 接下来,可以通过MultipartHttpServletRequest对象的getFiles()方法来获取所有上传的文件。可以使用该方法返回的MultipartFile数组来逐个操作每个文件。可以使用MultipartFile对象的getOriginalFilename()方法获取文件名,使用getContentType()方法获取文件类型,使用getBytes()方法获取文件内容的字节数组等。 此外,还可以通过MultipartHttpServletRequest对象的getParameter()方法来获取表单中的其他文本参数。可以通过该方法传递参数名来获取对应的值。 总结起来,可以使用MultipartHttpServletRequest对象获取多个图片文件和文字信息。对于文件,可以使用MultipartFile对象获取文件名、类型和内容。对于文字信息,可以使用MultipartHttpServletRequest对象的getParameter()方法获取表单中的其他参数值。 注意:在使用MultipartHttpServletRequest接收文件时,需要在后端的配置文件中设置合适的文件上传配置,如设置文件保存路径、最大文件大小等。另外,还需要相关的依赖库来支持文件上传功能,如Apache Commons FileUpload或Spring的MultipartResolver等。
评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值