简体   繁体   English

改造-春季图片上传

[英]Retrofit - Spring Image upload

I have a problem in uploading file to server(Spring Boot) from Android-retrofit. 我从Android改造文件上传文件到服务器(春季启动)时遇到问题。

this is my code in Spring Boot. 这是我在Spring Boot中的代码。

@RestController
@RequestMapping("beongae/api/{version}/profile")
public class ProfileController {
    @RequestMapping(value = "/upload/{name}", method = RequestMethod.POST)
    public ApiMessasge uploadBasic(@PathVariable("name") String name,
                                   @RequestPart("file") MultipartFile data) throws IOException {
        ApiMessasge apiMessasge = new ApiMessasge();
        System.out.println("start upload !!");
        if (!data.isEmpty()) {
            try {
                byte[] bytes = data.getBytes();
                BufferedOutputStream stream = new BufferedOutputStream(
                        new FileOutputStream("./profilepictures/" + new File(name + ".png"))
                );
                stream.write(bytes);
                stream.close();
                apiMessasge.setCode(1);
            } catch (Exception e) {
                System.out.println("Exception : " + e.getMessage());
                for (int i = 0; i < e.getStackTrace().length; i++) {
                    System.out.println(e.getStackTrace()[i].toString());
                }
                apiMessasge.setCode(-1);
            }
        }
        return apiMessasge;
    }
}


This is in Android 这是在Android中

Uri resultUri = result.getUri();
File file = new File(resultUri.getPath());

RequestBody requestFile = RequestBody.create(MediaType.parse("multipart/form-data"), file);

MultipartBody.Part body = MultipartBody.Part.createFormData("file", file.getName(), requestFile);


And this is in APiService.class 这是在APiService.class中

@Multipart
@Headers("Content-Type:application/json")
@POST("/beongae/api/{version}/profile/upload/{name}")
Call<ApiMessasge> upload(@Path("version") int version, @Path("name") String fileName
        , @Part MultipartBody.Part file);

And This is the error message in Spring Boot 这是Spring Boot中的错误消息

