由于我在关于CDI的文档方面挣扎不已,我希望这个问题能够成为在Jersey/Glassfish中使用的正确CDI注释的有用资源。使用Jersey/Glassfish更正CDI注释
假设我们有一个应用程序BookStore
:
package my.bookstore;
import javax.ws.rs.ApplicationPath;
import org.glassfish.jersey.server.ResourceConfig;
@ApplicationPath("/bookstore")
public class BookStore extends ResourceConfig {
public BookStore() {
this.packages("my.bookstore.resource");
}
}
我们希望通过RESTful服务Book
实体访问:
package my.bookstore.entity;
public class Book {
public String isbn;
public String title;
public String author;
public Book(String isbn, String title, String author) {
this.isbn = isbn;
this.title = title;
this.author = author;
}
}
所以我们需要一个DAO
访问数据存储:
package my.bookstore.dao;
import my.bookstore.entity.Book;
import java.util.List;
public interface BookDAO {
public List<Book> getAllBooks();
}
及其实施:
package my.bookstore.dao;
import my.bookstore.entity.Book;
import java.util.List;
import java.util.ArrayList;
public class DefaultBookDAO implements BookDAO {
public List<Book> getAllBooks() {
List<Book> bookList = new ArrayList<>();
list.add(new Book("1234", "Awesome Book", "Some Author"));
return bookList;
}
}
然后我想在DefaultBookDAO
注入RESTful服务:
package my.bookstore.resource;
import javax.inject.Inject;
import javax.ws.rs.GET;
import javax.ws.rs.Path;
import javax.ws.rs.Produces;
import javax.ws.rs.core.MediaType;
@Path("/books")
public class BookResource {
@Inject
BookDAO dao;
@GET
@Produces(MediaType.APPLICATION_JSON)
public List<Book> getBooks() {
return this.dao.getAllBooks();
}
}
现在,部署应用程序时,我得到:
Unsatisfied dependencies for type BookDAO with qualifiers @Default
,因为我需要让CDI知道它;但是如何?我尝试了各种组合@Named
,@Default
,@Model
,@Singleton
,@Stateless
和许多资源,如问题和博客文章都有他们自己的解释。
什么是在Jersey/Glassfish中使用这个注射工作的正确的纯CDI注释?
什么版本的玻璃鱼? –
@JohnAment Glassfish 4.1 –