首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >TomEE CDI @Inject

TomEE CDI @Inject
EN

Stack Overflow用户
提问于 2017-06-07 11:40:00
回答 1查看 786关注 0票数 1

我试图让CDI在我的应用程序中工作,但只有在我得到NullPointerExceptions时才能得到它。

当通常实例化playlistService时,它运行得非常好,但是当我尝试使用CDI时,它就不再使用了。

服务器可以启动,但是当我将beans.xml添加到META/和WEB/时,它也不能再启动了。

PlaylistRESTController.java

代码语言:javascript
复制
import javax.inject.Inject;
import javax.servlet.http.HttpServletRequest;
import javax.ws.rs.*;
import javax.ws.rs.core.*;

@Path("/api/playlist")
public class PlaylistRESTController {

    @Inject
    PlaylistService playlistService; //This one

    @GET
    @Produces(MediaType.APPLICATION_JSON)
    public Playlist[] getUsersPlaylists(
            @CookieParam("st-session") Cookie session,
            @Context HttpServletRequest httpServletRequest
    ) {
        User user = (User) httpServletRequest.getAttribute("user");

        Playlist[] playlist = playlistService.getAllPlaylists(user);

        return playlist;
    }
}

PlaylistService.java

代码语言:javascript
复制
public class PlaylistService implements IPlaylistService {

    PlaylistJPA playlistJPA = new PlaylistJPA();

    public Playlist[] getAllPlaylists(User owner) {
        ArrayList<Playlist> playlist = this.playlistJPA.findByOwner(owner);

        return playlist.toArray(new Playlist[playlist.size()]);
    }
}

pom.xml

代码语言:javascript
复制
<dependencies>
    <dependency>
        <groupId>javax</groupId>
        <artifactId>javaee-api</artifactId>
        <version>7.0</version>
    </dependency>
    <!-- https://mvnrepository.com/artifact/mysql/mysql-connector-java -->
    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
        <version>6.0.6</version>
        <scope>compile</scope>
    </dependency>

    <dependency>
        <groupId>org.hibernate</groupId>
        <artifactId>hibernate-entitymanager</artifactId>
        <version>4.2.6.Final</version>
    </dependency>
</dependencies>

编辑:

资源/META/sistence.xml

代码语言:javascript
复制
<?xml version="1.0" encoding="UTF-8"?>

<persistence version="2.0" xmlns="http://java.sun.com/xml/ns/persistence"
             xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
             xsi:schemaLocation="http://java.sun.com/xml/ns/persistence
   http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd">
    <persistence-unit
            name="mysql">
        <provider>org.hibernate.ejb.HibernatePersistence</provider>

        <class>
            nl.han.dea.domain.Song
        </class>
        <class>
            nl.han.dea.domain.Playlist
        </class>
        <class>
            nl.han.dea.domain.Video
        </class>
        <class>
            nl.han.dea.domain.User
        </class>

        <properties>
            <property name="hibernate.archive.autodetection" value="class"/>
            <property name="hibernate.dialect" value="org.hibernate.dialect.MySQLInnoDBDialect"/>
            <property name="hibernate.connection.driver_class" value="com.mysql.cj.jdbc.Driver"/>
            <property name="hibernate.connection.url"
                      value="jdbc:mysql://localhost:3306/Spotitube?autoReconnect=true&amp;useSSL=false&amp;serverTimezone=UTC"/>
            <property name="hibernate.connection.username" value="spotitube"/>
            <property name="hibernate.connection.password" value="java"/>
            <property name="hibernate.show_sql" value="true"/>
            <property name="javax.persistence.sql-load-script-source" value="insert.sql"/>
            <property name="hibernate.flushMode" value="FLUSH_AUTO"/>
            <property name="hibernate.hbm2ddl.auto" value="update"/>
        </properties>

    </persistence-unit>
</persistence>
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-06-07 11:48:49

您只需在WEB/中添加一个beans.xml即可。

还确保javaee具有提供的范围,确保将jpa和jta从hibernate实体管理器传递依赖项中排除在外,以确保war具有正确的依赖关系,并且与EE服务器没有冲突的api。

附带注意:使用org.apache.tomee:javaee:7.0-1:提供而不是javax:javaee也可以使嵌入式测试工作(openejb或tomee)

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/44411625

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档