Не удалось создать экземпляр класса HeroController;конструктор бросил исключение;вложенным исключением является java.lang.NullPointerException - PullRequest
0 голосов
/ 15 мая 2019

Я использую SpringBoot для своего веб-приложения, и у меня возникает следующая ошибка:

Исключительная ситуация при инициализации контекста - отмена попытки обновления: org.springframework.beans.factory.BeanCreationException: ошибка создания бина с именем 'heroController', определенного в файле [D: \ Projects \ Java \ mydbexxcercise \ target \ classes \ com \ db \ controllers \ HeroController.class]: не удалось создать объект bean; вложенным исключением является org.springframework.beans.BeanInstantiationException: не удалось создать экземпляр [com.db.controllers.HeroController]: конструктор вызвал исключение; Вложенное исключение - java.lang.NullPointerException.

Это мои занятия:

Класс DBApp (основной класс):

package com.db.app;
import org.springframework.boot.SpringApplication;

import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.autoconfigure.domain.EntityScan;
import org.springframework.context.ConfigurableApplicationContext;
import org.springframework.context.annotation.ComponentScan;

import org.springframework.data.jpa.repository.config.EnableJpaRepositories;

/*
* DAL - Data Access Layer
* BL - Business Layer
*
* */


@SpringBootApplication
@ComponentScan(basePackages = {"com.db.controllers","com.db.services"})
@EnableJpaRepositories(basePackages = "com.db.repositories")
@EntityScan(basePackages = "com.db.entities")
public class DBApp
{
    public enum PowerCatagory{SpecialPower,Weapon,Machines}
    private static ConfigurableApplicationContext appContext;
    public static void main(String[] args)
    {
        appContext = SpringApplication.run(DBApp.class,args);

    }

    public static ConfigurableApplicationContext getAppContext()
    {
        return appContext;
    }

}

Класс HeroRepository:

@Repository
public interface HeroRepository extends JpaRepository<Hero, Integer>
{


}

Класс сущности героя:

package com.db.entities;

import javax.persistence.Entity;
import javax.persistence.Id;
import javax.persistence.Table;
import com.db.app.DBApp;
import org.postgresql.geometric.PGpolygon;
import org.springframework.stereotype.Component;

@Entity
@Table(name="hero")
public class Hero
{

    public int getHid() {
        return hid;
    }

    public PGpolygon getArea() {
        return area;
    }

    public String getSpower() {
        return spower;
    }

    public String getFname() {
        return fname;
    }

    public String getLname() {
        return lname;
    }

    public DBApp.PowerCatagory getPc() {
        return pc;
    }

    public float getPower_level() {
        return power_level;
    }

    public float getLuck() {
        return luck;
    }

    @Id private int hid;//This is the table's primary key

    public void setHid(int hid) {
        this.hid = hid;
    }

    public void setArea(PGpolygon area) {
        this.area = area;
    }

    public void setSpower(String spower) {
        this.spower = spower;
    }

    public void setFname(String fname) {
        this.fname = fname;
    }

    public void setLname(String lname) {
        this.lname = lname;
    }

    public void setPc(DBApp.PowerCatagory pc) {
        this.pc = pc;
    }

    public void setPower_level(float power_level) {
        this.power_level = power_level;
    }

    public void setLuck(float luck) {
        this.luck = luck;
    }

    private PGpolygon area;
    private String spower;
    private String fname;
    private String lname;
    private DBApp.PowerCatagory pc;
    private float power_level;
    private float luck;

    public Hero(int hid, PGpolygon area, String spower, String fname, String lname, DBApp.PowerCatagory pc, float power_level, float luck) {
        this.hid = hid;
        this.area = area;
        this.spower = spower;
        this.fname = fname;
        this.lname = lname;
        this.pc = pc;
        this.power_level = power_level;
        this.luck = luck;
    }

}

Класс HeroService:

package com.db.services;
import com.db.entities.Hero;
import com.db.repositories.HeroRepository;
import com.db.app.DBApp;
import org.springframework.stereotype.Service;

import java.util.ArrayList;
import java.util.List;

@Service
public class HeroService
{
    private HeroRepository heroRepository = DBApp.getAppContext().getBean(HeroRepository.class);

    public List<Hero> getAllHeroes()
    {
        List<Hero> res = new ArrayList<>();
        heroRepository.findAll().forEach(res::add);
        return res;
    }

    public void addHero(Hero hero)
    {
        heroRepository.save(hero);
    }

    public Hero getHero(int id)
    {
        return heroRepository.findById(id).get();
    }

    public void updateHero(Hero hero)
    {
        heroRepository.save(hero);/*If a hero with the same id
        already exists in the DB then the save() function
        will automatically update that same tuple.*/
    }

    public void deleteHero(Hero hero)
    {
        heroRepository.delete(hero);
    }
}

Класс HeroController:

package com.db.controllers;
import com.db.app.DBApp;
import com.db.entities.Hero;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;
import com.db.services.HeroService;

import java.util.List;

@RestController
public class HeroController
{
    private HeroService heroService = DBApp.getAppContext().getBean(HeroService.class);

    @GetMapping("/hero")
    public List<Hero> getAllHeroes()
    {
        //System.out.println(heroService.getAllHeroes());
        return heroService.getAllHeroes();
    }

