Jersey 2.x Multipart /表单数据服务器返回400 Bad Request和MessageBodyWriterNotFoundException

问题描述

当我在jersey 2.26中运行多部分/表单数据上传功能时,它将返回400错误请求。我尝试了很多方法但没有用

不带文件上传时,显示响应消息。当我使用客户端“ MessageBodyWriterNotFoundException”时显示

Upload.java

@Path("/upload")
public class UploadFileDemo {
    
    @POST
    @Consumes(MediaType.MULTIPART_FORM_DATA)
    @Produces(MediaType.TEXT_PLAIN)
    public Response uploadFile(@FormDataParam("file") FileInputStream fileInputStream,@FormDataParam("file") FormDataContentdisposition fileInfo) {
        System.out.println(fileInfo.getFileName()+"-"+fileInfo.getSize());
        String path= "D://"+fileInfo.getFileName();
        int read=0;
        byte[] bytes = new byte[1024];
        try {
            OutputStream out = new FileOutputStream(new File(path));
            while((read = fileInputStream.read(bytes))!=-1) {
                out.write(bytes,read);
            }
            out.flush();
            out.close();    
        } catch (FileNotFoundException e) {
            e.printstacktrace();
        } catch (IOException e) {
            e.printstacktrace();
        }
        return Response.ok("Data uploaded successfully").build();
    }

}

web.xml

<servlet>
        <servlet-name>Jersey Web Application</servlet-name>
        <servlet-class>org.glassfish.jersey.servlet.ServletContainer</servlet-class>
        <init-param>
            <param-name>jersey.config.server.provider.packages</param-name>
            <param-value>com.packages.resource</param-value>
        </init-param>
        <init-param>
            <param-name>jersey.config.server.provider.classnames</param-name>
            <param-value>org.glassfish.jersey.filter.LoggingFilter;
            org.glassfish.jersey.media.multipart.MultiPartFeature</param-value>
        </init-param>
        <load-on-startup>1</load-on-startup>
    </servlet>
    <servlet-mapping>
        <servlet-name>Jersey Web Application</servlet-name>
        <url-pattern>/webapi/*</url-pattern>
    </servlet-mapping>

仅供参考-未显示异常

My logging filter log
Aug 25,2020 12:53:29 PM org.glassfish.jersey.filter.LoggingFilter log
INFO: 1 * Server has received a request on thread http-nio-9090-exec-8
1 > POST http://localhost:9090/rest-new-version/webapi/upload/file
1 > accept: */*
1 > accept-encoding: gzip,deflate,br
1 > connection: keep-alive
1 > content-length: 240
1 > content-type: multipart/form-data; boundary=--------------------------247816562830114154909314
1 > host: localhost:9090
1 > postman-token: 91bec8ef-5857-4604-a512-6dc97d5e22c6
1 > user-agent: PostmanRuntime/7.26.3

Aug 25,2020 12:53:30 PM org.glassfish.jersey.filter.LoggingFilter log
INFO: 1 * Server responded with a response on thread http-nio-9090-exec-8
1 < 400

请帮助我解决这个问题:)

解决方法

FileInputStream用作参数。因此,它返回了400错误的请求。代替使用 InputStream

@Path("/upload")
public class UploadFileDemo {
    
    @POST
    @Consumes(MediaType.MULTIPART_FORM_DATA)
    @Produces(MediaType.TEXT_PLAIN)
    public Response uploadFile(@FormDataParam("file") InputStream fileInputStream,@FormDataParam("file") FormDataContentDisposition fileInfo) {
        System.out.println(fileInfo.getFileName()+"-"+fileInfo.getSize());
        String path= "D://"+fileInfo.getFileName();
        int read=0;
        byte[] bytes = new byte[1024];
        try {
            OutputStream out = new FileOutputStream(new File(path));
            while((read = fileInputStream.read(bytes))!=-1) {
                out.write(bytes,read);
            }
            out.flush();
            out.close();    
        } catch (FileNotFoundException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        }
        return Response.ok("Data uploaded successfully").build();
    }

}

这将起作用。 祝您编码愉快!