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

使用SpringBoot上传文件并存储至数据库springboot2.2.1.RELEASE <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId><…

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

springboot 2.2.1.RELEASE

	<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 进行单表处理

建表语句如下:

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类如下:

@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,如下:

@Repository
public interface ImageRepository extends JpaRepository<ImageFile,Integer> { 
   
}

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

注意点:

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

Controller控制器

 @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处理,方式类似:

<insert id="insert" parameterType="com.wojiushiwo.ImageFile">
insert into image
values(#{ 
   image})
</insert>

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

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

 @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类:

//这里是lombok jar包的注解
@Data
public class User { 
   

    private Integer userId;

    private String name;

    private MultipartFile file;
}

controller类:

@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.net/143927.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 【SpringBoot】46、SpringBoot中整合JWT实现Token验证(拦截器篇)

    【SpringBoot】46、SpringBoot中整合JWT实现Token验证(拦截器篇)前言上篇文章我们已经实现了使用自定义注解验证token信息,这样我们就会发现,当我们需要验证的接口较多时,我们需要每个方法上面都加上@JwtToken这个注解,也是非常麻烦,本片文章,我们继续使用拦截器来实现token信息的验证如果对整合JWT还不熟悉的朋友,可以先看看我的这篇博客:【SpringBoot】四十四、SpringBoot中整合JWT实现Token验证(整合篇)如果对自定义注解验证token信息感兴趣的朋友,可以看看我的这篇博客:【SpringBoot】四十五、Spr

    2022年7月25日
    40
  • 机顶盒知识详解_罗盘的知识与技巧

    机顶盒知识详解_罗盘的知识与技巧机顶盒定义数字视频变换盒(英语:SetTopBox,简称STB),通常称作机顶盒或机上盒,是一个连接电视机与外部信号源的设备;它可以将压缩的数字信号转成电视内容,并在电视机上显示出来;信号可以来自有线电缆、卫星天线、宽带网络以及地面广播。机顶盒接收的内容除了模拟电视可以提供的图像、声音之外,更在于能够接收数据内容,包括电子节目指南、因特网网页、字幕等等;使用户能在现有电视机上观…

    2025年8月6日
    3
  • Nginx日志切割脚本

    Nginx日志切割脚本

    2021年6月4日
    124
  • java 怎样卸载一个类_Java 动态卸载类[通俗易懂]

    java 怎样卸载一个类_Java 动态卸载类[通俗易懂]通过反射,我们可以动态的将类加载到方法区中,但是卸载这个类,却有着比较严苛的条件1.该类所有的实例都已经被GC,也就是JVM中不存在该Class的任何实例。2.加载该类的ClassLoader已经被GC。3.该类的java.lang.Class对象没有在任何地方被引用,如不能在任何地方通过反射访问该类的方法.publicstaticvoidmain(String[]args)th…

    2022年5月18日
    44
  • Linux C编程语言学习材料

    Linux C编程语言学习材料

    2022年1月2日
    49
  • pve虚拟机单网口(虚拟机做软路由)

    PVE虚拟网口扩展实现一线多拨PVE网口设置可以看到这里有两个物理网口我的物理网口enp3s0没有对应的vmbr1,需要先创建LinuxBridge,步骤如下:ROS虚拟网口设置这是关键一步,需要创建四个虚拟网口对应一个LAN口设置四个虚拟网口,完成如下:完成!…

    2022年4月16日
    691

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号