jsp远程存图片入ORACLE

只要大家将连接数据库的参数改一下就可以了。     
SQL>create   table   image(id   int,content   varchar(200),image   blob);     
如果在sqlserver2000的数据库中,可以将blob字段换为image类型,这在SqlServer2000中是新增的。

testimage.html文件内容如下:

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
 <HTML>    
  <HEAD>    
  <TITLE>Image   File   </TITLE>    
  <meta   http-equiv="Content-Type"   content="text/html;   charset=gb2312">    
  </HEAD>    
  <FORM   METHOD=POST   ACTION="testimage.jsp">    
  <INPUT   TYPE="text"   NAME="content"><BR>    
  <INPUT   TYPE="file"   NAME="image"><BR>    
  <INPUT   TYPE="submit"></FORM>    
  <BODY>    
  </BODY>    
 </HTML>    

我们在Form的action里定义了一个动作testimage.jsp,它的内容如下:
<%@   page contentType="text/html;charset=gb2312"%>
<%@   page import="java.sql.*"%>
<%@   page import="java.util.*"%>
<%@   page import="java.text.*"%>
<%@   page import="java.io.*"%>
<html>
 <body>    
  <%
  Class.forName("oracle.jdbc.OracleDriver");  
  Connection   conn=   DriverManager.getConnection(
             "jdbc:oracle:thin:@192.100.1.70:1521:qqdb",
             "qqdb",
             "qqdb");
  //Class.forName("oracle.jdbc.driver.OracleDriver").newInstance();
  //String   url="jdbc:mysql://localhost/mysql?user=ccdb&password=ccdb&useUnicode=true&characterEncoding=8859_1";    
  //其中mysql为你数据库的名字,user为你连接数据库的用户,password为你连接数据库用户的密码,可自己改    
  //Connection   conn=   DriverManager.getConnection(url);            
  String   content=request.getParameter("content");    
  String   filename=request.getParameter("image");    
  FileInputStream   str=new   FileInputStream(filename);    
  String   sql="insert   into   image(id,content,image)   values(1,?,?)";    
  PreparedStatement   pstmt=conn.prepareStatement(sql);    
  pstmt.setString(1,content);    
  pstmt.setBinaryStream(2,str,str.available());    
  pstmt.execute();    
  out.println("Success,You   Have   Insert   an   Image   Successfully");    
  %>
 </body>
</html>
写一个测试image输出的例子看我们上面程序写的对不对,testimageout.jsp的内容如下:  

  <%@   page   contentType="text/html;charset=gb2312"%>    
  <%@   page   import="java.sql.*"%>    
  <%@   page   import="java.util.*"%>    
  <%@   page   import="java.text.*"%>    
  <%@   page   import="java.io.*"%>    
  <html>    
  <body>    
  <%
  //Class.forName("oracle.jdbc.driver.OracleDriver").newInstance();    
  //String   url="jdbc:mysql://localhost/mysql?user=ccdb&password=ccdb&useUnicode=true&characterEncoding=8859_1";    
  //其中mysql为你数据库的名字,user为你连接数据库的用户,password为你连接数据库用户的密码,可自己改    
  //Connection   conn=   DriverManager.getConnection(url);    
  Class.forName("oracle.jdbc.OracleDriver");   
  Connection   conn=   DriverManager.getConnection(
             "jdbc:oracle:thin:@192.100.1.70:1521:qqdb",
             "qqdb",
             "qqdb"); 
  String   sql   =   "select   image   from   image   where   id=1";    
  Statement   stmt=null;    
  ResultSet   rs=null;    
  try{    
  stmt=conn.createStatement();    
  rs=stmt.executeQuery(sql);    
  }catch(SQLException   e){}    
  try   {    
  while(rs.next())   {    
  response.setContentType("image/jpeg");    
  ServletOutputStream   sout   =   response.getOutputStream();    
  InputStream   in   =   rs.getBinaryStream(1);    
  byte   b[]   =   new   byte[0x7a120];    
  for(int   i   =   in.read(b);   i   !=   -1;)    
  {    
  sout.write(b);    
  in.read(b);    
  }    
  sout.flush();    
  sout.close();    
  }    
  }    
  catch(Exception   e){System.out.println(e);}    
  %>    
  </body>    
  </html>       

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值