Я использую 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);
Я понятия не имею, почему здесь выдается исключение, поэтому любая помощь будет очень признательна. Большое спасибо за ваше время