Postman没有选择文件,但是后端还接收到的文件

一、原因分析

Postman往后端传输文件,没有选择文件,但是后端还接收到的文件。但文件名为空,大小为0;

原因: 是因为请求头里多了一行Content-Type:multipart/form-data,Postman向后端指明,我传输的是文件类型的,但是又没有给后端传出文件。则后端会接接收到一个空文件。

二、请求方式验证

下面按三种请求,去看一下这个的区别。

后端接收代码:

@RequestMapping(value = "/file", method = {RequestMethod.POST})
public void addFile(@RequestParam MultipartFile file) throws IOException {
    String name = file.getName();
    byte[] bytes = file.getBytes();
    int length = bytes.length;
    String originalFilename = file.getOriginalFilename();
    String contentType = file.getContentType();
  
    logger.info("getName:{}", name);
    logger.info("bytes.length:{}", length);
    logger.info("getOriginalFilename:{}",originalFilename);
    logger.info("getContentType:{}",contentType);
}
上传方式一:正常传输

Postman请求页面:
在这里插入图片描述

请求头:
在这里插入图片描述

后端打印结果:
在这里插入图片描述

上传方式二:添加请求头,但是不选择文件

Postman请求页面:
在这里插入图片描述

请求头:

在这里插入图片描述

后端打印结果:
在这里插入图片描述
传输一个空文件,大小为0,文件名为空

上传方式三:未添加请求头,未选择文件

Postman请求页面:
在这里插入图片描述

请求头:

在这里插入图片描述

后端打印结果:
在这里插入图片描述
报出错误,当前的请求不是MultipartFile的请求方式。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Java后端可以使用Apache POI来读取和处理Excel文件。 以下是一个简单的例子,展示如何接收Postman导入的Excel文件并读取其内容: ```java @PostMapping("/upload") public String uploadExcel(@RequestParam("file") MultipartFile file) { if (file.isEmpty()) { return "上传失败,请选择文件"; } try { InputStream inputStream = file.getInputStream(); Workbook workbook = WorkbookFactory.create(inputStream); // 读取第一个sheet Sheet sheet = workbook.getSheetAt(0); // 读取第一行(标题行) Row titleRow = sheet.getRow(0); // 读取第二行(数据行) Row dataRow = sheet.getRow(1); // 读取第一列的值 Cell titleCell = titleRow.getCell(0); String title = titleCell.getStringCellValue(); // 读取第二列的值 Cell dataCell = dataRow.getCell(1); String data = dataCell.getStringCellValue(); return "标题:" + title + ",数据:" + data; } catch (IOException | InvalidFormatException e) { e.printStackTrace(); return "上传失败,发生异常:" + e.getMessage(); } } ``` 在上面的例子中,我们首先通过@RequestParam注解将上传的Excel文件作为参数传递给方法。然后,我们使用MultipartFile.getInputStream()方法获取文件的输入流,并使用WorkbookFactory.create()方法创建一个Workbook对象,用于读取Excel文件的内容。 接下来,我们读取工作簿中的第一个sheet,并读取其标题行和数据行。我们使用Row.getCell()方法读取单元格中的值,并使用Cell.getStringCellValue()方法将其转换为字符串。 最后,我们返回读取的标题和数据。您可以根据实际需求进一步处理Excel文件的内容。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

ha_lydms

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值