论坛登陆 用户名:  密 码:
设为首页  加入收藏
08年北京名校秋季招生
名牌院校免试入学宽进严出,突破考分限制,名校与你零距离,以下院校按报名先后顺序录取,24小时网上报名覆盖全国
  您现在的位置: 中国教育招生在线 >> IT >> JAVA认证 >> IT正文
从数据库中读取并生成图片的Servlet
 作者:佚名     2007-3-14 17:20:36        来源:不详  浏览次数:


 

 

 

 

 

 

 

 

作者:邵望


日期:2000-12-24 21:44:55


大体思路


1)创建ServletOutputStream对象out,用于以字节流的方式输出图像


2)查询数据库,用getBinaryStream方法返回InputStream对象in


3)创建byte数组用作缓冲,将in读入buf[],再由out输出



注:下面的例程中数据库连接用了ConnectionPool,以及参数的获得进行了预处理



package net.seasky.music;



import javax.servlet.*;


import javax.servlet.http.*;


import java.io.*;


import java.util.*;


import java.sql.*;


import net.seasky.util.*;


import net.seasky.database.DbConnectionManager;



public class CoverServlet extends HttpServlet {


private static final String CONTENT_TYPE = "image/gif";


public void init(ServletConfig config) throws ServletException {


super.init(config);


}



public void doGet(HttpServletRequest request, HttpServletResponse response


) throws ServletException, IOException {


response.setContentType(CONTENT_TYPE);


int albumID;


ServletOutputStream out = response.getOutputStream();


try {


albumID = ParamManager.getIntParameter(request,"albumID",0);


}


catch (Exception e) {


response.sendRedirect("../ErroePage.jsp");


return;


}


try {


InputStream in=this.getCover(albumID);


int len;


byte buf[]=new byte[1024];


while ((len=in.read(buf,0,1024))!=-1) {


out.write(buf,0,len);


}


}


catch (IOException ioe) {


ioe.printStackTrace() ;


}


}



private InputStream getCover(int albumID) {


InputStream in=null;


Connection cn = null;


PreparedStatement pst = null;


try {


cn=DbConnectionManager.getConnection();


cn.setCatalog("music");


pst=cn.prepareStatement("SELECT img FROM cover where ID =?");


pst.setInt(1,albumID);


ResultSet rs=pst.executeQuery();


rs.next() ;


in=rs.getBinaryStream("img");


}


catch (SQLException sqle) {


System.err.println("Error in CoverServlet : getCover()-" + sqle);


sqle.printStackTrace() ;


}


finally {


try {


pst.close() ;


cn.close() ;


}


catch (Exception e) {


e.printStackTrace();


}


}


return in;


}



public void destroy() {


}


}

 

责任编辑:lss
  相关新闻
程序员考试:数据结构笔记
《数据结构》(严蔚民)配套纯C代码下载
数据库之——Hibernate实现级联删除
数据库系统工程师:数据库原理各章节简答题总结
2006年9月23日计算机等级考试三级数据库标准试卷
【JAVA基础】JDBC连接DB2数据库详解
Oracle下调数据库许可价格 以适应多芯CPU
Oracle数据仓库查询优化技术
2006年软考程序员数据结构复习笔记
如何有效管理Exchange的数据管理
三级数据库备考经验——三级,并不难
程序员考试:数据结构笔记
《数据结构》(严蔚民)配套纯C代码下载
计算机硬件\数据结构\标准化考试模块指导
2006年软考程序员数据结构复习笔记
《数据结构(C++)》学习辅导系列:序言
《数据结构(C++)》学习辅导系列:栈和队列
《数据结构(C++)》学习辅导系列:队列应用
数据库系统工程师:NBU备份ORACLE时Code 29错误
数据库系统工程师:数据库原理各章节简答题总结
  评论
现在有100人对本文发表评论
查看所有评论
 
推  荐
 
100本成功必读热销书
热门招生
  北京文理研修学院   前进大学
  北京明园大学   北京建设大学
  北京邮电大学世纪学院   北方工商管理学院
  联想软件定向委培班   香港数码动画学院
  青年企业管理研修学院   北京华夏管理学院
热门培训
网络化办公专家培训认证 电子科技大学软件学院
软件测试工程师培训认证 北大青鸟十大授权培训
IT硬件工程师培训认证班 北京环球雅思荷兰预科
JAVA开发工程师培训 潜能时代IT服务管理培训
网络信息化工程师培训 清华大学继续教育学院
论坛精选
 
有些细节是男人也该注意的风度!最容易读错的字
某强人手机里保存的30条短信 中国十大高薪职业
最感人的十大韩剧经典台词 嫁给工程师的N个理由
爆强!只有一句话的鬼故事 转贴教你如何做妖精
 女人一定要記住的話 女人最好别嫁给最爱的男人
城市联盟
 大连 上海 天津 广州 西安 深圳  天津  青岛  大连  福州  沈阳  青海  连云港  南京  吉林  厦门  威海  辽宁  呼和浩特
Copyright © 2006   www.edu999.com   All rights reserved. 中国教育招生在线  版权所有
北京市通信管理局[2004]字第552号函    京ICP证040442号