改造 - 春季图片上传

时间:2017-09-19 21:56:47

标签: java android spring spring-mvc retrofit

我在从Android-retrofit上传文件到服务器(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;
    }
}


这是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);


这是在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);

这是Spring Boot中的错误消息

  

2017-09-19 21:34:51.179 ERROR 22271 --- [nio-8080-exec-2]   o.a.c.c.C。[。[。[/]。[dispatcherServlet]:Servlet.service()for   在path []的上下文中的servlet [dispatcherServlet]引发了异常   [请求处理失败;嵌套异常是   org.springframework.web.multipart.MultipartException:当前请求   具有根本原因的不是多部分请求       org.springframework.web.multipart.MultipartException:当前请求不是多部分请求               在org.springframework.web.servlet.mvc.method.annotation.RequestPartMethodArgumentResolver.resolveArgument(RequestPartMethodArgumentResolver.java:151)   〜[弹簧webmvc-4.3.10.RELEASE.jar /:4.3.10.RELEASE]               在org.springframework.web.method.support.HandlerMethodArgumentResolverComposite.resolveArgument(HandlerMethodArgumentResolverComposite.java:121)   〜[弹簧网络4.3.10.RELEASE.jar /:4.3.10.RELEASE]               在org.springframework.web.method.support.InvocableHandlerMethod.getMethodArgumentValues(InvocableHandlerMethod.java:158)   〜[弹簧网络4.3.10.RELEASE.jar /:4.3.10.RELEASE]               在org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:128)   〜[弹簧网络4.3.10.RELEASE.jar /:4.3.10.RELEASE]               at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:97)   〜[弹簧webmvc-4.3.10.RELEASE.jar /:4.3.10.RELEASE]               在org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:827)   〜[弹簧webmvc-4.3.10.RELEASE.jar /:4.3.10.RELEASE]               在org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:738)   〜[弹簧webmvc-4.3.10.RELEASE.jar /:4.3.10.RELEASE]               在org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:85)   〜[弹簧webmvc-4.3.10.RELEASE.jar /:4.3.10.RELEASE]               在org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:967)   〜[弹簧webmvc-4.3.10.RELEASE.jar /:4.3.10.RELEASE]               在org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:901)   〜[弹簧webmvc-4.3.10.RELEASE.jar /:4.3.10.RELEASE]               在org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:970)   〜[弹簧webmvc-4.3.10.RELEASE.jar /:4.3.10.RELEASE]               在org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:872)   〜[弹簧webmvc-4.3.10.RELEASE.jar /:4.3.10.RELEASE]               在javax.servlet.http.HttpServlet.service(HttpServlet.java:661)   [!Tomcat的嵌入芯-8.5.16.jar /:16年5月8日]〜               在org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:846)   〜[弹簧webmvc-4.3.10.RELEASE.jar /:4.3.10.RELEASE]               在javax.servlet.http.HttpServlet.service(HttpServlet.java:742)   [!Tomcat的嵌入芯-8.5.16.jar /:16年5月8日]〜               在org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:231)   [!Tomcat的嵌入芯-8.5.16.jar /:16年5月8日]〜               在org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)   [!Tomcat的嵌入芯-8.5.16.jar /:16年5月8日]〜               在org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)   [!Tomcat的嵌入-的WebSocket-8.5.16.jar /:16年5月8日]〜               在org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)   [!Tomcat的嵌入芯-8.5.16.jar /:16年5月8日]〜               在org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)   [!Tomcat的嵌入芯-8.5.16.jar /:16年5月8日]〜               在org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:197)   〜[弹簧网络4.3.10.RELEASE.jar /:4.3.10.RELEASE]               在org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)   〜[弹簧网络4.3.10.RELEASE.jar /:4.3.10.RELEASE]               在org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)   [!Tomcat的嵌入芯-8.5.16.jar /:16年5月8日]〜               在org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)   [!Tomcat的嵌入芯-8.5.16.jar /:16年5月8日]〜               在org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:198)   [!Tomcat的嵌入芯-8.5.16.jar /:16年5月8日]〜               在org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:96)   [Tomcat的嵌入核心-8.5.16.jar /:16年5月8日]               在org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:478)   [Tomcat的嵌入核心-8.5.16.jar /:16年5月8日]               在org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:140)   [Tomcat的嵌入核心-8.5.16.jar /:16年5月8日]               at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:80)   [Tomcat的嵌入核心-8.5.16.jar /:16年5月8日]               在org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:87)   [Tomcat的嵌入核心-8.5.16.jar /:16年5月8日]               在org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:342)   [Tomcat的嵌入核心-8.5.16.jar /:16年5月8日]               在org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:799)   [Tomcat的嵌入核心-8.5.16.jar /:16年5月8日]               在org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:66)   [Tomcat的嵌入核心-8.5.16.jar /:16年5月8日]               at org.apache.coyote.AbstractProtocol $ ConnectionHandler.process(AbstractProtocol.java:868)   [Tomcat的嵌入核心-8.5.16.jar /:16年5月8日]               在org.apache.tomcat.util.net.NioEndpoint $ SocketProcessor.doRun(NioEndpoint.java:1455)   [Tomcat的嵌入核心-8.5.16.jar /:16年5月8日]               在org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49)   [Tomcat的嵌入核心-8.5.16.jar /:16年5月8日]               在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的嵌入核心-8.5.16.jar /:16年5月8日]               在java.lang.Thread.run(Thread.java:748)[na:1.8.0_131]

但是,当我使用Postman时,它做得很好。

请告诉我是什么问题以及如何解决

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

1 个答案:

答案 0 :(得分:0)

尝试稍微修改一下您的服务并尝试

$ meteor add