restTemplate.postForObject() MultipartFile(上傳文件)

        Result result=new Result(true);
            String api = releaseUrl + "/productPrice/ImportExcelData";//遠程接口
            ByteArrayResource fileAsResource = new ByteArrayResource(multipartFile.getBytes()) {
                @Override
                public String getFilename() {
                    return multipartFile.getOriginalFilename();
                }

                @Override
                public long contentLength() {
                    return multipartFile.getSize();
                }
            };
            MultiValueMap<String, Object> multipartRequest = new LinkedMultiValueMap<>();
            multipartRequest.add("files", fileAsResource);//注意此處定義的"files"名稱需與接口參數名稱一致,不然沒法拿到數據
            HttpHeaders headers = new HttpHeaders();
            headers.setContentType(MediaType.MULTIPART_FORM_DATA);
            HttpEntity<MultiValueMap<String, Object>> files = new HttpEntity(multipartRequest, headers);
            result=restTemplate.postForObject(api, files, Result.class);//接口調用

遠程接口定義:api

  @PostMapping("/ImportExcelData")
    public Result ImportExcelData(@RequestParam List<MultipartFile> files){
        if (files.size()==1) {
            return service.ImportExcelData(files.get(0));
        }else {
            return new Result(false,"請上傳單個Excel文件");
        }
    }
相關文章
相關標籤/搜索