Itext PDF附件在电子邮件中

时间:2013-03-23 16:51:59

标签: java itext javamail attachment

我无法打开作为电子邮件附件发送的PDF。 PDF是使用iText和Flying Saucer创建的,并使用Java中的MimeMessage发送。我很确定在尝试下载附件时存在编码问题,因为在创建PDF时它看起来很好。它只是在作为附件发送时才会出现问题。例如,在Chrome中,它会发送“无法加载PDF文档”错误。它在其他浏览器和Adobe Reader中发送类似的错误。感谢。

//creates the pdf
        DocumentBuilder builder =  DocumentBuilderFactory.newInstance().newDocumentBuilder();
        byte[] bytes              = buf.toString().getBytes("iso-8859-1");
        ByteArrayInputStream baos = new ByteArrayInputStream(bytes);

        Document doc = builder.parse(baos);

        ITextRenderer renderer = new ITextRenderer();
        renderer.setDocument(doc, null);
        renderer.layout();
        OutputStream os = new ByteArrayOutputStream();
        os = response.getOutputStream();
        renderer.createPDF(os);
        os.close();


        //email
        MimeMessage msg = new MimeMessage(session);
        Multipart multipart = new MimeMultipart();
        MimeBodyPart messageBodyPart = new MimeBodyPart();
        messageBodyPart.setText("This is a test");
        multipart.addBodyPart(messageBodyPart);

        messageBodyPart = new MimeBodyPart();
        //construct the pdf body part
        DataSource dataSource = new ByteArrayDataSource(bytes, "application/pdf");
        messageBodyPart.setHeader("Content-Transfer-Encoding", "base64");
        messageBodyPart.setDataHandler(new DataHandler(dataSource));
        messageBodyPart.setFileName("test.pdf");

        multipart.addBodyPart(messageBodyPart);

        //construct message
        msg.setHeader("Content-Type", "multipart/mixed");
        msg.setFrom(new InternetAddress(user));
        msg.setReplyTo(InternetAddress.parse(replyEmail,false));
        msg.setSubject("Test");
        msg.setRecipients(Message.RecipientType.TO, to);
        msg.setSentDate(new java.util.Date());
        msg.setContent(multipart);

        //send email
        Transport.send(msg);            

2 个答案:

答案 0 :(得分:1)

问题是我正在设置

os=response.getOutputStream

相反,我摆脱了这一行并创建了

byte[] outputBytes = os.toByteArray();

现在是我在dataSource中使用的。

答案 1 :(得分:0)

什么是“buf”?为什么要将它转换为字符串然后从字符串中提取字节,假设它在iso-8859-1中编码?

看起来PDF正在创建为“os”,它不会保存在任何地方,也不会用于附件。