前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >使用SpringBoot上传文件并存储至数据库

使用SpringBoot上传文件并存储至数据库

作者头像
全栈程序员站长
发布2022-08-31 10:49:53
2.8K0
发布2022-08-31 10:49:53
举报

大家好,又见面了,我是你们的朋友全栈君。

springboot 2.2.1.RELEASE

代码语言:javascript
复制
	<dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-jdbc</artifactId>
        </dependency>
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-jpa</artifactId>
        </dependency>

由于是演示上传文件,并将文件存储进数据库,所以这里简单的使用JPA 进行单表处理

建表语句如下:

代码语言:javascript
复制
CREATE TABLE `image` (
  `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '主键',
  `image` longblob NOT NULL COMMENT '图片文件',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8

domain类如下:

代码语言:javascript
复制
@Table(name="image")
@Entity
@Data
public class ImageFile { 
   
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Integer id;

    @Column(name = "image",columnDefinition = "imageBlob")
    private byte[] imageBytes;

}

这里简单的使用下JPA,如下:

代码语言:javascript
复制
@Repository
public interface ImageRepository extends JpaRepository<ImageFile,Integer> { 
   
}

JPA是基于反射的机制来动态构成SQL,执行SQL

注意点:

  • 上传文件需要指定类型为MultiPartFile,如果要上传多文件,使用MultiPartFile[]
  • 文件对应到数据库类型是blob/longblob等,在处理的时候,获取文件的字节数据 直接存储即可。

Controller控制器

代码语言:javascript
复制
 @Autowired
    private ImageRepository imageRepository;
    @PostMapping
    public void upload(@RequestParam("file") MultipartFile file, @RequestParam("id")Integer id, HttpServletRequest request) throws IOException { 
   
        byte[] bytes = file.getBytes();
        ImageFile imageFile=new ImageFile();
        imageFile.setImageBytes(bytes);

        imageRepository.save(imageFile);

    }

使用MyBatis处理,方式类似:

代码语言:javascript
复制
<insert id="insert" parameterType="com.wojiushiwo.ImageFile">
insert into image
values(#{ 
   image})
</insert>

至此 将文件上传存储至数据库即完成。

下面展示如果从数据库中获取存储的二进制文件,并处理(这里还原二进制文件)

代码语言:javascript
复制
 @GetMapping
    public void getById(@RequestParam("id")Integer id, @Nullable Integer abc) throws IOException { 
   

        Optional<ImageFile> imageFile = imageRepository.findById(id);
        if(imageFile.isPresent()){ 
   
            byte[] imageBytes = imageFile.get().getImageBytes();
            ByteArrayInputStream inputStream=new ByteArrayInputStream(imageBytes);
			//将二进制字节数组 转为文件
            Files.copy(inputStream, Paths.get("/Users/wojiushiwo/Desktop/1.jpg"));
        }

    }
实现表单数据与文件同时上传

domain类:

代码语言:javascript
复制
//这里是lombok jar包的注解
@Data
public class User { 
   

    private Integer userId;

    private String name;

    private MultipartFile file;
}

controller类:

代码语言:javascript
复制
@PostMapping(value = "/upload")
    public void upload(User user){ 
   
        // 这里就可以对传入的参数进行业务处理了
    }

问题1 Data too long for column ‘image’ at row 1’

原因及解决方式:上传的文件太大了,使用blob类型不行了,将数据库表中image的数据类型改为longblob

问题2 Table ‘…hibernate_sequence’ doesn’t exist 这个与主键的生成策略有关,只需要将id的生成策略由@GeneratedValue==>@GeneratedValue(strategy = GenerationType.IDENTITY)

可参考主键生成策略问题

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/143927.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022年5月2,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 实现表单数据与文件同时上传
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档