REST를 통해 통신해야하는 두 개의 애플리케이션을 작성 중입니다. 두 응용 프로그램 모두 SpringBoot 응용 프로그램입니다. 대부분의 웹 서비스는 정상적으로 작동하지만 파일 업로드와 관련하여 몇 가지 문제가 있습니다. 나머지 템플릿스프링 레스트 컨트롤러로 파일 업로드가 작동하지 않습니다.
@RestController
@RequestMapping(PathConstants.SERVER_PACKAGING_INTERFACE + "/**")
public class PackagingCommunication {
//@PostMapping(PathConstants.SERVER_UPLOAD_FILE)
@RequestMapping(name = PathConstants.SERVER_UPLOAD_FILE, method = RequestMethod.POST, headers=("content-type=multipart/*"))
public ResponseEntity<String> uploadFileInStorage(@RequestParam("file") MultipartFile file,
RedirectAttributes redirectAttributes) {
try {
InputStream inputStream = file.getInputStream();
String fileName = file.getOriginalFilename();
//storageService.saveInputStreamInStorage(inputStream, fileName);
return ResponseEntity.status(HttpStatus.OK).build();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR).build();
}
}
}
내 클라이언트 :
public void uploadeFileToStorage(File file, String serverUrl) {
try{
final MultiValueMap<String, Object> parameterMap = createMultipartFileParam(file.getAbsolutePath());
parameterMap.add("file", file);
HttpHeaders headers = new HttpHeaders();
//headers.set("Content-Type", "multipart/form-data");
//headers.set("Accept", "text/plain");
headers.setContentType(MediaType.MULTIPART_FORM_DATA);
String url = serverUrl + PathConstants.SERVER_PACKAGING_INTERFACE + PathConstants.SERVER_UPLOAD_FILE;
restTemplate = getRestTemplate();
ResponseEntity<String> response = restTemplate.exchange(url, HttpMethod.POST, new HttpEntity<MultiValueMap<String, Object>>(parameterMap, headers),
String.class);
System.out.println(response.getHeaders().getAccept());
} catch(Exception ex) {
System.out.println(ex.getMessage());
} finally {
// Delete the file from the temporary directory of the client.
file.delete();
}
}
가 나는 HTTP 오류 코드 400
를 얻을이 내 나머지 컨트롤러입니다. 주석 처리 된 행은 문제를 해결하기 위해 시도한 진술을 보여줍니다. 그런 다음 Java 프로그램없이 웹 서비스와 통신하려는 html 형식을 작성했습니다.
<html>
<body>
<div>
<form method="POST" enctype="multipart/form-data" action="http://localhost:9292/serverPackaging/uploadFile">
<table>
<tr><td>File to upload:</td><td><input type="file" name="file" /></td></tr>
<tr><td></td><td><input type="submit" value="Upload" /></td></tr>
</table>
</form>
</div>
</body>
</html>
또한 작동하지 않습니다. "필요한 요청 부분 '파일'이 없습니다. '라는 오류 메시지가 나타납니다. 나는 무엇을해야할지 모른다. html formular는 중요하지 않습니다. 나머지 템플릿의 도움으로 두 응용 프로그램 간의 통신이 정말로 중요합니다. 여기
는 스택 트레이스입니다 :org.springframework.web.client.HttpClientErrorException: 400 null
at org.springframework.web.client.DefaultResponseErrorHandler.handleError(DefaultResponseErrorHandler.java:91)
at org.springframework.web.client.RestTemplate.handleResponse(RestTemplate.java:700)
at org.springframework.web.client.RestTemplate.doExecute(RestTemplate.java:653)
at org.springframework.web.client.RestTemplate.execute(RestTemplate.java:613)
at org.springframework.web.client.RestTemplate.exchange(RestTemplate.java:531)
at de.feu.kdmp4.packagingtoolkit.client.operations.classes.ServerCommunicationOperationsImpl.uploadeFileToStorage(ServerCommunicationOperationsImpl.java:314)
at de.feu.kdmp4.packagingtoolkit.client.operations.facade.OperationsFacade.uploadeFileToStorage(OperationsFacade.java:49)
at de.feu.kdmp4.packagingtoolkit.client.service.classes.ArchiveServiceImpl.addFileReference(ArchiveServiceImpl.java:69)
at de.feu.kdmp4.packagingtoolkit.client.service.facades.ServiceFacade.addFileReference(ServiceFacade.java:48)
at de.feu.kdmp4.packagingtoolkit.client.view.prime.managedBeans.InformationPackageCreationBean.createInformationPackage(InformationPackageCreationBean.java:192)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
at java.lang.reflect.Method.invoke(Unknown Source)
at org.apache.el.parser.AstValue.invoke(AstValue.java:247)
at org.apache.el.MethodExpressionImpl.invoke(MethodExpressionImpl.java:267)
at javax.faces.event.MethodExpressionActionListener.processAction(MethodExpressionActionListener.java:149)
at javax.faces.event.ActionEvent.processListener(ActionEvent.java:88)
at javax.faces.component.UIComponentBase.broadcast(UIComponentBase.java:814)
at javax.faces.component.UICommand.broadcast(UICommand.java:300)
at javax.faces.component.UIViewRoot.broadcastEvents(UIViewRoot.java:790)
at javax.faces.component.UIViewRoot.processApplication(UIViewRoot.java:1282)
at com.sun.faces.lifecycle.InvokeApplicationPhase.execute(InvokeApplicationPhase.java:81)
at com.sun.faces.lifecycle.Phase.doPhase(Phase.java:101)
at com.sun.faces.lifecycle.LifecycleImpl.execute(LifecycleImpl.java:198)
at javax.faces.webapp.FacesServlet.service(FacesServlet.java:658)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:230)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:165)
at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:192)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:165)
at org.springframework.boot.web.filter.ApplicationContextHeaderFilter.doFilterInternal(ApplicationContextHeaderFilter.java:55)
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:192)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:165)
at org.springframework.boot.actuate.trace.WebRequestTraceFilter.doFilterInternal(WebRequestTraceFilter.java:108)
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:192)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:165)
at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:197)
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:192)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:165)
at org.springframework.boot.actuate.autoconfigure.MetricsFilter.doFilterInternal(MetricsFilter.java:106)
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:192)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:165)
at org.springframework.boot.web.support.ErrorPageFilter.doFilter(ErrorPageFilter.java:115)
at org.springframework.boot.web.support.ErrorPageFilter.access$000(ErrorPageFilter.java:59)
at org.springframework.boot.web.support.ErrorPageFilter$1.doFilterInternal(ErrorPageFilter.java:90)
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)
at org.springframework.boot.web.support.ErrorPageFilter.doFilter(ErrorPageFilter.java:108)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:192)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:165)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:198)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:96)
at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:474)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:140)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:79)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:87)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:349)
at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:783)
at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:66)
at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:798)
at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1434)
at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49)
at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
at java.lang.Thread.run(Unknown Source)
'
사람이 내가 잘못하고있는 무슨 아이디어가 있습니까?
덕분에, 크리스토퍼
게시하시기 바랍니다 완전한 스택 트레이스 그냥 코드 예제에 대한 컨텍스트를 무시합니다. – mrkernelpanic
죄송합니다. stacktrace를 잊어 버렸습니다. 여기에 : – Christopher