Вопрос-ответ

MULTIPART_FORM_DATA: No injection source found for a parameter of type public javax.ws.rs.core.Response

MULTIPART_FORM_DATA: Не найден источник внедрения для параметра типа public javax.ws.rs.core.Ответ

Я использую стратегию реализации restful Service на основе Джерси для создания сервиса, который будет использоваться для загрузки файлов. Имя моего класса service: UploadFileService.java (См. Код ниже)

 package com.jerser.service;

import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import javax.ws.rs.Consumes;
import javax.ws.rs.POST;
import javax.ws.rs.Path;
import javax.ws.rs.core.MediaType;
import javax.ws.rs.core.Response;
import com.sun.jersey.core.header.FormDataContentDisposition;
import com.sun.jersey.multipart.FormDataParam;

@Path("/fileUpload")
public class UploadFileService {

@POST
@Path("/upload")
@Consumes(MediaType.MULTIPART_FORM_DATA)
public Response uploadFile(
@FormDataParam("file") InputStream uploadedInputStream,
@FormDataParam("file") FormDataContentDisposition fileDetail)
{

String uploadedFileLocation = "d://uploaded/" + fileDetail.getFileName();

// save it
writeToFile(uploadedInputStream, uploadedFileLocation);

String output = "File uploaded to : " + uploadedFileLocation;

return Response.status(200).entity(output).build();

}

// save uploaded file to new location
private void writeToFile(InputStream uploadedInputStream,
String uploadedFileLocation)
{

try {
OutputStream out = new FileOutputStream(new File(
uploadedFileLocation));
int read = 0;
byte[] bytes = new byte[1024];

out = new FileOutputStream(new File(uploadedFileLocation));
while ((read = uploadedInputStream.read(bytes)) != -1) {
out.write(bytes, 0, read);
}
out.flush();
out.close();
} catch (IOException e) {

e.printStackTrace();
}

}

}

Это файлы JAR, которые есть у меня в моей библиотеке:


aopalliance-repackaged-2.4.0-b10.jar     
asm-debug-all-5.0.2.jar
hk2-api-2.4.0-b10.jar
hk2-locator-2.4.0-b10.jar
hk2-utils-2.4.0-b10.jar
javassist-3.18.1-GA.jar
javax.annotation-api-1.2.jar
javax.inject-2.4.0-b10.jar
javax.servlet-api-3.0.1.jar
javax.ws.rs-api-2.0.1.jar
jaxb-api-2.2.7.jar
jersey-client.jar
jersey-common.jar
jersey-container-servlet-core.jar
jersey-container-servlet.jar
jersey-core-1.11.jar
jersey-guava-2.17.jar
jersey-media-jaxb.jar
jersey-multipart-1.18.jar
jersey-server.jar
org.osgi.core-4.2.0.jar
osgi-resource-locator-1.0.1.jar
persistence-api-1.0.jar
validation-api-1.1.0.Final.jar

Я получаю следующую ошибку при попытке запустить мой сервер tomcat :

org.glassfish.jersey.server.model.ModelValidationException: Validation of the application resource model has failed during application initialization.
[[FATAL] No injection source found for a parameter of type public javax.ws.rs.core.Response com.jerser.service.UploadFileService.uploadFile(java.io.InputStream,com.sun.jersey.core.header.FormDataContentDisposition) at index 0.; source='ResourceMethod{httpMethod=POST, consumedTypes=[multipart/form-data], producedTypes=[], suspended=false, suspendTimeout=0, suspendTimeoutUnit=MILLISECONDS, invocable=Invocable{handler=ClassBasedMethodHandler{handlerClass=class com.jerser.service.UploadFileService, handlerConstructors=[org.glassfish.jersey.server.model.HandlerConstructor@d3e2d4]}, definitionMethod=public javax.ws.rs.core.Response com.jerser.service.UploadFileService.uploadFile(java.io.InputStream,com.sun.jersey.core.header.FormDataContentDisposition), parameters=[Parameter [type=class java.io.InputStream, source=file, defaultValue=null], Parameter [type=class com.sun.jersey.core.header.FormDataContentDisposition, source=file, defaultValue=null]], responseType=class javax.ws.rs.core.Response}, nameBindings=[]}']
at org.glassfish.jersey.server.ApplicationHandler.initialize(ApplicationHandler.java:528)
at org.glassfish.jersey.server.ApplicationHandler.access$500(ApplicationHandler.java:166)
at org.glassfish.jersey.server.ApplicationHandler$3.run(ApplicationHandler.java:327)
at org.glassfish.jersey.internal.Errors$2.call(Errors.java:289)
at org.glassfish.jersey.internal.Errors$2.call(Errors.java:286)
at org.glassfish.jersey.internal.Errors.process(Errors.java:315)
at org.glassfish.jersey.internal.Errors.process(Errors.java:297)
at org.glassfish.jersey.internal.Errors.processWithException(Errors.java:286)
at org.glassfish.jersey.server.ApplicationHandler.<init>(ApplicationHandler.java:324)
at org.glassfish.jersey.servlet.WebComponent.<init>(WebComponent.java:338)
at org.glassfish.jersey.servlet.ServletContainer.init(ServletContainer.java:171)
at org.glassfish.jersey.servlet.ServletContainer.init(ServletContainer.java:363)
at javax.servlet.GenericServlet.init(GenericServlet.java:160)
at org.apache.catalina.core.StandardWrapper.initServlet(StandardWrapper.java:1176)
at org.apache.catalina.core.StandardWrapper.loadServlet(StandardWrapper.java:1102)
at org.apache.catalina.core.StandardWrapper.load(StandardWrapper.java:1009)
at org.apache.catalina.core.StandardContext.loadOnStartup(StandardContext.java:4885)
at org.apache.catalina.core.StandardContext$3.call(StandardContext.java:5212)
at org.apache.catalina.core.StandardContext$3.call(StandardContext.java:5207)
at java.util.concurrent.FutureTask$Sync.innerRun(Unknown Source)
at java.util.concurrent.FutureTask.run(Unknown Source)
at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
at java.lang.Thread.run(Unknown Source)

