为了简化我们的web服务,我想在2.34版本中引入一个使用jersey框架的自定义myobj类,并希望通过@context注解注入创建的示例。
我有两个问题:
假设有一个web服务方法@get test(@context myobj obj),我如何控制何时根据现有servlet请求过滤器的执行创建myobj示例?
为了创建myobj的示例,我已经有了一个基于hk2工厂的工作示例(见下文)。由于我观察到我的工厂类被示例化了两次,并且jersey 2.26+推荐使用基于供应商的新方法,所以我尝试转换我的示例。不幸的是,configure()不会在提供的binder implements supplier类中调用,因此不会创建任何对象。我怎样才能让它工作(顺便说一句,在这两种情况下,binder和binderhk都是通过myweb.xml中的jersey.config.server.provider.classnames注册的。)
谢谢你的帮助。
工作hk2工厂示例:
public class MyObjHK {}
import org.glassfish.hk2.utilities.binding.AbstractBinder;
import org.glassfish.jersey.process.internal.RequestScoped;
public class BinderHK
extends AbstractBinder {
@Override protected void configure() {
bindFactory(MyObjFactoryHK.class).to(MyObjHK.class).in(RequestScoped.class);
}
}
import org.glassfish.hk2.api.Factory;
public class MyObjFactoryHK
implements Factory<MyObjHK> {
@Override public MyObjHK provide() {return new MyObjHK();} // ok
@Override public void dispose(MyObjHK instance) {};
}
public class API_HK2 {
@GET
public static Response myobjhk(@Context MyObjHK obj) {
System.out.println("called hk, obj="+obj); // ok
return Response.ok().build();
}
}
不起作用的供应商示例:
public class MyObj {}
import org.glassfish.jersey.internal.inject.AbstractBinder;
import org.glassfish.jersey.process.internal.RequestScoped;
public class Binder
extends AbstractBinder {
@Override protected void configure() { // not called ???
bindFactory(MyObjFactory.class).to(MyObj.class).in(RequestScoped.class);
}
}
import java.util.function.Supplier;
public class MyObjFactory
implements Supplier<MyObj> {
@Override public MyObj get() {return new MyObj();}
}
public class API {
@GET
public static Response myobj(@Context MyObj obj) {
System.out.println("called, obj="+obj); // null ???
return Response.ok().build();
}
}
1条答案
按热度按时间z4iuyo4d1#
活页夹不是可以注册到
jersey.config..classnames
初始化参数。你要么用一个ResourceConfig
或与Feature
(并用init参数注册特性)