MongodbGridFSに保存している画像を提供するための単純な画像サーブレットがあります。ただし、サーブレットが呼び出されていないようです。
以下に、私のweb.xmlの一部と、ブラウザーのxhtmlおよびhtmlソースを示します。jsfコードは正常に機能しているようで、正しいIDを取得しています。私のログから、ページが表示されているときにサーブレットのdoGetメソッドが呼び出されていないようです。
なぜそうしないのかについてのアイデアは大歓迎です。
これが私のweb.xmlフラグメントです:
<servlet>
<servlet-name>imageServlet</servlet-name>
<servlet-class>com.iLearn.view.servlet.ImageServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>imageServlet</servlet-name>
<url-pattern>/image/*</url-pattern>
</servlet-mapping>
xhtmlファイルのフラグメントは次のとおりです。
<h:panelGrid id="resourcePanel" columns="4">
<a4j:repeat value="#{resourceUpload.resources}" var="res"
rowKeyVar="rowKey">
<h:panelGrid columns="1" style="width:100px; height:150 px;">
<h:graphicImage
value="image?id=#{res.idAsString}"
style="width:100px; height:100px;"
/>
<h:outputText value="#{res.name}" />
<h:outputText value="#{res.mimeType}" />
<h:outputText value="#{res.bytes}" />
</h:panelGrid>
</a4j:repeat>
</h:panelGrid>
そして、これは私が私のブラウザから得ているソースです:
<table style="width:100px; height:150 px;">
<tbody>
<tr>
<td><img src="image?id=50ad879f93839043ffc4f156" style="width:100px; height:100px;" /></td>
</tr>
<tr>
<td>headshot.JPG</td>
</tr>
<tr>
<td>image/jpeg</td>
</tr>
<tr>
<td></td>
</tr>
</tbody>
</table>
<table style="width:100px; height:150 px;">
<tbody>
<tr>
<td><img src="image?id=50add3b09383f7b98d0f6e66" style="width:100px; height:100px;" /></td>
</tr>
<tr>
<td>workon.JPG</td>
</tr>
<tr>
<td>image/jpeg</td>
</tr>
<tr>
<td></td>
</tr>
</tbody>
</table>
これが私のサーブレットのdoGetメソッドです。最初のログステートメントにヒットしないので、このメソッドに入ることはないと確信しています。なぜだめですか??
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
String idString = request.getParameter("id");
getLogger().debug("ImageServlet got request to serve up image id = " + idString);
if((idString == null) || (idString.isEmpty())) {
getLogger().debug("Image id was null, so image not displayed");
return;
}
ObjectId id = new ObjectId(idString);
Resource image = getResourceRecordDao().load(id);
if(image == null) {
getLogger().warn("Could not find image with id: " + id);
return;
}
response.reset();
response.setContentType(image.getMimeType());
response.setHeader("Content-Length", String.valueOf(image.getSize()));
response.setHeader("Content-Disposition", "inline; filename=\"" + image.getName() + "\"");
image.render(response.getOutputStream());
}