私は、SpringブートアプリケーションではnullのautoWiredサービスクラスに住んでいます。すべてのオブジェクトはSpringによってインスタンス化されるため、なぜそれが起こるのかわかりません。スプリングブート - サービスクラスがnullです
状況は次のとおりです。 私は以下の通りですRele.javaクラスを持っている:
@Component
public class Rele {
private Pin pin;
private GpioController gpio;
private GpioPinDigitalOutput relePin;
private static final Logger logger = Logger.getLogger(Rele.class);
private Interruttore interruttore;
@Autowired AccensioneService accensioneService;
public Rele(){
}
// Costruttore
public Rele(Pin pin, Interruttore interruttore) {
this.pin = pin;
this.gpio = GpioFactory.getInstance();
this.relePin = gpio.provisionDigitalOutputPin(pin, "MyRele", PinState.LOW);
this.interruttore = interruttore;
}
public void lightOn() {
try {
if (relePin.isLow()) {
relePin.high();
updateAccensione(interruttore, true);
logger.debug("Rele acceso");
}
} catch (NullPointerException e) {
logger.debug("relepin è:" +relePin);
logger.debug("gpio è:"+gpio);
}
}
public void lightOff() {
if (relePin.isHigh()) {
relePin.low();
updateAccensione(interruttore, false);
logger.debug("Rele spento");
}
}
public void updateAccensione(Interruttore interruttore, boolean acceso) {
Date lastDateAccensione = new Date();
try {
logger.debug("accensioneService is"+accensioneService);
lastDateAccensione = accensioneService.findLastDate(interruttore);
} catch(NullPointerException npe){
logger.debug("accensioneService is: "+accensioneService);
logger.error("Error is:", npe);
lastDateAccensione = new Timestamp(lastDateAccensione.getTime());
}
Accensione accensione = new Accensione();
Date date = new Date();
logger.debug("lastDate:" + lastDateAccensione);
accensione.setDateTime(new Timestamp(date.getTime()));
accensione.setInterruttore(interruttore);
accensione.setIsLit(acceso);
accensione.setLastDateTime(lastDateAccensione);
logger.debug("Accensione è:"+accensione.toString());
accensioneService.saveAccensione(accensione);
}
public Pin getPin() {
return pin;
}
public void setPin(Pin pin) {
this.pin = pin;
}
public Interruttore getInterruttore() {
return interruttore;
}
public void setInterruttore(Interruttore interruttore) {
this.interruttore = interruttore;
}
public GpioPinDigitalOutput getRelePin() {
return relePin;
}
public void setRelePin(GpioPinDigitalOutput relePin) {
this.relePin = relePin;
}
public GpioController getGpio() {
return gpio;
}
public void setGpio(GpioController gpio) {
this.gpio = gpio;
}
}
updateAccensione
ために呼び出そうとすると、これはnullです。 RELEこの方法RELEが作成され
@RequestMapping(value="/illuminazione")
public ResponseEntity<Illuminazione> findIlluminazione(@RequestParam(value="idLuce") int idLuce,
@RequestParam(value="lit") boolean lit,
@RequestParam(value="suServer") boolean suServer) {
Illuminazione illuminazione = new Illuminazione();
Date lastDate = illuminazioneService.findLastDate(idLuce);
illuminazione.setLastDateTime(lastDate);
illuminazione.setIdLuce(idLuce);
illuminazione.setIsLit(lit);
Date date = new Date();
illuminazione.setDateTime(new Timestamp(date.getTime()));
illuminazioneService.saveIlluminazione(illuminazione);
logger.debug("Aggiornata luce " + idLuce + " accesa: "+lit);
//managing rele
if(suServer){
//check if status has changed
Luce luce = luceService.findById(idLuce);
int idInterruttore = luce.getInterruttore().getIdInterruttore();
Interruttore interruttore = interruttoreService.findById(idInterruttore);
Rele rele = releService.findByInterruttore(interruttore);
logger.debug("rele="+rele.toString());
if(lit){
rele.lightOn();
} else {
rele.lightOff();
}
}
return new ResponseEntity<Illuminazione>(illuminazione,HttpStatus.OK);
}
により、コントローラから作成され、私は私のログにそれを見つけます。
@Service("accensioneService")
@Transactional
public class AccensioneServiceImpl implements AccensioneService{
@Autowired AccensioneDao dao;
@Override
public void saveAccensione(Accensione accensione) {
dao.saveAccensione(accensione);
}
@Override
public Accensione findById(int id) {
return dao.findById(id);
}
@Override
public Date findLastDate(Interruttore interruttore) {
return dao.findLastDate(interruttore);
}
@Override
public boolean findLastStatus(int id) {
return dao.findLastStatus(id);
}
@Override
public void updateAccensione(Interruttore interruttore) {
}
}
何か他のものが必要とされている場合、私は知らない: AccensioneServiceがインターフェイスである、それは具体的な実装がAccensioneServiceImplあるのです。 AccensioneServiceも私にこのエラーが発生しますRELE内部で呼び出さときにだけ...他の方法およびコントローラに呼ばれ、それが動作します...
あなたの 'releService'はアンマネージドBeanを返すようです。 'Rele'のコンストラクタが複数あるということは、実際にはアンマネージインスタンスを作成していることを強く示唆しています。 – chrylis