SpringBoot上传图片以Blob格式存储在Mysql

本文记录了在SpringBoot项目中实现图片以Blob格式存储到Mysql数据库的过程,涉及Mysql的Blob类型选择、SpringBoot配置、实体结构设计、图片存储与读取方法,以及遇到的问题和解决方案,特别提醒了图片数据存储为Base64编码后的格式,需要解码后才能正常显示。
摘要由CSDN通过智能技术生成

前言

最近需要用到上传图标的功能,由于数据量较小,所以直接存储在数据库中,踩了很多坑,以此记录一下

说明

我用的是MariaDB数据库,版本是10.4.0,和Mysql是一样的,下面以kotlin来举例说明,其他语言可对照参考

Mysql的Blob类型

MySQL有四种BLOB类型:
  ·tinyblob:仅255个字符
  ·blob:最大限制到65K字节
  ·mediumblob:限制到16M字节
  ·longblob:可达4GB

SpringBoot的配置

#配置文件传输
spring:
  servlet:
    multipart:
      enabled: true
      #单个文件的大小
      max-file-size: 20MB
	  #总数据的大小
      max-request-size: 20MB

实体结构

@Table(name = "picture")
open class Picture: Serializable {
   

    private val serialVersionUID = 1L
    /** id */
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    @Column(name = "id")
    var id: Int? = null
    
    @JSONField(name = 
### 回答1: 可以使用 Spring Boot 中的 JPA 来存储图片MySQL 数据库。首先,在数据库中建立一张表,其中一列用来存储图片,类型为 BLOB。然后在实体类中使用 `@Lob` 注解将该字段映射到 BLOB类型。在存储图片时,可以将图片转换为字节数组,并将其存储到对应的字段中。 ### 回答2: Spring Boot是一个极为方便的应用框架,可以帮助开发者快速地构建出各种应用。在进行web应用开发的过程中,经常需要实现图片的上传、处理和存储等功能,而本文将从如何使用Spring Boot的方式进行图片存储Mysql数据库的操作方法介绍。 首先,我们需要为Spring Boot应用添加对MySQL数据库的支持,并在pom.xml文件中添加相关的依赖,如下所示: ``` <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-jpa</artifactId> </dependency> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> </dependency> ``` 在创建实体类时,需要使用JPA规范进行注解,在实体类中添加一个属性,用于保存图片的二进制流。 ``` @Entity @Table(name = "image") public class Image { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private int id; private String imageName; private byte[] imageContent; //getter/setter } ``` 接下来,需要编写一个Controller类,用于处理图片上传的请求,代码如下: ``` @RestController @RequestMapping("/image") public class ImageController { private final ImageRepository imageRepository; @Autowired public ImageController(ImageRepository imageRepository) { this.imageRepository = imageRepository; } @PostMapping("/upload") public ResponseEntity<?> upload(@RequestParam("image") MultipartFile multipartFile) { try { Image image = new Image(); image.setImageName(multipartFile.getOriginalFilename()); image.setImageContent(multipartFile.getBytes()); imageRepository.save(image); return new ResponseEntity<>(HttpStatus.OK); } catch (IOException e) { e.printStackTrace(); return new ResponseEntity<>(HttpStatus.BAD_REQUEST); } } } ``` 其中,upload()方法负责处理上传请求,首先从MultipartFile对象中获取文件名和文件内容,将其保存到Image实体类的属性中,然后通过JPA规范中的save()方法将Image对象存储到数据库中。 最后,需要编写一个JpaRepository的接口,继承于CrudRepository,并实现数据访问的方法,代码如下: ``` public interface ImageRepository extends CrudRepository<Image, Integer> { } ``` 接下来,所有的准备工作已经完成了,我们运行起来程序,上传一张名为“test.jpg”的图片成功插入到MySQL数据库中。 综上,本文介绍了使用Spring Boot存储图片MySQL数据库的方法,主要包括添加MySQL依赖,实现图片存储的实体类和Controller类以及访问数据的repository接口各个步骤。对于图片的上传和存储Spring Boot提供了简便易行的方法,为web开发带来了极大的便利。 ### 回答3: Spring Boot 是一种用于构建独立应用程序的框架,它可以方便地将应用程序部署到不同的平台上。在许多应用程序中,我们可能需要将用户上传的图片保存到数据库中。本文将介绍如何在Spring Boot中将图片存储MySQL数据库中。 在Spring Boot中,使用JPA(Java Persistence API)来管理对象持久化。我们可以通过使用 JPA 来操作数据库中的数据。为了将图片存储MySQL数据库中,需要创建一个表来存储图片的二进制数据。我们可以通过以下代码创建一个名为`Image`的实体类: ```java @Entity @Table(name = "images") public class Image { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private long id; private String name; @Column(name = "image_data") private byte[] data; // getters, setters and constructors } ``` 在上面的代码中,我们使用了`@Entity`和`@Table`注解来指示这是一个实体类,并定义了一个`id`作为主键。我们还用注解`@GeneratedValue`来指定主键的自动生成策略。此外,我们还定义了一个`name`来保存图片名称,并使用`@Column`注解定义了一个`data`字段来保存图片的二进制数据。 接下来,我们需要使用Spring Boot提供的`MultipartFile`类来从上传的文件中读取二进制数据。我们可以使用以下代码将图片保存到MySQL数据库中: ```java @PostMapping("/upload") public ResponseEntity<?> uploadFile(@RequestParam("file") MultipartFile file) { if(file.isEmpty()) { return ResponseEntity.status(HttpStatus.BAD_REQUEST).body("Please select a file to upload"); } try { Image image = new Image(); image.setName(file.getOriginalFilename()); image.setData(file.getBytes()); imageRepository.save(image); return ResponseEntity.ok("File uploaded successfully"); } catch (IOException e) { return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR).body("Error occurred while uploading file"); } } ``` 在上面的代码中,我们首先检查文件是否为空。接下来,我们使用`getBytes()`方法从`MultipartFile`中读取二进制数据,并创建一个`Image`对象。然后调用`imageRepository.save()`将图片保存到MySQL数据库中。 最后,我们可以使用以下代码从MySQL数据库中检索图片: ```java @GetMapping("/{id}") public ResponseEntity<?> getImage(@PathVariable("id") Long id) { Image image = imageRepository.findById(id).orElse(null); if(image == null) { return ResponseEntity.status(HttpStatus.NOT_FOUND).body("Image not found"); } else { return ResponseEntity.ok() .contentType(MediaType.IMAGE_JPEG) .body(new ByteArrayResource(image.getData())); } } ``` 在上面的代码中,我们使用`findById`方法根据ID从MySQL数据库中检索图片。如果找不到图片,则返回一个HTTP 404 Not Found响应。如果找到图片,则返回一个HTTP 200 OK响应,其中的内容类型被设置为JPEG图片,并将图片的二进制数据作为响应主体发送。 总结来说,将图片存储MySQL数据库中是非常容易的,只需要使用Spring Boot提供的JPA和MultipartFile类即可实现。上述代码只是一个简单的示例,你可以根据自己的需求进行修改和扩展。
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值