为什么我的Java调度程序在AEM中不起作用?

问题描述 投票:0回答:1

我为AEM编写了一个Java调度程序。当我在system/console/bundle上的Apache Felix上传jar文件时,我的Java服务没有启动。

我的代码:

@Component
@Service(value = Runnable.class)
@Properties(value = { @Property(name = "scheduler.period", longValue = 1),
        @Property(name = "scheduler.concurrent", boolValue = false), })
public class DisclosureLevel_Scheduler implements Runnable {

    private static final Logger log = LoggerFactory.getLogger(DisclosureLevel_Scheduler.class);

    @Reference
    private DisclosureLevelService disclosureLevelService;
    @Reference
    private ResourceResolverFactory resolverFactory;

    @Override
    public void run() {
        try {
            log.info("disclosureLevelService Job Started ::: ");
        } catch (Exception e) {
            log.error("Exception in scedular job " + e.getMessage());
        }
    }
}

我的日志文件中没有打印任何内容:(

组件服务状态是unsatisfied reference

java aem
1个回答
1
投票

组件服务状态是不满意的参考

这意味着AEM无法“注入”您在课堂上定义的一个或两个@Reference。如果应该注入的服务不存在,通常会发生这种情况。

看看你的参考资料,我认为DisclosureLevelService缺失了,因为Aaz(或Sling)提供的ResourceResolverFactoryis本身应该存在,除非你的AEM确实存在问题。

要检查您的服务是否存在,请访问Felix控制台<your-host>/system/console/services。要检查组件是否存在,请转到Felix控制台<your-host>/system/console/components

© www.soinside.com 2019 - 2024. All rights reserved.