java 图片批量上传_SpringBoot 2.0 图片上传(支持批量上传)

SpringBoot 2.0提供了很多开箱即用的功能,这使得我们开发也更加的简单。

下面是一个图片上传的Demo(包含前端代码与后端的代码)

Web端代码,支持批量上传

File upload

upload

var length;

$("#file").change(function () {

length = this.files.length;

console.log(length);

})

function getUpload(){

var formData = new FormData();

var arr=new Array();

var container;

var i=0;

for(let i=0;i

formData.append('file', $('#file')[0].files[i]);

console.log(formData.get("file"));

}

container=formData.getAll("file");

for (var item in container) {

arr[i] = container[item];

i++;

}

console.log(arr);

$.ajax({

url: '/pic',

type: 'POST',

dataType:"json",

cache: false,

data: formData,

processData: false,

contentType: false,

success:(function(data) {

window.confirm(data.code)

}),

error:(function(res) {

alert("失败");

})

});

}

Controller 层参数接收

@RequestMapping("/pic")

@ResponseBody

public BaseResponse uplodFile(@RequestParam("file") MultipartFile[] file) throws Exception {

/*String originalFilename = file.getOriginalFilename();

FileInputStream inputStream = (FileInputStream) file.getInputStream();*/

/* System.out.println(inputStream);

System.out.println(originalFilename);*/

System.out.println("数组的长度"+file.length);

for (int i = 0; i < file.length; i++) {

String originalFilename = file[i].getOriginalFilename();

InputStream inputStream = file[i].getInputStream();

OSSUtil.uploadImageToOSS(originalFilename, inputStream);

}

return BaseResponse.ok(200,"OK");

}

关于会遇见的Exception

f158c5cc072df87451da967f7edafb21.png

异常

org.apache.tomcat.util.http.fileupload.FileUploadBase$FileSizeLimitExceededException: The field file exceeds its maximum permitted size of 1048576 bytes.

at org.apache.tomcat.util.http.fileupload.FileUploadBase$FileItemIteratorImpl$FileItemStreamImpl$1.raiseError(FileUploadBase.java:630)

at org.apache.tomcat.util.http.fileupload.util.LimitedInputStream.checkLimit(LimitedInputStream.java:76)

at org.apache.tomcat.util.http.fileupload.util.LimitedInputStream.read(LimitedInputStream.java:135)

at java.io.FilterInputStream.read(FilterInputStream.java:107)

at org.apache.tomcat.util.http.fileupload.util.Streams.copy(Streams.java:98)

at org.apache.tomcat.util.http.fileupload.util.Streams.copy(Streams.java:68)

at org.apache.tomcat.util.http.fileupload.FileUploadBase.parseRequest(FileUploadBase.java:293)

org.apache.tomcat.util.http.fileupload.FileUploadBase$FileSizeLimitExceededException: The field file exceeds its maximum permitted size of 1048576 bytes.

根据异常信息可以看出是因为我们单次上传的文件的大小超过了 1048576bytes 也就是超过了1MB的大小。这是因我SpringBoot2.0的默认配置是1MB的小大,所以这个时候我们需要在SpringBoot的配置文件中自定义一下这些属性,我这里是这样配置的。

c476c032774624000d15c55c25899f16.png

配置文件更改

详细讲解

d261d09d037b2cbc7903f6e77506ed86.png

图片上传

02ddb6b669457f65f899a507636af101.png

文件选择

b1b9790af6e7b40143203f07d8db80d3.png

文件选择

public interface MultipartFile extends InputStreamSource {

String getName();

@Nullable

String getOriginalFilename();

@Nullable

String getContentType();

....

我们的代码

@RequestMapping("/pic")

@ResponseBody

public BaseResponse uplodFile(@RequestParam("file") MultipartFile[] file) throws Exception {

.....

通过查看MultipartFile继承了InputStreamSource那么传递给我们的最重要的信息就是我们卡伊拿到文件流了InputStream inputStream = file[i].getInputStream();

那么所有问题就迎刃而解了。

我们使用的阿里的OSS对象存储,代码中使用的OSSUtils我在之前的代码中也贴出过相应的代码传送门:https://www.jianshu.com/p/2e419be10729

715496c36e2d20d4e25c35e21623626e.png

OSS控制台

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值