在jsp中显示数据库Blob字段图片实例

第一步:新建一个serverlet,用于获得图片流。代码如下:


public class ImageServlet extends HttpServlet {

    public ImageServlet() {
        super();
    }

    public void destroy() {
        super.destroy(); // Just puts "destroy" string in log
        // Put your code here
    }

    public void doGet(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {

               doPost(request,response);
    }

    public void doPost(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {

        response.setContentType("text/html");
    //    PrintWriter out = response.getWriter();
        VideoService service=new VideoService();
        String id=request.getParameter("id");
        byte[] imageData=service.getImageDataById(id);
        if (imageData != null) 
   {  
        response.setContentType("image/png");            
        OutputStream stream = response.getOutputStream();
        stream.write(imageData); 
        stream.flush();
        stream.close();
     } 
   else 
     { 
         response.setContentType("text"); 
        response.getWriter().write("attribute byArr not found"); 
      } 

    }

    public void init() throws ServletException {
        // Put your code here
    }

}


第二步:jsp部分代码如下:

<html>
  <head>
  </head>
 
  <body>
       <%
             VideoService service=new VideoService();
             ArrayList<VideoBean> dataLst=service.getVideListInfoByType("100","1","5");
             if(dataLst==null){
                  System.out.println("dataLst is null...");
             }else{
               for(int i=0;i<dataLst.size();i++){
         %>
         <%=dataLst.get(i).getName()%><br/>
         <img alt="图片" src="imageTest?id=<%=dataLst.get(i).getId()%>"><br/>
         <%
                   System.out.println("name:"+dataLst.get(i).getName());
             }
             }
        %>

  </body>
</html>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值