首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > JAVA > Java Web开发 >

<>用jsp从oracle数据库中读取图片并在网页上显示~解决办法

2012-01-06 
急用jsp从oracle数据库中读取图片并在网页上显示~~在网上找了些例子,都不怎么完全,以前没接触过从数据库

<急>用jsp从oracle数据库中读取图片并在网页上显示~~

在网上找了些例子,都不怎么完全,
以前没接触过从数据库中读取图片~~
因为比较急~~~~
请给个完整的例子~~~~谢谢~~~~

[解决办法]
帮顶~
[解决办法]
数据库里取图片,图片是怎么存在数据库里的?
[解决办法]
在数据库里图片存的是二进制还是路径呀
[解决办法]
对啊,没说清楚是用blob存储的还是用路径

如果是用blob的,先去网上查下怎么把blob读取到文件流
我这里给你贴个片段,片段里面如何获取数据库连接的代码被我删掉了,因为不同的系统不一样


ByteArrayOutputStream bao = new ByteArrayOutputStream();
st = conn.createStatement();
if(iTimeOut>0)st.setQueryTimeout(iTimeOut);
 
ResultSet rs = st.executeQuery(sql);
 if (rs.next()) {
 //到数据库的输出流
 oracle.sql.BLOB blob = (oracle.sql.BLOB)rs.getBlob(fieldName);
 InputStream blobReader = blob.getBinaryStream();
 byte[] b = new byte[blob.getBufferSize()];
 int len=-1;
 while ((len=blobReader.read(b)) != -1) {
 bao.write(b, 0, len);
 }
 bao.flush();
 bao.close();
 }else{
 rs.close(); 
 st.close();
 return null;
 }
  st.close(); 
rs.close();
return bao;

然后在JSP里面写这些代码

ServletOutputStream sos = response.getOutputStream();
baos.writeTo(sos);//baos就是文件流
sos.flush();

这样图片就显示出来了。
[解决办法]

Java code
<%@ page contentType="text/html;charset=GBK"%><%request.setCharacterEncoding("GBK");%><%@ page import="java.util.*" %><%@ page import="javazoom.upload.*"%><%    if (MultipartFormDataRequest.isMultipartFormData(request)) {        MultipartFormDataRequest mrequest = new MultipartFormDataRequest(request);        Hashtable files = mrequest.getFiles();        if ((files != null) || (!files.isEmpty())) {            UploadFile file = (UploadFile) files.get("uploadfile");            String file_name = file.getFileName();            PreparedStatement pstmt=con.prepareStatement("insert into blobtest values(1,?)");            FileInputStream fis = new FileInputStream(file.getInpuStream());                        //把输入流设置为预处理语句的对象。            pstmt.setBinaryStream(1, fis, (int)file.length());                          //执行更新            pstmt.executeUpdate();                                pstmt.close();                }        }
[解决办法]
<%@ page contentType="text/html; charset=UTF-8"%>
<%@ page import="java.sql.*"%>
<%@ page import="java.io.*"%>
<jsp:useBean id="sqlConn" scope="application" class="dgeip.OraconnDg"/>
<%

Connection con=null;
Statement stmt=null;
try{
con=sqlConn.getConnection();
stmt=con.createStatement();//数据库的连接
String sql="select * from dd_model WHERE model_no='07002'";
ResultSet rs=stmt.executeQuery(sql);
rs.next();
InputStream in=rs.getBinaryStream("shoe_pic");
response.reset();
response.setContentType("image/jpeg");
byte[] b=new byte[1024];
int len;
while((len=in.read(b))>0)
{
response.getOutputStream().write(b,0,len); 
}
out.clear();
out = pageContext.pushBody();
in.close();
rs.close();
stmt.close();
con.close();


}
catch (Exception e){
out.println(e.getMessage());
}
%>

直接加上
out.clear();
out = pageContext.pushBody();
就OK了,试试

热点排行