对于图片在JSP中显示的问题很常见,用户上传图片,最简单的办法放到数据库中,如何显示?
用户需要把图片以BASE64编码的方式放到XML中,然后上传XML,我们需要显示该图片,
办法是:
1、把图片编码存储到数据库中,然后利用Servlet来显示图片
try {
MysqlDAO md = MysqlDAO.getInstance();
String chartId = request.getParameter("picChartId");
PicChartBean pcb = md.findPicChartById(chartId);
byte[] picdata = new sun.misc.BASE64Decoder().decodeBuffer(pcb
.getPic_content());
response.setContentType("image/*"); // 设置返回的文件类型
OutputStream toClient = response.getOutputStream(); // 得到向客户端输出二进制数据的对象
toClient.write(picdata); // 输出数据
toClient.close();
} catch (IOException e) // 错误处理
{
PrintWriter toClient = response.getWriter(); // 得到向客户端输出文本的对象
response.setContentType("text/html;charset=gb2312");
toClient.write("无法打开图片!");
toClient.close();
}
2、在JSP中,调用该Servlet
<c:if test="${not empty piccharts}">
<c:forEach var="picChart" items="${piccharts}" varStatus="sindex">
<tr>
<td>${picChart.pic_name }</td>
<td><img src="<%=basePath1%>servlet/picShow?picChartId=${picChart.id }"> </td>
<td>${picChart.pic_description }</td>
</tr>
</c:forEach>
</c:if>