2017-09-19 21:34:51.179 ERROR 22271 --- [nio-8080-exec-2] oaccC[.[.[/].[dispatcherServlet] : Servlet.service() for servlet [dispatcherServlet] in context with path [] threw exception [Request processing failed; 2017-09-19 21:34:51.179错误22271-[nio-8080-exec-2] oaccC [。[。[/]。[dispatcherServlet]:Servlet [dispatcherServlet]的Servlet.service()路径[]引发异常[请求处理失败; nested exception is org.springframework.web.multipart.MultipartException: Current request is not a multipart request] with root cause org.springframework.web.multipart.MultipartException: Current request is not a multipart request at org.springframework.web.servlet.mvc.method.annotation.RequestPartMethodArgumentResolver.resolveArgument(RequestPartMethodArgumentResolver.java:151) ~[spring-webmvc-4.3.10.RELEASE.jar!/:4.3.10.RELEASE] at org.springframework.web.method.support.HandlerMethodArgumentResolverComposite.resolveArgument(HandlerMethodArgumentResolverComposite.java:121) ~[spring-web-4.3.10.RELEASE.jar!/:4.3.10.RELEASE] at org.springframework.web.method.support.InvocableHandlerMethod.getMethodArgumentValues(InvocableHandlerMethod.java:158) ~[spring-web-4.3.10.RELEASE.jar!/:4.3.10.RELEASE] at org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:128) ~[spring-web-4.3.10.RELEASE.jar!/:4.3.10.RELEASE] at org.springframework.web.servl 嵌套异常是org.springframework.web.multipart.MultipartException:当前请求不是多部分请求],根本原因是org.springframework.web.multipart.MultipartException:在org.springframework.web.servlet中,当前请求不是多部分请求。 mvc.method.annotation.RequestPartMethodArgumentResolver.resolveArgument(RequestPartMethodArgumentResolver.java:151)〜[spring-webmvc-4.3.10.RELEASE.jar!/:4.3.10.RELEASE]在org.springframework.web.method.support.HandlerMethodArgumentResolverComposite .resolveArgument(HandlerMethodArgumentResolverComposite.java:121)〜[spring-web-4.3.10.RELEASE.jar!/:4.3.10.RELEASE]位于org.springframework.web.method.support.InvocableHandlerMethod.getMethodArgumentValues(InvocableHandlerMethod.java: 158)〜[spring-web-4.3.10.RELEASE.jar!/:4.3.10.RELEASE]在org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:128)〜[spring-web -4.3.10.RELEASE.jar!/:4.3.10.RELEASE]在org.springframework.web.servl et.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:97) ~[spring-webmvc-4.3.10.RELEASE.jar!/:4.3.10.RELEASE] at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:827) ~[spring-webmvc-4.3.10.RELEASE.jar!/:4.3.10.RELEASE] at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:738) ~[spring-webmvc-4.3.10.RELEASE.jar!/:4.3.10.RELEASE] at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:85) ~[spring-webmvc-4.3.10.RELEASE.jar!/:4.3.10.RELEASE] at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:967) ~[spring-webmvc-4.3.10.RELEASE.jar!/:4.3.10.RELEASE] at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:901) ~[spring-webmvc-4.3.10.RELEASE.jar!/: et.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:97)〜[spring-webmvc-4.3.10.RELEASE.jar!/:4.3.10.RELEASE]在org.springframework.web.servlet.mvc .method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:827)〜[spring-webmvc-4.3.10.RELEASE.jar!/:4.3.10.RELEASE]位于org.springframework.web.servlet.mvc.method。注解.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:738)〜[spring-webmvc-4.3.10.RELEASE.jar!/:4.3.10.RELEASE]在org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle (AbstractHandlerMethodAdapter.java:85)〜[spring-webmvc-4.3.10.RELEASE.jar!/:4.3.10.RELEASE]在org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:967)〜[ spring-webmvc-4.3.10.RELEASE.jar!/:4.3.10.RELEASE]在org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:901)〜[spring-webmvc-4.3.10.RELEASE 。罐!/: 4.3.10.RELEASE] at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:970) ~[spring-webmvc-4.3.10.RELEASE.jar!/:4.3.10.RELEASE] at org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:872) ~[spring-webmvc-4.3.10.RELEASE.jar!/:4.3.10.RELEASE] at javax.servlet.http.HttpServlet.service(HttpServlet.java:661) ~[tomcat-embed-core-8.5.16.jar!/:8.5.16] at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:846) ~[spring-webmvc-4.3.10.RELEASE.jar!/:4.3.10.RELEASE] at javax.servlet.http.HttpServlet.service(HttpServlet.java:742) ~[tomcat-embed-core-8.5.16.jar!/:8.5.16] at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:231) ~[tomcat-embed-core-8.5.16.jar!/:8.5.16] at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) ~[tomcat-embed-core-8.5.16.jar!/:8.5.16] at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52 org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:970)〜[spring-webmvc-4.3.10.RELEASE.jar!/:4.3.10.RELEASE]中的[4.3.10.RELEASE]。 springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:872)〜[spring-webmvc-4.3.10.RELEASE.jar!/:4.3.10.RELEASE]在javax.servlet.http.HttpServlet.service(HttpServlet .java:661)〜[tomcat-embed-core-8.5.16.jar!/:8.5.16]在org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:846)〜[spring-webmvc- 4.3.10.RELEASE.jar!/:4.3.10.RELEASE]在javax.servlet.http.HttpServlet.service(HttpServlet.java:742)〜[tomcat-embed-core-8.5.16.jar!/:8.5 .16]在org.apache.catalina.core上的org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:231)〜[tomcat-embed-core-8.5.16.jar!/:8.5.16] .ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)〜[tomcat-embed-core-8.5.16.jar!/:8.5.16]在org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java: 52 ) ~[tomcat-embed-websocket-8.5.16.jar!/:8.5.16] at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193) ~[tomcat-embed-core-8.5.16.jar!/:8.5.16] at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) ~[tomcat-embed-core-8.5.16.jar!/:8.5.16] at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:197) ~[spring-web-4.3.10.RELEASE.jar!/:4.3.10.RELEASE] at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107) ~[spring-web-4.3.10.RELEASE.jar!/:4.3.10.RELEASE] at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193) ~[tomcat-embed-core-8.5.16.jar!/:8.5.16] at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) ~[tomcat-embed-core-8.5.16.jar!/:8.5.16] at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:198) ~[tomcat- )〜[tomcat-embed-websocket-8.5.16.jar!/:8.5.16]在org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)〜[tomcat-embed-core-8.5。 16.org!/:8.5.16] at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)〜[tomcat-embed-core-8.5.16.jar!/:8.5.16] at org.springframework.web.filter.OncePerRequestFilter上的org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:197)〜[spring-web-4.3.10.RELEASE.jar!/:4.3.10.RELEASE] .doFilter(OncePerRequestFilter.java:107)〜[spring-web-4.3.10.RELEASE.jar!/:4.3.10.RELEASE]在org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193) 〜[tomcat-embed-core-8.5.16.jar!/:8.5.16]在org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)〜[tomcat-embed-core-8.5.16 .jar!/:8.5.16],位于org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:198)〜[tomcat- embed-core-8.5.16.jar!/:8.5.16] at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:96) [tomcat-embed-core-8.5.16.jar!/:8.5.16] at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:478) [tomcat-embed-core-8.5.16.jar!/:8.5.16] at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:140) [tomcat-embed-core-8.5.16.jar!/:8.5.16] at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:80) [tomcat-embed-core-8.5.16.jar!/:8.5.16] at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:87) [tomcat-embed-core-8.5.16.jar!/:8.5.16] at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:342) [tomcat-embed-core-8.5.16.jar!/:8.5.16] at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:799) [tomcat-embed-core-8.5.16.jar!/:8.5.16] at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:66) [tomcat-embed-core-8.5.16. embed-core-8.5.16.jar!/:8.5.16]在org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:96)[tomcat-embed-core-8.5.16.jar!/: 8.5.16]在org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:478)[tomcat-embed-core-8.5.16.jar!/:8.5.16]在org.apache.catalina.core .StandardHostValve.invoke(StandardHostValve.java:140)[tomcat-embed-core-8.5.16.jar!/:8.5.16]在org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:80)[ tomcat-embed-core-8.5.16.jar!/:8.5.16],位于org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:87)[tomcat-embed-core-8.5.16.jar! /:8.5.16]在org.apache.coyote上的org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:342)[tomcat-embed-core-8.5.16.jar!/:8.5.16] .http11.Http11Processor.service(Http11Processor.java:799)[tomcat-embed-core-8.5.16.jar!/:8.5.16]在org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:66)[ tomcat嵌入核心8.5.1。 jar!/:8.5.16] at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:868) [tomcat-embed-core-8.5.16.jar!/:8.5.16] at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1455) [tomcat-embed-core-8.5.16.jar!/:8.5.16] at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49) [tomcat-embed-core-8.5.16.jar!/:8.5.16] at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149) [na:1.8.0_131] at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624) [na:1.8.0_131] at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) [tomcat-embed-core-8.5.16.jar!/:8.5.16] at java.lang.Thread.run(Thread.java:748) [na:1.8.0_131] jar!/:8.5.16]在org.apache.coyote.AbstractProtocol $ ConnectionHandler.process(AbstractProtocol.java:868)[tomcat-embed-core-8.5.16.jar!/:8.5.16]在org.apache .tomcat.util.net.NioEndpoint $ SocketProcessor.doRun(NioEndpoint.java:1455)[tomcat-embed-core-8.5.16.jar!/:8.5.16]在org.apache.tomcat.util.net.SocketProcessorBase .run(SocketProcessorBase.java:49)[tomcat-embed-core-8.5.16.jar!/:8.5.16] at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)[na:1.8。 0_131],位于java.util.concurrent.ThreadPoolExecutor $ Worker.run(ThreadPoolExecutor.java:624)[na:1.8.0_131],位于org.apache.tomcat.util.threads.TaskThread $ WrappingRunnable.run(TaskThread.java:61 )[tomcat-embed-core-8.5.16.jar!/:8.5.16]在java.lang.Thread.run(Thread.java:748)[na:1.8.0_131]

But, It's done well when I use Postman. 但是,当我使用Postman时,做得很好。

Please tell me what is the problem and how to solve 请告诉我问题是什么以及如何解决

https://i.stack.imgur.com/2sYO7.png

尝试稍微修改服务,然后尝试

 @Part("file\"; filename=\"filename.png\" ")

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM