SpringMVC Shiro 上传文件时,获取的是ShiroHttpServletRequest,如何转换成MultipartHttpServletRequest

<pre style="font-family: 宋体; font-size: 9pt; background-color: rgb(255, 255, 255);"><pre name="code" class="java">  /**
   * 资料上传
   *
   * @param request
   * @return
   * @throws Exception
   */
  public JSONObject uploadFile(HttpServletRequest request, HttpServletResponse response) throws Exception {
    ShiroHttpServletRequest shiroRequest = (ShiroHttpServletRequest) request;
    CommonsMultipartResolver commonsMultipartResolver = new CommonsMultipartResolver();
    MultipartHttpServletRequest multipartRequest = commonsMultipartResolver.resolveMultipart((HttpServletRequest) shiroRequest.getRequest());

    Iterator<String> itr = multipartRequest.getFileNames();
    MultipartFile multipartFile = null;

    while (itr.hasNext()) {
      multipartFile = multipartRequest.getFile(itr.next());
      String fileRealName = String.valueOf(new Date().getTime());
      fileRealName = fileRealName + FileUtils.getSuffix(multipartFile.getOriginalFilename());

      HSSFWorkbook hssfWorkbook = new HSSFWorkbook(multipartFile.getInputStream());
      // xlsx
      //XSSFWorkbook xssfWorkbook = new XSSFWorkbook(multipartFile.getInputStream());

      if (hssfWorkbook != null) {
        for (int numSheet = 0; numSheet < hssfWorkbook.getNumberOfSheets(); numSheet++) {
          HSSFSheet hssfSheet = hssfWorkbook.getSheetAt(numSheet);
          // xlsx
          //XSSFSheet xssfSheet = xssfWorkbook.getSheetAt(numSheet);

          // 循环行Row
          for (int rowNum = 0; rowNum <= hssfSheet.getLastRowNum(); rowNum++) {
            if (rowNum == 0) {
              continue;
            }
            HSSFRow hssfRow = hssfSheet.getRow(rowNum);
            if (hssfRow == null || (hssfRow.getCell(0) == null && hssfRow.getCell(1) == null && hssfRow.getCell(2) == null && hssfRow.getCell(3) == null && hssfRow.getCell(4) == null
                    && hssfRow.getCell(5) == null && hssfRow.getCell(6) == null && hssfRow.getCell(7) == null && hssfRow.getCell(8) == null && hssfRow.getCell(9) == null)) {
              continue;
            }

          }
        }
      }
    }
    JSONObject obj = new JSONObject();
    obj.put("title", "123123");
    return obj;
  }
发现这个问题的大家凑合着看看,有更好的解决方法的亲,也请留下更好的方法。

 

                
  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 5
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值