Heim  >  Fragen und Antworten  >  Hauptteil

java - 关于excel上传解析

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

PHP中文网PHP中文网2741 Tage vor437

Antworte allen(4)Ich werde antworten

  • 伊谢尔伦

    伊谢尔伦2017-04-18 10:29:52

    你试试官网的示例。

    Antwort
    0
  • 巴扎黑

    巴扎黑2017-04-18 10:29:52

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

    Antwort
    0
  • 怪我咯

    怪我咯2017-04-18 10:29:52

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

    Antwort
    0
  • 怪我咯

    怪我咯2017-04-18 10:29:52

    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...

    Antwort
    0
  • StornierenAntwort