Файл POST Multipart как данные формы для службы REST - PullRequest
0 голосов
/ 16 октября 2018

Я пытаюсь отправить многокомпонентный файл в виде данных формы в службу REST, которая возвращает мне URL-адрес после его сохранения в конце службы REST.У почтальона просьба выглядит так.enter image description here

У меня есть служба Spring Boot, в которой есть метод для получения внешнего интерфейса многокомпонентного файла через jquery fileuploader.Мне нужно отправить файл по указанному выше URL, который почтальон отправляет и сохраняет в конце.Я думаю, что я должен построить данные формы в моем сервисе загрузки Spring.Ниже приведены несколько снимков службы загрузки Spring.

Конец контроллера.

@RequestMapping(method = RequestMethod.POST, value = "/file-upload/{profileName:.+}")
  public Attachment uploadFile(@RequestParam("file") MultipartFile input,
   @PathVariable("profileName") String profileName) throws IOException {
   Attachment attachment = new Attachment();
   if (input != null) {
    log.info("Upload a new attachment item" + input.getName());
    byte[] fileByteArray = input.getBytes();
    attachment.setEncodedFile(Utils.encodeBytes(fileByteArray));
    attachment.setFileName(input.getOriginalFilename());

    socialMediaService.uploadMedia(input, profileName);

   }
   return attachment;
  }

SocialMediaService

  public String uploadMedia(MultipartFile input, String profileName) {

   String mediaUploadPath = "wall_attach/lenne-public";
   Map < String, String > params = new HashMap < > ();
   String mediaUploadFullPath =
    UrlBuilder.build(System.getenv(Constants.HUBZILLA_URL), mediaUploadPath, params);
   if (!isRestServiceProvided) {
    restService = new RestService(RequestType.POST, mediaUploadFullPath);
   }

   MultipartEntityBuilder builder = restService.getEntityBuilder();
   builder.setMode(HttpMultipartMode.BROWSER_COMPATIBLE);
   try {
    builder.addBinaryBody("userfile", input.getBytes(), ContentType.DEFAULT_BINARY, input.getOriginalFilename());
   } catch (IOException e) {
    e.printStackTrace(); //To change body of catch statement use File | Settings | File Templates.
   }

   String strResp = restService.execute(profileName, Constants.HUBZILLA_PW);
   return strResp;

  }

  return null;


  }

Класс RestService

public class RestService {

  private Logger log;

  private HttpClient client = null;
  private HttpRequest request = null;
  private RequestType reqType = null;
  private String body;
  MultipartEntityBuilder builder = null;

  public RestService() {
    this.log = LoggerFactory.getLogger(RestService.class);
  }

  /**
   * Create REST service with external parameters.
   *
   * @param reqType RequestType
   * @param client HttpClient
   * @param request External HttpRequest
   */
  public RestService(RequestType reqType, HttpClient client, HttpRequest request, Logger log) {
    this.reqType = reqType;
    this.client = client;
    this.request = request;
    this.log = log;
  }

  /**
   * Create REST service string parameters.
   * 
   * @param reqType RequestType
   * @param fullPath Full path of REST service
   */
  public RestService(RequestType reqType, String fullPath) {
    this.client = HttpClientBuilder.create().build();
    this.reqType = reqType;
    this.log = LoggerFactory.getLogger(RestService.class);


    if (reqType == RequestType.GET) {
      this.request = new HttpGet(fullPath);
    } else if (reqType == RequestType.POST) {
      this.request = new HttpPost(fullPath);
    } else if (reqType == RequestType.DELETE) {
      this.request = new HttpDelete(fullPath);
    }
  }

  /**
   * Execute REST service without authentication.
   * 
   * @return - Result of the service.
   */
  public String execute() {
    return execute(null, null);
  }

  /**
   * Execute REST web service with basic authentication.
   *
   * @return - Result of the service.
   */
  public String execute(String user, String password) {
    try {

      if (user != null && password != null) {
        StringBuilder authString = new StringBuilder();
        authString.append(user).append(":").append(password);
        String authBase = new String(
            Base64.getEncoder().encode(authString.toString().getBytes(Charset.forName("UTF-8"))));

        String authType = "Basic ";
        String authHeader = authType + authBase;

        request.setHeader(HttpHeaders.AUTHORIZATION, authHeader);
      }

      HttpResponse response = null;

      if (this.reqType == RequestType.GET) {
        HttpGet get = (HttpGet) request;
        response = client.execute(get);

      } else if (this.reqType == RequestType.POST) {
        HttpPost post = (HttpPost) request;

        if (body != null) {
          StringEntity stringEntity = new StringEntity(body);
          post.setEntity(stringEntity);
        }

        if (builder != null) {
          HttpEntity entity = builder.build();
          post.setEntity(entity);
        }
        response = client.execute(post);

      } else {
        throw new NotImplementedException();
      }

      if (response != null && (response.getStatusLine().getStatusCode() == Status.OK.getStatusCode()
          || response.getStatusLine().getStatusCode() == Status.CREATED.getStatusCode())) {
        HttpEntity entity = response.getEntity();
        return EntityUtils.toString(entity);
      }

    } catch (Exception e) {
      log.error("External service call failed ", e);
    }

    return null;
  }

  public void setBody(String body) {
    this.body = body;
  }

  public MultipartEntityBuilder getEntityBuilder() {
    this.builder = MultipartEntityBuilder.create();
    return this.builder;
  }


}

Моя проблема не дает никакого результата после того, как я выполнил метод загрузки медиа службы остальных услуг.Но он отлично работал через почтальона.

Кто-нибудь может дать мне знать, что мне не хватает?Является ли способ построения данных формы в Java правильным?

Заранее спасибо.

1 Ответ

0 голосов
/ 16 октября 2018

Попробуйте добавить параметр потребление в @RequestMapping следующим образом (потребляет = "multipart / form-data")

@RequestMapping(method = RequestMethod.POST, consumes = "multipart/form-data" ,value = "/file-upload/{profileName:.+}")
public Attachment uploadFile(@RequestParam("file") MultipartFile input,
    @PathVariable("profileName") String profileName) throws IOException {
----
----  
}

Здесь есть еще одна важная проблема: Попытка загрузить MultipartFile с почтальоном Пожалуйста, прочитайте комментарии под ответом в этой ссылке.Надеюсь, это поможет!

...