使用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)
上一篇 2022年5月20日 下午3:00
下一篇 2022年5月20日 下午3:00


相关推荐

  • 《5》CentOS7.0+OpenStack+kvm云平台的部署—组态Horizon[通俗易懂]

    《5》CentOS7.0+OpenStack+kvm云平台的部署—组态Horizon

    2022年1月18日
    51
  • linux下修改hosts文件没有权限

    linux下修改hosts文件没有权限昨天激活成功教程 Pycharm 是需要修改 hosts 文件 需要修改 hosts 文件 结果没有权限 gedit 提示没有足够的权限保存修改 然后 vi 里面键盘输入直接异常 找了许久才找到一种可行的方案 sudopasswd nbsp nbsp 修改 root 系统密码 输入旧密码和新密码 若没有初始化过 root 密码 系统会提示你输入当前用户的密码和新的 root 用户密码 su nbsp nbsp nbsp 输入密码后就能以 roo

    2026年3月20日
    1
  • 用jquery实现表单验证_jquery验证插件

    用jquery实现表单验证_jquery验证插件功能强大的jQuery表单验证插件,适用于日常的E-mail、电话号码、网址等验证及Ajax验证,除自身拥有丰富的验证规则外,还可以添加自定义的验证规则。jQueryValidationEnginev2.6.2:兼容IE6+,Chrome,Firefox,Safari,Opera10+,要求jQuery版本1.7以上。下载地址:http://code.ciao

    2022年10月3日
    5
  • 圆周率两千万亿位_圆周率后3000万亿位

    圆周率两千万亿位_圆周率后3000万亿位网友一:对于我们日常生活应用来说,π=3.14就够用了,这就是小学毕业的要求。如果是工程上用,π=3.1415927也足够用了,也就是计算器的精度。那么如果继续计算圆周率,到100位、1万位,其实已经不是实用价值,而是数学研究价值了。1,信念,验证无限不循环π肯定是无限不循环的,不需要验证了。但是,作为数学的信念,我们就想验证一下。这种信念不仅仅在数学家中有,在其他学科领域、行业领域也有。2,研究…

    2025年11月5日
    4
  • 云计算与虚拟化

    云计算与虚拟化云计算与虚拟化一 什么是云计算云计算 cloudcomputi 是分布式计算的一种 指的是通过网络 云 将巨大的数据计算处理程序分解成无数个小程序 然后 通过多部服务器组成的系统进行处理和分析这些小程序得到结果并返回给用户 云计算是一种模型 它可以实现随时随地 便捷地 随需应变地从可配置计算资源共享池中获取所需的资源 例如 网络 服务器 存储 应用 及服务 资源能够快速供应并释放 使管理资源的工作量和与服务器提供商的交互减小到最低限度 2 云计算的特色超大规模 云 具有相当的规模 企

    2026年3月20日
    1
  • topcoder srm 315 div1

    topcoder srm 315 div1

    2021年6月20日
    88

发表回复

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

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