在现代互联网时代,图片已经成为了信息传递中不可或缺的一部分。大量的网站都需要图片的支持,而对于这些图片的存储和管理,数据库成为了一种非常方便、高效的选择。Java作为现代编程语言中更受欢迎的一种,也可以利用其自带的数据库接口,实现对图片的存储和管理。本篇文章将会详细介绍如何在Java中使用数据库实现图片存储,包括建立数据库连接、创建表结构、存储图片、读取图片等内容。
建立数据库连接
在Java中,我们可以使用JDBC(Java Database Connectivity)来建立与数据库的连接。具体来说,我们需要引入数据库驱动程序,并在代码中使用连接串来建立连接。下面是一个示例代码:
“`
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
public class DbConnector {
Connection conn;
public DbConnector() {
try {
Class.forName(“com.mysql.cj.jdbc.Driver”);
String url = “jdbc:mysql://localhost:3306/mydb?useSSL=false&allowPublicKeyRetrieval=true&serverTimezone=UTC”;
String user = “root”;
String pwd = “password”;
this.conn = DriverManager.getConnection(url, user, pwd);
} catch (ClassNotFoundException | SQLException e) {
e.printStackTrace();
}
}
public Connection getConn() {
return conn;
}
public void close() {
if (this.conn != null) {
try {
this.conn.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
}
}
“`
这个类中定义了一个`Connection`类型的`conn`变量,用于存储连接对象。在构造函数中,我们首先使用`Class.forName()`方法引入了数据库驱动程序。然后,我们定义了一个连接串,其中需要填写具体的数据库地址、用户名和密码。使用`DriverManager.getConnection()`方法,传入连接串即可建立与数据库的连接。注意到在这个连接串中,我们需要使用`allowPublicKeyRetrieval=true`,这是为了避免在使用新版MySQL时需要进行SSL配置的问题。
创建表结构
接下来,我们需要在数据库中创建一个表来存储图片。在这个表中,我们需要为每个图片存储以下信息:
– 图片ID(唯一标识每个图片的ID)
– 图片名称(用于方便查找和管理)
– 图片二进制数据(真正存储图片的数据)
下面是一个示例DDL语句,用于在MySQL数据库中创建这个表:
“`
CREATE TABLE image (
id INT PRIMARY KEY AUTO_INCREMENT,
name VARCHAR(255),
data MEDIUMBLOB
);
“`
这个表中,`id`列是一个自增的整数,作为图片的唯一标识;`name`列是一个长度为255的字符串,用于存储图片的名称;`data`列是一个MEDIUMBLOB类型,用于存储图片的二进制数据。
存储图片
在建立好数据库连接和表结构之后,我们现在可以将图片存储到数据库中了。具体地,我们可以将图片的二进制数据作为一个参数传给`PreparedStatement`对象的`setBytes()`方法,然后执行`executeUpdate()`方法即可完成对图片的存储。下面是一个示例代码:
“`
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.SQLException;
public class DbImage {
public static void storeImage(Connection conn, String name, String filePath) {
String sql = “INSERT INTO image(name, data) VALUES (?, ?)”;
try {
PreparedStatement ps = conn.prepareStatement(sql);
ps.setString(1, name);
InputStream is = new FileInputStream(filePath);
byte[] data = new byte[is.avlable()];
is.read(data);
ps.setBytes(2, data);
ps.executeUpdate();
ps.close();
is.close();
} catch (SQLException | IOException e) {
e.printStackTrace();
}
}
}
“`
这个类中定义了一个`storeImage()`方法,用于将图片存储到数据库中。在这个方法中,我们首先构造了一个`sql`语句,用于表示对数据库中的`image`表执行插入操作。然后,我们使用`PreparedStatement`对象,将`name`和`data`对应的值绑定到`?`占位符上。接下来,我们使用`FileInputStream`读取图片的二进制数据,存储到一个`byte`数组中。我们使用`ps.executeUpdate()`方法执行插入操作,将图片信息存储到数据库中。
读取图片
在将图片存储到数据库中之后,我们现在需要从数据库中读取出来,渲染到网页上。这个过程涉及到从数据库中读取二进制数据,并将其转换为网页可以显示的图片格式。在Java中,我们可以使用`ResultSet`对象的`getBinaryStream()`方法,将MEDIUMBLOB类型的数据读取为一个`InputStream`对象。然后,我们可以使用`BufferedImage`对象将这个二进制流转换成一个可以显示的图片。下面是一个示例代码:
“`
import java.awt.image.BufferedImage;
import java.io.ByteArrayInputStream;
import java.io.IOException;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import javax.imageio.ImageIO;
public class DbImage {
public static BufferedImage loadImage(Connection conn, int id) {
String sql = “SELECT * FROM image WHERE id = ?”;
try {
PreparedStatement ps = conn.prepareStatement(sql);
ps.setInt(1, id);
ResultSet rs = ps.executeQuery();
if (rs.next()) {
ByteArrayInputStream bs = new ByteArrayInputStream(rs.getBytes(“data”));
BufferedImage img = ImageIO.read(bs);
bs.close();
rs.close();
ps.close();
return img;
}
rs.close();
ps.close();
} catch (SQLException | IOException e) {
e.printStackTrace();
}
return null;
}
}
“`
这个类中定义了一个`loadImage()`方法,用于从数据库中读取图片。在这个方法中,我们首先构造了一个`sql`语句,用于表示从数据库中读取ID为`id`的图片信息。然后,我们使用`PreparedStatement`对象,将`id`对应的值绑定到`?`占位符上。接下来,我们使用`ps.executeQuery()`方法执行查询操作,并使用`rs.next()`判断结果集中是否有数据。如果有,我们可以使用`rs.getBytes()`方法读取`data`列中的MEDIUMBLOB类型的二进制流,将其转换成一个`ImageIO`对象,最后返回这个对象。
结语
本篇文章详细介绍了如何在Java中使用数据库实现图片存储。具体来说,我们介绍了如何建立数据库连接、创建表结构、存储图片和读取图片等操作。通过这些基本操作,我们可以快速地实现图片的存储和管理,为现代互联网应用提供更好的体验和支持。希望本篇文章能够对Java初学者和互联网开发者有所帮助。
相关问题拓展阅读:
MySQL 不是文本类数据存储,不能直接存储图片和文件。
可以,用BLOB,但是不推荐这么做,保存路径比较好
数据库中使用blob字段。 不过建议还是存储图片路径吧,数据库的输出流慢的多
这种代码网上不是一大片吗
public boolean storeImage(File file){
纯尺 try{
// 打开文件
FileInputStream fin = new FileInputStream(file);
// 建一个缓冲保存数据
ByteBuffer nbf = ByteBuffer.allocate((int) file.length());
byte array = new byte;
int offset = 0, length = 0;
薯老 // 读存数据
while((length = fin.read(array)) > 0){
if(length != 1024) nbf.put(array,0,length);
else nbf.put(array);
offset += length;
}
// 关闭文件
fin.close();
// 新建一个数组保存要写的内容
byte content = nbf.array();
String sql = “insert into images (bin_data) values (?) “;
PreparedStatement pstmt = conn.prepareStatement(sql);
pstmt.setBytes(1,content);
pstmt.execute();
pstmt.close();
}catch(Exception e){
e.printStackTrace();
return false;
}
数裤升 return true;
}
关于java数据库存储图片的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。
创新互联服务器托管拥有成都T3+级标准机房资源,具备完善的安防设施、三线及BGP网络接入带宽达10T,机柜接入千兆交换机,能够有效保证服务器托管业务安全、可靠、稳定、高效运行;创新互联专注于成都服务器托管租用十余年,得到成都等地区行业客户的一致认可。
本文题目:Java数据库实现图片存储详解(java数据库存储图片)
地址分享:http://www.mswzjz.cn/qtweb/news22/474222.html
攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 贝锐智能