|
![]() |
名片设计 CorelDRAW Illustrator AuotoCAD Painter 其他软件 Photoshop Fireworks Flash |
|
<%@ page contentType="text/html;charset=gb2312"%> <%@ page import="java.sql.*,java.io.*,java.awt.Image,java.awt.image.*,com.sun.image.codec.jpeg.*"%> <html> <body> <% /* drop table imagetable; create table imagetable ( nid int not null, image blob, primary key (nid) ) type = InnoDB; */ /* //==== 一 、将文件写入到数据库的大字段中begin============= Class.forName("org.gjt.mm.mysql.Driver").newInstance(); String url ="jdbc:mysql://localhost:3306/test?user=root&password=eastsoftweb"; Connection conn= DriverManager.getConnection(url); java.io.File file = new File("d:/temp/1.jpg"); FileInputStream is=new FileInputStream(file); PreparedStatement stmt = conn.prepareStatement( "INSERT INTO imagetable (nid,image)" + "VALUES (?, ?)"); //预编译SQL语句 stmt.setInt(1, 1); stmt.setBinaryStream(2, is,(int)file.length()); stmt.executeUpdate(); stmt.close(); is.close(); out.println("update end"); //======将文件写入到数据库的大字段中end============== */ /* //=== 二、jsp显示服务器硬盘图片示例 begin============== FileInputStream is=new FileInputStream("d:/temp/1.JPG"); response.reset(); response.setContentType("image/jpeg"); ServletOutputStream sos = response.getOutputStream(); byte[] buffer = new byte[1024]; int len=0; while((len=is.read(buffer))>0){ sos.write(buffer,0,len); } sos.flush(); sos.close(); //===jsp显示服务器硬盘图片示例 end=============== */ //==== 三、将数据库的大字段图片还原到本地,并在网页上显示begin==Class.forName("org.gjt.mm.mysql.Driver").newInstance(); String url ="jdbc:mysql://localhost:3306/test?user=root&password=eastsoftweb"; Connection conn= DriverManager.getConnection(url); java.io.File file = new File("d:/temp/db.jpg"); FileOutputStream os=new FileOutputStream(file); Statement stmt=conn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_READ_ONLY); ResultSet rs=stmt.executeQuery("select nid,image from imagetable where nid=1"); rs.next(); byte[] buffer=rs.getBytes(2); stmt.close(); os.write(buffer); os.flush(); os.close(); out.println("query end"); //网页上显示 response.reset(); response.setContentType("image/jpeg"); ServletOutputStream sos = response.getOutputStream(); sos.write(buffer); sos.flush(); sos.close(); //====将数据库的大字段图片还原到本地,并在网页上显示end====== /* //========四、生成缩略图begin================ File file = new File("d:/temp/1.JPG"); String newurl="d:/temp/2.jpg"; //新的缩略图保存地址 Image src = javax.imageio.ImageIO.read(file); //构造Image对象 float tagsize=200; int old_w=src.getWidth(null); //得到源图宽 int old_h=src.getHeight(null); int new_w=0; int new_h=0; //得到源图长 int tempsize; float tempdouble; if(old_w>old_h){ tempdouble=old_w/tagsize; }else{ tempdouble=old_h/tagsize; } new_w=Math.round(old_w/tempdouble); new_h=Math.round(old_h/tempdouble);//计算新图长宽 BufferedImage tag = new BufferedImage(new_w,new_h,BufferedImage.TYPE_INT_RGB); tag.getGraphics().drawImage(src,0,0,new_w,new_h,null); //绘制缩小后的图 FileOutputStream newimage=new FileOutputStream(newurl); //输出到文件流 JPEGImageEncoder encoder = JPEGCodec.createJPEGEncoder(newimage); encoder.encode(tag); //近JPEG编码 newimage.close(); //=====生成缩略图end===================== */ %> 返回类别: 教程 上一教程: JSTL简化JSP编码 下一教程: 透过 JAVA 参数来改善 JAVA 效能 您可以阅读与"JSP中图片处理相关操作"相关的教程: · JSP中图片验证的实现 · Java API的Date, Calendar日期处理相关类分析 · 在Web应用中图片和长文本的处理策略总结 · 用JSP从数据库中读取图片并显示在网页上 · 纯 jsp 操作服务器上的文本文件 [2] |
![]() ![]() |
快精灵印艺坊 版权所有 |
首页![]() ![]() ![]() ![]() ![]() ![]() ![]() |