问题描述
当我在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();
}
}
这将起作用。 祝您编码愉快!