Jersey 2 + HK2 - @ApplicationScoped 不工作
Jersey 2 + HK2 - @ApplicationScoped not working
我有class
@ApplicationScoped
public class Service{
private Map<String, Integer> something ;
private final Logger LOGGER = LoggerFactory.getLogger(Service.class);
@PostConstruct
public void initialize(){
something = new HashMap<>();
}
public void increase(String userName){
something.put(userName, something.getOrDefault(userName, 0) + 1);
}
public Map<String, Integer> getSomething(){
return this.something;
}
public Integer getSomethingForUser(String userName){
return something.getOrDefault(userName, 0);
}
}
我想成为全局一个实例。
问题是,当我在两个不同的地方注入此服务时,我有两个不同的服务实例 - 这导致 return 总是反 0
。 .toString()
return如下:
package.services.Service@492e4f4b
package.services.Service@4bc86c4d
我创建此服务是为了测试我的 HK2-Jersey 实施,它显然没有正常工作。
Web.xml:
<servlet-name>jersey-serlvet</servlet-name>
<servlet-class>org.glassfish.jersey.servlet.ServletContainer</servlet-class>
<init-param>
<param-name>jersey.config.server.provider.packages</param-name>
<param-value>io.swagger.jaxrs.listing,mypackage.rest</param-value>
</init-param>
<init-param>
<param-name>jersey.config.server.provider.classnames</param-name>
<param-value>
io.swagger.jaxrs.listing.ApiListingResource,
io.swagger.jaxrs.listing.SwaggerSerializers
</param-value>
</init-param>
<init-param>
<param-name>javax.ws.rs.Application</param-name>
<param-value>mypackage.config.ApplicationConfiguration</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>jersey-serlvet</servlet-name>
<url-pattern>/rest/*</url-pattern>
</servlet-mapping>
ApplicationConfiguration.java:
public class ApplicationConfiguration extends ResourceConfig {
public ApplicationConfiguration() {
register(new AbstractBinder() {
@Override
protected void configure() {
bind(Service.class).to(Service.class);
}
});
packages(true, "com.mypackage.rest");
}
}
如果没有此 bind
函数,服务器会抛出 @Inject
不满足的异常。
谁能指出,哪里不对?
HK2中没有@ApplicationScoped
这样的东西。那只是 CDI(这是不同的)。在 HK2 中有一个单例作用域。根据您的配置,您可以执行
bind(new Service()).to(Service.class);
这将自动使其成为单例。唯一的问题是你失去了容器的任何注入(如果你需要的话)。另一种方式是在in(Scope)
方法中设置作用域
bind(Service.class).to(Service.class).in(Singleton.class);
那是 javax.inject.Singleton
。
我有class
@ApplicationScoped
public class Service{
private Map<String, Integer> something ;
private final Logger LOGGER = LoggerFactory.getLogger(Service.class);
@PostConstruct
public void initialize(){
something = new HashMap<>();
}
public void increase(String userName){
something.put(userName, something.getOrDefault(userName, 0) + 1);
}
public Map<String, Integer> getSomething(){
return this.something;
}
public Integer getSomethingForUser(String userName){
return something.getOrDefault(userName, 0);
}
}
我想成为全局一个实例。
问题是,当我在两个不同的地方注入此服务时,我有两个不同的服务实例 - 这导致 return 总是反 0
。 .toString()
return如下:
package.services.Service@492e4f4b
package.services.Service@4bc86c4d
我创建此服务是为了测试我的 HK2-Jersey 实施,它显然没有正常工作。
Web.xml:
<servlet-name>jersey-serlvet</servlet-name>
<servlet-class>org.glassfish.jersey.servlet.ServletContainer</servlet-class>
<init-param>
<param-name>jersey.config.server.provider.packages</param-name>
<param-value>io.swagger.jaxrs.listing,mypackage.rest</param-value>
</init-param>
<init-param>
<param-name>jersey.config.server.provider.classnames</param-name>
<param-value>
io.swagger.jaxrs.listing.ApiListingResource,
io.swagger.jaxrs.listing.SwaggerSerializers
</param-value>
</init-param>
<init-param>
<param-name>javax.ws.rs.Application</param-name>
<param-value>mypackage.config.ApplicationConfiguration</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>jersey-serlvet</servlet-name>
<url-pattern>/rest/*</url-pattern>
</servlet-mapping>
ApplicationConfiguration.java:
public class ApplicationConfiguration extends ResourceConfig {
public ApplicationConfiguration() {
register(new AbstractBinder() {
@Override
protected void configure() {
bind(Service.class).to(Service.class);
}
});
packages(true, "com.mypackage.rest");
}
}
如果没有此 bind
函数,服务器会抛出 @Inject
不满足的异常。
谁能指出,哪里不对?
HK2中没有@ApplicationScoped
这样的东西。那只是 CDI(这是不同的)。在 HK2 中有一个单例作用域。根据您的配置,您可以执行
bind(new Service()).to(Service.class);
这将自动使其成为单例。唯一的问题是你失去了容器的任何注入(如果你需要的话)。另一种方式是在in(Scope)
方法中设置作用域
bind(Service.class).to(Service.class).in(Singleton.class);
那是 javax.inject.Singleton
。