我正试图从DB访问图像并以PDF呈现。下面是我的servlet从DB获取图像。
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.jar
和xmlworker-5.4.1.jar
和spring MVC。
UPDATED 如果我使用RAD和Tomcat 7.0服务器,则完整路径调用我的servlet并生成带有图像的PDF。但是当我使用RAD和Websphere 8.5时,它根本没有调用我的servlet。
你试着解析这个HTML
String pdfString="<html><body>hello<img src='/tesing/Image?imageId=1' alt='' /></body></html>";
您的图像源URL既不包含协议也不包含主机。iText如何知道如何(哪个协议)和在哪里(哪个主机)请求您的部分URL ?
因此,使用完整的URL代替。