电信主站 网通分站
购买流程 付款方式 常见问题 在线提问 续租服务 购物车
用户名: 密 码: 忘记密码?
首 页
域名注册
虚拟主机
双线主机
服务器租用
VPS主机
企业邮局
代理专区
客服中心
虚拟主机行业资讯 虚拟主机评测对比 互联网最新动态 技术学院 站长资讯 在线教程 网站运营
搜索优化 服务器 网络编程 图形图象 站长之家 网页制作 操作系统
冲浪宝典 软件教学 视频通信 办公软件 邮件系统 网络安全 认证考试
您当前位置:西部数码->资讯中心-> 在线教程-> JSP教程
在java应用程序中显示数据库的blob图像-JSP教程,Java技巧及代码
作者:网友供稿 点击:47
  西部数码-全国虚拟主机10强!20余项虚拟主机管理功能,全国领先!第6代双线路虚拟主机,南北访问畅通无阻!虚拟主机可在线rar解压,自动数据恢复设置虚拟目录等.虚拟主机免费赠送访问统计,企业邮局.Cn域名注册10元/年,自助建站480元起,免费试用7天,满意再付款!P4主机租用799元/月.月付免压金!
文章页数:[1] 
 

原理:

<1> 从数据库中读取blob到blob对象. blob blob = rs.getblob(2);

<2>把blob传给stream.

<3>用stream参数创建image对象

<4>显示image对象.

说明: 这只是例子, 没有考虑其他方面. 希望大家能对java连接数据库,和取对象有个具体的了解.

关于数据库的sql

create table photo (
photo_no int(6) unsigned not null auto_increment,
image blob,
primary key (`photo_no`)
)

本例子用到两个文件:

drawpanel.java如下

import java.awt.*;
import java.sql.*;
import java.awt.image.*;
import java.io.*;
import javax.swing.*;


/**

* <p>title: </p>
*
* <p>description:vincentlaw@163.com </p>
*
* <p>copyright: copyright (c) 2005</p>
*
* <p>vincent</p>
*
* @author vincent
* @version 1.0
*/

public class drawpanel extends panel {
image im;
insets insets;

public drawpanel() {
im=toolkit.getdefaulttoolkit().getimage("c:1.jpg"); //默认的文件
try {
jbinit();
} catch (exception ex) {
ex.printstacktrace();
}

}

public void addnotify() {
super.addnotify();
insets = getinsets();
setbounds(100, 100, 217 + insets.left, 321 + insets.top);
}

public void paint(graphics g) {
g.drawimage(im, insets.left, insets.top, this);
}

private void jbinit() throws exception {
}
public void changeimage(string filename)
{
try {
//class.forname("oracle.jdbc.driver.oracledriver");
//connection conn = drivermanager.getconnection("jdbc:oracle:thin:@127.0.0.1:1521:orcl2", "user","password");
class.forname("com.mysql.jdbc.driver");
connection conn = drivermanager.getconnection("jdbc:mysql://localhost:3306/job?user=root&password=5672831");
statement stmt = conn.createstatement();
resultset rs = stmt.executequery("select photo_no,photo_image from photo");
rs.next();
blob blob = rs.getblob(2);
// 数据库连接
inputstream fin = blob.getbinarystream();
im = javax.imageio.imageio.read(fin);
rs.close();
stmt.close();
conn.close();
}
catch(exception e)
{
e.printstacktrace();
joptionpane.showmessagedialog(null,"错误,装载本地文件");
im=toolkit.getdefaulttoolkit().getimage(filename);
}

this.repaint();
}
}

showimage.java如下:


import java.awt.borderlayout;
import java.awt.*;
import javax.swing.*;
import javax.swing.jtogglebutton;
import java.awt.event.actionevent;
import java.awt.event.actionlistener;

