对于图片在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>