我正在尝试从数据库访问图像并将其呈现为 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.jar
andxmlworker-5.4.1.jar
和 spring MVC。
更新如果我使用 RAD 和 Tomcat 7.0 服务器,完整路径将调用我的 servlet 并生成带有图像的 PDF。但是当我使用 RAD 和 Websphere 8.5 时,它根本没有调用我的 servlet。