0

我正在尝试从数据库访问图像并将其呈现为 PDF。下面是我从数据库获取图像的 servlet。

public class ImageDownloadServlet extends HttpServlet 
{
private  Connection connection = null;
private Statement stmt = null;
    public void doGet(HttpServletRequest req, HttpServletResponse resp) throws IOException {
 try {
Integer imageId=Integer.parseInt(req.getParameter("imageId").toString());


            connection = //creating connection  
                stmt = connection.createStatement();
        ResultSet rs = stmt.executeQuery("SELECT IMG_BLOB FROM ImageTable WHERE img_id = "+imageId);
        rs.next();
        Blob b=rs.getBlob(1);

        resp.setContentType("image/jpeg");
        resp.setContentLength((int) b.length());
        InputStream is = b.getBinaryStream();
        OutputStream os = resp.getOutputStream();
        byte buf[] = new byte[(int) b.length()];
        is.read(buf);
        os.write(buf);
        os.close();

        stmt.close();
        connection.close();


    }
    catch (Exception e) 
    {
        e.printStackTrace();
    }


}
}

此代码工作正常,我在 CKEditor 中获取图像。但是在尝试创建 PDF 时,并没有调用这个 servlet。我的 web.xml 是 <servlet> <description></description> <display-name>ImageDownloadServlet</display-name> <servlet-name>ImageDownloadServlet</servlet-name> <servlet-class>test.ImageDownloadServlet</servlet-class> </servlet> <servlet-mapping> <servlet-name>ImageDownloadServlet</servlet-name> <url-pattern>/tesing/Image</url-pattern> </servlet-mapping>

我创建 PDF 的代码是

File file = new File(D:/satz/sat.pdf);
    FileOutputStream fos=new FileOutputStream(file);
    Document doc=new Document(PageSize.A4, 50, 50, 70, 130);
    PdfWriter pdfWriter=PdfWriter.getInstance(doc, fos);
    String pdfString="<html><body>hello<img src='/tesing/Image?imageId=1' alt='' /></body></html>";
    doc.open();
    XMLWorkerHelper worker=XMLWorkerHelper.getInstance();
    ByteArrayInputStream is = new ByteArrayInputStream(pdfString.getBytes());
    worker.parseXHtml(pdfWriter, doc, is);
    doc.close();

我的问题是在创建 PDF 时它没有调用这个 servlet。我正在使用itextpdf-5.4.4.jarandxmlworker-5.4.1.jar和 spring MVC。

更新如果我使用 RAD 和 Tomcat 7.0 服务器,完整路径将调用我的 servlet 并生成带有图像的 PDF。但是当我使用 RAD 和 Websphere 8.5 时,它根本没有调用我的 servlet。

4

1 回答 1

2

你尝试解析这个 HTML

String pdfString="<html><body>hello<img src='/tesing/Image?imageId=1' alt='' /></body></html>";

您的图像源 URL 既不包含协议也不包含主机。iText 应该如何知道如何(哪个协议)以及在哪里(哪个主机)请求您的部分 URL。

因此,请改用完整的 URL。

于 2014-03-24T06:45:22.977 回答