Java读取oracle中blob图片并在页面上显示

背景:有两个平台,A和B,A平台负责图片的上传,B平台负责图片的展示

今天第一次遇到读二进制图片并显示页面的问题,在网上淘了淘,加上自己实际的情况得以实现,现记录在此,以作备忘。
1.项目中业务处理放在ejb中,ejb直接跟数据库打交道。下面为ejb层方法。

//讲图片以二进制形式返回给Action控制层
public byte[] getMenuInfo(String type)
{
//final byte[] result =new byte[1024];
final List result=new ArrayList();
String sql = "select F_VALUE from suitpicture where f_type=?";
getJdbcTemplate().query(sql, new Object[] { type},
new RowMapper() {
public Object mapRow(ResultSet rs, int index)throws SQLException
{
Blob img=rs.getBlob("F_VALUE");
long size=img.length();
byte[] bs=img.getBytes(1, (int)size);
result.add(bs);
return null;
}
});
if(result!=null&&result.size()>0)

return result.get(0);
else return null;
}

2.Action 层方法

//获取套餐图片信息
public String getMenuInfo()
{
String type=getRequest().getParameter("type");
try {
BusinessRemote br = EJBHomeFactory.getInstance().lookupBusinessRemote();
byte[] bs=br.getMenuInfo(type);
ServletOutputStream outs=getResponse().getOutputStream();
outs.write(bs);
outs.flush();
return null;

} catch (Exception e)
{
addErr("获取图片信息发生错误!");
log.error("获取图片信息发生错误!",e);
}
return null;
}


3.jsp(展示层)
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>




Insert title here




你可能感兴趣的:(JavaUtil)