创建名称为' FilterService的bean时出错:通过字段< filterDAO'表示不满意的依赖关系

时间:2018-05-15 19:46:20

标签: java spring jpa

我是春天的初学者,我的代码存在问题。当我尝试运行后端应用程序时,我有以下错误:

我不知道问题是什么,因为我跟踪了关于foruns和教程的例子

我认为FilterDAO类不能注入我的Controoler FilterService,但我不知道为什么。

你可以帮我解决这个错误吗?

按照以下错误和我的课程

1 - 日食错误:

 org.springframework.web.util.NestedServletException: Request processing failed; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'FilterService': Unsatisfied dependency expressed through field 'filterDAO': Error creating bean with name 'FilterDAO' defined in file [C:\Users\andrev\Documents\kaiju_project\.metadata\.plugins\org.eclipse.wst.server.core\tmp0\angularkaiju\WEB-INF\classes\com\motorola\gisele\persistence\moto4u\FilterDAO.class]: Instantiation of bean failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [com.motorola.gisele.persistence.moto4u.FilterDAO]: Constructor threw exception; nested exception is java.lang.NullPointerException; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'FilterDAO' defined in file [C:\Users\andrev\Documents\kaiju_project\.metadata\.plugins\org.eclipse.wst.server.core\tmp0\angularkaiju\WEB-INF\classes\com\motorola\gisele\persistence\moto4u\FilterDAO.class]: Instantiation of bean failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [com.motorola.gisele.persistence.moto4u.FilterDAO]: Constructor threw exception; nested exception is java.lang.NullPointerException
at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:982)
at org.springframework.web.servlet.FrameworkServlet.doOptions(FrameworkServlet.java:908)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:716)
at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:846)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:790)
at org.eclipse.jetty.servlet.ServletHolder.handle(ServletHolder.java:848)
at org.eclipse.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1772)
at com.googlecode.objectify.ObjectifyFilter.doFilter(ObjectifyFilter.java:48)
at org.eclipse.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1759)
at com.google.appengine.tools.development.ResponseRewriterFilter.doFilter(ResponseRewriterFilter.java:134)
at org.eclipse.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1759)
at com.google.appengine.tools.development.HeaderVerificationFilter.doFilter(HeaderVerificationFilter.java:34)
at org.eclipse.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1759)
at com.google.appengine.api.blobstore.dev.ServeBlobFilter.doFilter(ServeBlobFilter.java:63)
at org.eclipse.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1759)
at com.google.apphosting.utils.servlet.TransactionCleanupFilter.doFilter(TransactionCleanupFilter.java:50)
at org.eclipse.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1759)
at com.google.appengine.tools.development.jetty9.StaticFileFilter.doFilter(StaticFileFilter.java:123)
at org.eclipse.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1759)
at com.google.appengine.tools.development.DevAppServerModulesFilter.doDirectRequest(DevAppServerModulesFilter.java:366)
at com.google.appengine.tools.development.DevAppServerModulesFilter.doDirectModuleRequest(DevAppServerModulesFilter.java:349)
at com.google.appengine.tools.development.DevAppServerModulesFilter.doFilter(DevAppServerModulesFilter.java:116)
at org.eclipse.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1759)
at com.google.appengine.tools.development.DevAppServerRequestLogFilter.doFilter(DevAppServerRequestLogFilter.java:44)
at org.eclipse.jetty.servlet.ServletHandler$CachedChain.doFilter(ServletHandler.java:1751)
at org.eclipse.jetty.servlet.ServletHandler.doHandle(ServletHandler.java:582)
at org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:143)
at org.eclipse.jetty.security.SecurityHandler.handle(SecurityHandler.java:524)
at org.eclipse.jetty.server.session.SessionHandler.doHandle(SessionHandler.java:226)
at org.eclipse.jetty.server.handler.ContextHandler.doHandle(ContextHandler.java:1180)
at org.eclipse.jetty.servlet.ServletHandler.doScope(ServletHandler.java:512)
at org.eclipse.jetty.server.session.SessionHandler.doScope(SessionHandler.java:185)
at org.eclipse.jetty.server.handler.ContextHandler.doScope(ContextHandler.java:1112)
at com.google.appengine.tools.development.jetty9.DevAppEngineWebAppContext.doScope(DevAppEngineWebAppContext.java:94)
at org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:141)
at org.eclipse.jetty.server.handler.HandlerWrapper.handle(HandlerWrapper.java:134)
at com.google.appengine.tools.development.jetty9.JettyContainerService$ApiProxyHandler.handle(JettyContainerService.java:597)
at org.eclipse.jetty.server.handler.HandlerWrapper.handle(HandlerWrapper.java:134)
at org.eclipse.jetty.server.Server.handle(Server.java:531)
at org.eclipse.jetty.server.HttpChannel.handle(HttpChannel.java:320)
at org.eclipse.jetty.server.HttpConnection.onFillable(HttpConnection.java:251)
at org.eclipse.jetty.io.AbstractConnection$ReadCallback.succeeded(AbstractConnection.java:283)
at org.eclipse.jetty.io.FillInterest.fillable(FillInterest.java:108)
at org.eclipse.jetty.io.SelectChannelEndPoint$2.run(SelectChannelEndPoint.java:93)
at org.eclipse.jetty.util.thread.strategy.ExecuteProduceConsume.executeProduceConsume(ExecuteProduceConsume.java:303)
at org.eclipse.jetty.util.thread.strategy.ExecuteProduceConsume.produceConsume(ExecuteProduceConsume.java:148)
at org.eclipse.jetty.util.thread.strategy.ExecuteProduceConsume.execute(ExecuteProduceConsume.java:100)
at org.eclipse.jetty.io.ManagedSelector.run(ManagedSelector.java:147)
at org.eclipse.jetty.util.thread.QueuedThreadPool.runJob(QueuedThreadPool.java:671)
at org.eclipse.jetty.util.thread.QueuedThreadPool$2.run(QueuedThreadPool.java:589)
at java.lang.Thread.run(Unknown Source)
Caused by: 