/**

* <p>title: </p>
*
* <p>description:vincentlaw@163.com </p>
*
* <p>copyright: copyright (c) 2005</p>
*
* <p>vincent</p>
*
* @author vincent
* @version 1.0
*/
public class showimage extends jframe {
borderlayout borderlayout1 = new borderlayout();
jtogglebutton jtogglebutton1 = new jtogglebutton();
drawpanel panel=new drawpanel();


public showimage() {
try {
jbinit();
} catch (exception exception) {
exception.printstacktrace();
}
}

private void jbinit() throws exception {
getcontentpane().setlayout(borderlayout1);
jtogglebutton1.settext("jtogglebutton1");
jtogglebutton1.addactionlistener(new
showimage_jtogglebutton1_actionadapter(this));
this.getcontentpane().add(jtogglebutton1, java.awt.borderlayout.north);
this.getcontentpane().add(panel,java.awt.borderlayout.center);
}

public void jtogglebutton1_actionperformed(actionevent e) {
panel.changeimage("e:photohoto1281.jpg"); //备用图像文件
}

public final static void main(string[] args){
jframe frame=new showimage();
frame.setsize(800,600);
frame.setdefaultcloseoperation(jframe.exit_on_close);
frame.setvisible(true);
}
}


class showimage_jtogglebutton1_actionadapter implements actionlistener {
private showimage adaptee;
showimage_jtogglebutton1_actionadapter(showimage adaptee) {
this.adaptee = adaptee;
}

public void actionperformed(actionevent e) {

adaptee.jtogglebutton1_actionperformed(e);
}

}


文章整理:西部数码--专业提供域名注册虚拟主机服务
http://www.west263.com
以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!
相关主题
文章页数:[1] 
Google
热门文章
·IReport与JasperReport开发详解一-JSP教程,Java技巧及代码
·JSTL(JSP标准标签库)介绍-JSP教程,资料/其它
·格式化输入日期时间控件 JieFormattedDateBox-JSP教程,Java技巧及代码
·JSTL简化JSP编码-JSP教程,Jsp/Servlet
·JUnit和单元测试入门简介-JSP教程,Java技巧及代码
·从数据库中读取一个图片并保存为一个图片文件-JSP教程,数据库相关
·Java Swing入门基础-JSP教程,Java技巧及代码
·IntelliJ IDEA培训-JSP教程,Java技巧及代码
·通过JSP的预编译消除性能瓶颈-JSP教程,Jsp/Servlet
·Java中利用JMF编写摄像头拍照程序-JSP教程,Java技巧及代码

最新文章
·J2ME中的时间处理方法
·J2ME播放声音流程简介
·J2ME开发之手机键盘使用注意问题
·J2ME 记录管理存储
·MVC模式在j2me项目中的应用(二)
·MVC模式在j2me项目中的应用(一)
·J2ME中使用记录存储系统(RMS)存储信息
·J2ME与MIDP开发(1)
·用简单的J2ME程序测试MIDlet的生命周期
·JAVA基础:提升JSP应用程序的七大绝招


 
 


版权申明:本站文章均来自网络,如有侵权,请联系我们,我们收到后立即删除,谢谢!

特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有。
  打印  刷新  关闭
返回首页 |关于我们 | 联系我们 | 付款方式 | 创业联盟 | 虚拟主机 | 资讯中心 | 友情链接 | 网站地图

版权所有 西部数码(www.west263.com)
CopyRight (c) 2002~2006 west263.com all right reserved.
公司地址:四川成都市万和路90号天象大厦4楼 邮编:610031
电话总机:028-86262244 86263048 86263408 86263960 86264018 86267838
售前咨询:总机转201 202 203 204 206 208
售后服务:总机转211 212 213 214
财务咨询:总机转224 223 传真:028-86264041 财务QQ:点击发送消息给对方635483282
售前咨询QQ:点击发送消息给对方2182518 点击发送消息给对方241975952 点击发送消息给对方275026793 点击发送消息给对方408235859
售后服务QQ:点击发送消息给对方17708515 点击发送消息给对方307742704 点击发送消息给对方287976517 点击发送消息给对方363783715
《中华人民共和国增值电信业务经营许可证》编号:川B2-20030065号