JDBC--(8)数据库存储图片、从数据库中获取图片

JDBC 存储图片

数据库当中的BLOB
存储图片、音频、视频等多媒体信息
以二进制流的形式
真正开发中
不会把二进制的文件存放在数据库当中
把文件存储的路径保存在数据库当中,以后再取出路径,到该路径下读取信息
BLOB类型
TINYBLOB 255个字节
BLOB 65535字节
MEDIUMBLOB 16M
LONGBLOB 4G

操纵:

  1. 在表中添加一个字段,类型选择为blob类型

  2. 通过代码存入一张图片到数据库当中

  3. 从数据库当中把存储的图片取出

在这里插入图片描述

package com.iris.jdbc.test;

import java.io.FileInputStream;
import java.sql.Connection;
import java.sql.PreparedStatement;
import com.iris.jdbc.util.JDBCUtil;

public class BlobTest {
	public static void main(String[] args) throws Exception  {
		Connection conn = JDBCUtil.getConn();
		String sql = "insert into student (img) values(?)";
		
		PreparedStatement ps = conn.prepareStatement(sql);
		//读取磁盘当中的文件,转成计算机能够识别的二进制
		//输入流 InputStream 
		// 将电脑当中的文件放到程序当中(是以二进流)输入流
		FileInputStream in = new FileInputStream("f:/截图/引用类型_地址传递/5.png");
		ps.setBlob(1,in);
		ps.executeUpdate();
		
		JDBCUtil.close(conn, ps, null);
	}
}

JDBC 从数据库中获取图片

package com.iris.jdbc.test;

import java.io.InputStream;
import java.nio.file.Files;
import java.nio.file.Paths;
import java.sql.Blob;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import com.iris.jdbc.util.JDBCUtil;

public class GetPictureTest {
	public static void main(String[] args) throws Exception {
		//连接数据库
		Connection conn = JDBCUtil.getConn();
		String sql = "select * from student where id =?";
		PreparedStatement ps = conn.prepareStatement(sql);
		ps.setInt(1, 1);
		
		ResultSet res = ps.executeQuery();
		 if(res.next()) {
			 //获取图片
			 Blob blob = res.getBlob("img");
			 //获取图片二进制流
			 InputStream in = blob.getBinaryStream();
			 //把程序当中的文件写到磁盘
			 Files.copy(in, Paths.get("f:/截图/mysql.png"));
		 }
		 JDBCUtil.close(conn, ps, res);
	}
}

  • 2
    点赞
  • 29
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
首先,需要在JSP页面使用form表单来上传文件,并且添加enctype属性来指定form表单的编码类型为multipart/form-data,示例如下: ``` <form action="upload.jsp" method="post" enctype="multipart/form-data"> <input type="file" name="file"> <input type="submit" value="上传"> </form> ``` 然后,在后台的upload.jsp页面,需要使用Commons FileUpload组件来处理上传的文件,并将文件存储数据库。可以按照以下步骤进行操作: 1. 创建DiskFileItemFactory对象,并设置缓冲区大小和临时文件存储路径: ``` DiskFileItemFactory factory = new DiskFileItemFactory(); factory.setSizeThreshold(4096); factory.setRepository(new File("D:/temp")); ``` 2. 创建ServletFileUpload对象,并设置文件上传的最大值和编码格式: ``` ServletFileUpload upload = new ServletFileUpload(factory); upload.setSizeMax(1024*1024*10); //设置文件上传的最大值为10M upload.setHeaderEncoding("UTF-8"); //设置编码格式为UTF-8 ``` 3. 解析请求,获取上传的文件: ``` List<FileItem> items = upload.parseRequest(request); for (FileItem item : items) { if (!item.isFormField()) { //判断是否为文件域 String filename = item.getName(); //获取文件名 InputStream in = item.getInputStream(); //获取文件输入流 //将文件存储数据库 //... } } ``` 4. 将文件存储数据库: ``` //获取数据库连接 Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/test", "root", "root"); PreparedStatement pstmt = null; //插入数据的SQL语句 String sql = "INSERT INTO image (name, content) VALUES (?, ?)"; try { pstmt = conn.prepareStatement(sql); pstmt.setString(1, filename); pstmt.setBinaryStream(2, in, in.available()); pstmt.executeUpdate(); } catch (SQLException e) { e.printStackTrace(); } finally { //关闭数据库连接和输入流 if (pstmt != null) { try { pstmt.close(); } catch (SQLException e) { e.printStackTrace(); } } if (in != null) { try { in.close(); } catch (IOException e) { e.printStackTrace(); } } if (conn != null) { try { conn.close(); } catch (SQLException e) { e.printStackTrace(); } } } ``` 以上就是使用Commons FileUpload组件将图片上传到数据库的基本步骤。需要注意的是,在实际应用,还需要进行文件类型、大小、重名等的校验,以及异常处理等操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值