关于excel上传解析

发布于 2022-09-04 07:17:42 字数 166 浏览 14 评论 0

前台通过form表单上传文件,后台通过request.getInputStream得到流,但是POI建立wordbook要求是fileInputStream,我获取的是servletInputStream,强转会出错。怎么解决。我查的资料都是通过固定文件位置读取流,我想使用用户上传的流来生成workbook该怎么做?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(4

八巷 2022-09-11 07:17:42

1、有种方案是先保存到服务器某位置再读取,需要注意文件名称唯一 处理完删除
2、不对啊 上传可以得到一个文件 是文件 File对象啊 忘记怎么做的了

最单纯的乌龟 2022-09-11 07:17:42

什么版本的POI?XSSFWorkbook的构造方法里,明明有一个的参数是InputStream啊

怂人 2022-09-11 07:17:42

ServletInputStream extends InputStream当然是强转不了的,你可以把ServletInputStream 从缓冲区读取然后再转换成InputStream(如果你不嫌麻烦的话),正常点的做法还是在服务器建立临时文件(如果你看着不顺可以删掉啊)
你可以尝试下使用springmvc做,
1.@RequestParam(value="file",required = false)MultipartFile file //接收参数
2.但是还要构建文件保存路径

String path = request.getSession(true).getServletContext().getRealPath("/upload");
 String fileName = new Date().getTime()+file.getOriginalFilename();

3.保存文件

File targetFile = new File(path,fileName);
file.transferTo(targetFile)

4.POI...

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文