java读取图片到页面_JAVA 读取 数据库中的图片显示到页面

我想写一个方法,往里传参数,例如传个图片ID,然后返回数据,显示到前台页面为图片,不知道怎么写了。请大家帮助一下。----------------------------------------------------------...

我想写一个方法,往里传参数,例如传个图片ID,然后返回数据,显示到前台页面为图片,不知道怎么写了。请大家帮助一下。

---------------------------------------------------------

----------------------------------------------------------

----------------------------------------------------------

我这里有个 直接在JSP 页面 写,显示图片的方法,但是这样写 代码太多,而且其他地方 也没法调用。

===

String showImage = " select * "+

" from t_attachment "+

" where upload_id='1210832040218' " ;

BufferedInputStream inputImage = null;

try{

Statement st = conn.createStatement();

ResultSet rs=st.executeQuery(showImage);

String filename="";

while(rs.next()) {

Blob blob = (Blob)rs.getBlob("BINARYFILE");

filename=rs.getString("FILENAME");

inputImage = new BufferedInputStream(blob.getBinaryStream());

}

BufferedImage image = null;

image=ImageIO.read(inputImage);

ServletOutputStream sos = response.getOutputStream();

JPEGImageEncoder encoder = JPEGCodec.createJPEGEncoder(sos);

encoder.encode(image);

inputImage.close();

} catch(SQLException se) {

se.printStackTrace();

} catch(IOException ie) {

ie.printStackTrace();

}

%>

catch(Exception e){

}

finally{

closeConn(conn);

}

%>

展开

您可以使用JSP和Java代码从数据库读取图片并将其显示在网页上。以下是一些步骤: 1. 在数据库创建一个BLOB类型的字段,用于存储图片的二进制数据。 2. 将图片转换为字节数组并将其保存到数据库。您可以使用Java的FileInputStream和ByteArrayOutputStream类来完成此操作。 3. 在JSP页面,使用Java代码从数据库检索图像数据。您可以使用JDBC API的ResultSet类来检索数据。 4. 将字节数组转换为图像,并将其显示在网页上。您可以使用JavaImageIO类来完成此操作。 下面是一个简单的示例代码,它演示了如何从数据库读取图像并将其显示在JSP页面上: ``` <%@page import="java.sql.*"%> <%@page import="java.io.*"%> <%@page import="javax.imageio.*"%> <%@page import="javax.servlet.http.*"%> <% // 获取图像ID int imageId = Integer.parseInt(request.getParameter("imageId")); // 从数据库检索图像数据 byte[] imageData = null; try { Connection conn = DriverManager.getConnection("jdbc:mysql://localhost/mydatabase", "myuser", "mypassword"); PreparedStatement stmt = conn.prepareStatement("SELECT image_data FROM images WHERE image_id = ?"); stmt.setInt(1, imageId); ResultSet rs = stmt.executeQuery(); if (rs.next()) { imageData = rs.getBytes("image_data"); } rs.close(); stmt.close(); conn.close(); } catch (SQLException e) { e.printStackTrace(); } // 将字节数组转换为图像 BufferedImage image = null; try { ByteArrayInputStream bis = new ByteArrayInputStream(imageData); image = ImageIO.read(bis); } catch (IOException e) { e.printStackTrace(); } // 在网页上显示图像 response.setContentType("image/jpeg"); OutputStream out = response.getOutputStream(); ImageIO.write(image, "jpg", out); out.close(); %> ``` 在上面的示例,我们从请求参数获取图像ID,并使用JDBC API从数据库检索图像数据。然后,我们将图像数据转换为图像,并将其写入响应流,以便在网页上显示。请注意,我们将响应类型设置为“image/jpeg”,因为我们使用的是JPEG格式的图像。如果您使用的是其他格式的图像,请相应地更改响应类型。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值