一.导入Excel的组件使用阿里的 EasyExcel。
二.controller代码如下:
注释:webflux跟web上传文件有所不同,webflux使用*@RequestPart**注解接受上传的文件。*
/**
* 导入用户数据
* @param file
* @return
*/
@PostMapping("/importExcel")
public RestVO importExcel(@RequestPart(value = "excel") FilePart file){
return userService.importExcel(file);
}
三.Serviceimpl的代码块如下,亲测可用:
注释:重点是下方try底下的六行代码的代码,把上传的文件转成byte数组,放到InputStream输入流中,让EasyExcel能读取到。
/**
* 用户导入
* @param file
* @return
*/
@Override
public RestVO importExcel(FilePart file) {
SysUserExcelListener sysUserExcelListener = new SysUserExcelListener(userService);
try {
Mono<byte[]> map = DataBufferUtils.join(file.content())
.map(dataBuffer -> dataBuffer.asByteBuffer().array());
byte[] block = map.block();
if(ObjectUtils.isEmpty(block)){
return RestVO.error("请上传Excel文件!");
}
InputStream sbs = new ByteArrayInputStream(block);
EasyExcelFactory.read(sbs, SysUserImportDto.class, sysUserExcelListener).sheet().doRead();
//失败的个数
List<ExcelCheckErrDto<SysUserImportDto>> errList = sysUserExcelListener.getErrList();
//成功的个数
List<SysUserImportDto> successList = sysUserExcelListener.getSuccessList();
String title = "导入用户信息完成,失败"+errList.size()+"条," +
"成功"+successList.size()+"条";
ExcelMessage excelMessage = new ExcelMessage();
excelMessage.setTitle(title);
if (errList.size() > 0) {
String errMsgs = "导入失败明细:"+ "\n";
for(ExcelCheckErrDto<SysUserImportDto> err : errList){
errMsgs = errMsgs + err.getErrMsg() + " | ";
}
String message = title + "\n" +errMsgs;
excelMessage.setMsg(message);
}
return RestVO.ok(excelMessage);
} catch (Exception e) {
e.printStackTrace();
log.error("导入数据失败:{}",e.getMessage());
}
return RestVO.error();
}