В Интернете я обнаружил множество примеров, показывающих, как загрузить СОСТАВНОЙ файл с помощью RESTful API. Но с тем же решением. Я также не могу запустить этот код.
Я думаю, что я делаю что-то не так с файлами JAR. Кто-нибудь, пожалуйста, может мне помочь в этом?

Переведено автоматически
Ответ 1

Избавиться от jersey-multipart-1.18.jar. Это для Jersey 1.x. Добавьте эти два

Для Maven вы бы использовали следующую зависимость (вам не нужно явно добавлять mimepull зависимость, так как она сама ее добавит).

<dependency>
<groupId>org.glassfish.jersey.media</groupId>
<artifactId>jersey-media-multipart</artifactId>
<version>2.17</version> <!-- Make sure the Jersey version matches
the one you are currently using -->

</dependency>

Затем вам нужно зарегистрировать MultiPartFeature. Если вы используете ResourceConfig для настройки, вы можете просто сделать

register(MultiPartFeature.class);

Если вы используете web.xml, то вы можете добавить класс как <init-param> в сервлет Jersey

<init-param>
<param-name>jersey.config.server.provider.classnames</param-name>
<param-value>org.glassfish.jersey.media.multipart.MultiPartFeature</param-value>
</init-param>

Обратите внимание, что если у вас есть несколько поставщиков, которые вы хотите зарегистрировать, вы можете разделить каждый класс поставщика запятой, точкой с запятой или пробелом / переводом строки. Вы не можете использовать одно и то же значение param-name дважды. Смотрите Ответ Суараба

Обновить

Кроме того, как только вы избавитесь от jersey-multipart-1.18.jar, у вас будут ошибки компиляции для отсутствующих импортированных классов. По большей части имена классов остаются прежними, изменились только пакеты, т.Е.


Для Dropwizard

Если вы используете Dropwizard, вместо добавления jersey-media-multipartони документируют, чтобы вы добавили dropwizard-forms вместо этого. И вместо регистрации MultiPartFeature вам следует зарегистрировать MultiPartBundle

@Override
public void initialize(Bootstrap<ExampleConfiguration> bootstrap) {
bootstrap.addBundle(new MultiPartBundle());
}

На самом деле это не имеет большого значения, поскольку все, что делает пакет Dropwizard, это регистрирует MultiPartFeature с ResourceConfig .


В сторону

Если вы здесь по другому поводу ModelValidationException, вот несколько ссылок для получения информации о других причинах исключения.

Ответ 2

Еще одной возможной причиной этой очень общей ошибки является то, что Jersey выполняет поиск фабрик, связанных с последней аннотацией, только тогда, когда в параметре объявлено несколько фабрик. (См. Отчет об ошибке)

Пока это не будет исправлено, если вы используете какие-либо другие аннотации помимо @FormDataParam, они должны быть последними.

Это работает:

@NotEmpty @FormDataParam("myParam") String myParam

Это не:

@FormDataParam("myParam") @NotEmpty String myParam
Ответ 3

Я тоже получил такое же исключение.Я внес следующие изменения в web.xml

<init-param>
<param-name>jersey.config.server.provider.classnames</param-name>
<param-value>org.glassfish.jersey.filter.LoggingFilter;org.glassfish.jersey.moxy.json.MoxyFeature;org.glassfish.jersey.media.multipart.MultiPartFeature</param-value>
</init-param>

и изменил jersey 2.7 на 2.9 .Я не знаю, какое изменение из этих 2 решило проблему.

Ответ 4

Если кто-то использует аннотацию swagger @FormDataParam with @ApiOperation, она не будет работать (согласно последней версии swagger на данный момент), как упомянуто здесь:

https://github.com/swagger-api/swagger-ui/issues/169

java rest