我正在使用在Spring Boot应用程序中为null的autoWired服务类。每个对象都由Spring实例化,所以我不知道为什么会发生。

情况是:
我有一个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

@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);

    }


Rele已创建,我在日志中找到它。
AccensioneService是一个接口,它的具体实现是AccensioneServiceImpl:

@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在其他方法和控制器中也被调用,并且它的工作原理是……仅当在Rele内部调用时才出现此错误……

最佳答案

编辑添加

您必须调用new Rele()或其他Rele(Pin, Interruttore )构造函数吗?如果在代码中调用这些函数,则accensioneService将为null,因为Spring需要创建Bean,如果要将bean自动装配到其中或将bean自动装配,则无法使用其构造函数创建它。如果您希望它具有这样的行为,Spring必须知道它,因此它必须位于(或来自)Spring上下文中。

在每个构造函数中放置一条log语句,找出谁在调用它们,并进行修复,以使您可以从Spring获取bean,而不是调用构造函数。

下面的旧答案

您需要发布此方法以确保:

Rele rele = releService.findByInterruttore(interruttore);

我敢打赌,您是通过调用rele在某个地方创建new Rele()的,这是不正确的。您需要让Spring为您创建它。

您没有发布足够的代码以提供更多建议。

另外,您说this is null。你这是在说什么

10-08 18:10