    @GetMapping("/")
    public String test()
    {
        //System.out.println(heroService.getAllHeroes());
        return "working!!!";
   }

}

pom.xml файл:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>MyDBExcercise</groupId>
    <artifactId>mydbexxcercise</artifactId>
    <version>1.0-SNAPSHOT</version>

    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-parent</artifactId>
        <version>2.1.4.RELEASE</version>
    </parent>

    <dependencies>
        <dependency>
            <groupId>com.aerospike</groupId>
            <artifactId>spring-data-aerospike</artifactId>
            <version>1.0.2.RELEASE</version>
        </dependency>


        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.data</groupId>
            <artifactId>spring-data-jpa</artifactId>
            <version>2.1.6.RELEASE</version>
        </dependency>
        <dependency>
            <groupId>javax.persistence</groupId>
            <artifactId>javax.persistence-api</artifactId>
            <version>2.2</version>
        </dependency>
        <dependency>
            <groupId>org.postgresql</groupId>
            <artifactId>postgresql</artifactId>
            <version>42.2.5</version>
        </dependency>
        <dependency>
            <groupId>org.hibernate</groupId>
            <artifactId>hibernate-entitymanager</artifactId>
            <version>5.4.2.Final</version>
        </dependency>

    </dependencies>



    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>


</project>

В соответствии с консолью причина, по которой Spring не может инициализировать HeroController, является исключением, вызванным следующим кодом:

private HeroService heroService = DBApp.getAppContext().getBean(HeroService.class);

Я понятия не имею, почему здесь выдается исключение, поэтому любая помощь будет очень признательна. Большое спасибо за ваше время

Ответы [ 2 ]

0 голосов
/ 15 мая 2019
  1. Переместите DBApp в пакет com.db.
  2. Удалить все аннотации, но @SpringBootApplication другие подразумеваются и автоматически распознаются
  3. Удалите метод getAppContext.

При этом ваш DBApp класс должен выглядеть примерно так.

package com.db;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class DBApp {
    public enum PowerCatagory{SpecialPower,Weapon,Machines}

    public static void main(String[] args) {
        SpringApplication.run(DBApp.class,args);

    }
}

Теперь в ваших HeroService и HeroController вам нужно использовать внедрение зависимостей. Лучшая практика - использовать инжектор конструктора вместо полевого.

@Service
public class HeroService {

  private final HeroRepository heroRepository;

  public HeroService(HeroRepository heroRepository) {
     this.heroRepository=heroRepository;
  }

HeroController

@RestController
public class HeroController {

  private final HeroService heroService;

  public HeroController(HeroService heroService) {
    this.heroService=heroService;
  }

ПРИМЕЧАНИЕ: Аннотация @Repository на HeroRepository может быть удалена, поскольку она ничего не добавляет.

Далее ваши зависимости немного беспорядочные, используйте выделенные стартовые средства весенней загрузки, чтобы получить правильные и протестированные версии. Вам не нужна зависимость Hibernate / JPA (они включены в spring-boot-starter-data-jpa), а другим нужны более новые версии.

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>MyDBExcercise</groupId>
    <artifactId>mydbexxcercise</artifactId>
    <version>1.0-SNAPSHOT</version>

    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-parent</artifactId>
        <version>2.1.4.RELEASE</version>
    </parent>

    <dependencies>
        <dependency>
            <groupId>com.aerospike</groupId>
            <artifactId>spring-data-aerospike</artifactId>
            <version>2.0.1.RELEASE</version>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-jpa</artifactId>
        </dependency>

        <dependency>
            <groupId>org.postgresql</groupId>
            <artifactId>postgresql</artifactId>
        </dependency>

    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>

</project>
0 голосов
/ 15 мая 2019

Ниже 2 изменений должны решить эту проблему.Нет необходимости получать бин из контекста приложения.

@Service
public class HeroService {
    @Autowired
    private HeroRepository heroRepository;

&

@RestController
public class HeroController {
    @Autowired
    private HeroService heroService;

& pom.xml

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">

<modelVersion>4.0.0</modelVersion>
<parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>2.1.4.RELEASE</version>
    <relativePath/> <!-- lookup parent from repository -->
</parent>

<groupId>MyDBExcercise</groupId>
<artifactId>mydbexxcercise</artifactId>
<version>0.0.1-SNAPSHOT</version>

<properties>
    <java.version>1.8</java.version>
</properties>

<dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter</artifactId>
    </dependency>

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-test</artifactId>
        <scope>test</scope>
    </dependency>

    <dependency>
        <groupId>com.aerospike</groupId>
        <artifactId>spring-data-aerospike</artifactId>
        <version>1.0.2.RELEASE</version>
    </dependency>


    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-data-jpa</artifactId>
    </dependency>

    <dependency>
        <groupId>org.postgresql</groupId>
        <artifactId>postgresql</artifactId>
    </dependency>

</dependencies>

<build>
    <plugins>
        <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
        </plugin>
    </plugins>
</build>

& application.свойства

spring.datasource.url=jdbc:postgresql://localhost:5432/postgres
spring.datasource.username=postgres
spring.datasource.password=*****
spring.jpa.properties.hibernate.jdbc.lob.non_contextual_creation=true
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...