我有一个名为' FilterServiceRest'的Rest类。 (见下文):

2 - FilterServiceRest.class

@Lazy
@CrossOrigin
@RestController("FilterService")
@RequestMapping("/filters")
@SuppressWarnings("rawtypes")
@DisableSecurity
public class FilterServiceRest extends RestService {

private static final String SOMETHING_WENT_WRONG_MSG = "Something went wrong. Try again in a few seconds!";

    private static final Logger logger = Logger.getLogger(FilterServiceRest.class.getName());

    @Autowired
    private FilterDAO filterDAO;


    @RequestMapping(value = "/top-models", method = RequestMethod.GET)
    public ResponseEntity topModels() {
        List models = filterDAO.getTopModels();
        return ok(models);
    }

    @RequestMapping(value = "/top-prices", method = RequestMethod.GET)
    public ResponseEntity topPrices() {
        List rangePrices = filterDAO.getTopPrices();
        return ok(rangePrices);
    }


    @RequestMapping(value = "/top-features", method = RequestMethod.GET)
    public ResponseEntity topFeatures() {
        TopFeaturesVO features = filterDAO.getTopFeatures();
        return ok(features);
    }

}

我有一个DAO类,它将创建EntityManager并在数据库上执行查询

3 - FilterDAO.class

@Lazy
@Repository("FilterDAO")
public class FilterDAO {

    private static final Logger logger = Logger.getLogger(FilterDAO.class.getName());
    private static final int BATCH_SIZE = 25;

    private Moto4UCloudSQLConfiguration moto4UCloudSQLConfiguration;

    private EntityManager entityManager;

    @Autowired
    public FilterDAO(Moto4UCloudSQLConfiguration moto4UCloudSQLConfiguration){
        this.moto4UCloudSQLConfiguration = moto4UCloudSQLConfiguration;
        this.entityManager = moto4UCloudSQLConfiguration.createEntityManagerFactory("jirammi");
    }

    public List getTopModels() {
        String query =
        "Select moto4u.device.model, count(*) as quant from moto4u.filter inner join moto4u.device on moto4u.device.id = moto4u.filter.device_selected group by device_selected order by quant DESC";
        return this.entityManager.createQuery(query).getResultList();
    }

    public List getTopPrices() {
        String query = "Select range_price, count(*) as quant from moto4u.filter group by range_price order by quant DESC";
        return this.entityManager.createQuery(query).getResultList();
    }

     /**....**/

}

最后我还有另外一个设置数据库配置和执行查询的类。

4 - Moto4UCloudSQLConfiguration.class

@Configuration
@PropertySource("classpath:application.properties")
public class Moto4UCloudSQLConfiguration {

    private static final Logger logger = Logger.getLogger(Moto4UCloudSQLConfiguration.class.getName());

    private static final String MOTO4U_PUNIT_NAME = "Moto4uSQL";
    private static final String JDBC_CLASS_NAME = "com.mysql.jdbc.GoogleDriver";
    private static final String LOCALHOST_NAME = "localhost";
    private static final String JAVAX_PERSISTENCE_JDBC_USER = "javax.persistence.jdbc.user";
    private static final String JAVAX_PERSISTENCE_JDBC_PASS = "javax.persistence.jdbc.password";
    private static final String JAVAX_PERSISTENCE_JDBC_URL = "javax.persistence.jdbc.url";

    @Value("${cloudsql.moto4u.localdb.user}")
    private String localDBUser;

    @Value("${cloudsql.moto4u.localdb.password}")
    private String localDBPass;

    @Value("${cloudsql.moto4u.localdb.url}")
    private String localDBURL;

    // This flag is used to connect the local development machine to a remote MySQL server (i.e. Jirammi)
    @Value("${cloudsql.moto4u.flag.use-remotedb}")
    private Boolean useRemoteDB;

    private EntityManagerFactory emf;
    private EntityManager em;

    /**
     * This method is used by LocalDataStoreLoader.
     *
     * @param server the server to connect to when creating the EntityManagerFactory
     * @return an EntityManagerFactory
     */
    public EntityManager createEntityManagerFactory(String server) {
        Map<String, String> properties = new HashMap<>();
        if(LOCALHOST_NAME.equals(server)){
            logger.info("EntityManagerFactory using localhost");
            properties.put(JAVAX_PERSISTENCE_JDBC_URL, localDBURL);
            properties.put(JAVAX_PERSISTENCE_JDBC_USER, localDBUser);
            properties.put(JAVAX_PERSISTENCE_JDBC_PASS, localDBPass);
        }

        properties.put("hibernate.ejb.entitymanager_factory_name", server);
        EntityManagerFactory factory = Persistence.createEntityManagerFactory(MOTO4U_PUNIT_NAME, properties);

        if (em == null) {
            em = factory.createEntityManager();
        }

        return em;
   } 

}

1 个答案:

答案 0 :(得分:0)

错误:&#39; FilterDAO&#39; - &GT; &#34;构造函数抛出异常;嵌套异常是java.lang.NullPointerException&#34;

private FilterDAO(){
        this.entityManager = moto4UCloudSQLConfiguration.createEntityManagerFactory("jirammi");
    }

这里moto4UCloudSQLConfiguration为空,你没有实现它