<beans>
<batch:job id="job1" restartable="false">
<batch:step id="step1" next="step2">
<batch:tasklet>
<batch:chunk reader="readerA" writer="writerA" commit-interval="1" />
</batch:tasklet>
</batch:step>
<batch:step id="step2">
<batch:tasklet ref="tasklet1"/>
</batch:step>
<batch:listeners>
<batch:listener ref="listenerA" />
</batch:listeners>
</batch:job>
<bean id="listenerA" class="com.example.ListenerA" scope="step">
<property name="archiveDate" value="#{jobParameters['jobRunDate']}" />
</bean>
</beans>
为什么上面给出了以下错误:
java.lang.IllegalStateException: No context available while replacing placeholders.
解决此问题的最佳方法是什么?
答案 0 :(得分:3)
我认为问题在于你想要一个步骤监听器,而不是一个求职者。步骤范围超出了您定义监听器的范围,因此范围步骤不可用 - 如果它是作业监听器,您将不需要占位符,因为您可以从当前JobExecution获取变量。
如果你改变了你的配置(假设这是一个步骤监听器,而不是一个工作监听器):
<batch:step id="step1" next="step2">
<batch:tasklet>
<batch:chunk reader="readerA" writer="writerA" commit-interval="1" />
<batch:listeners>
<batch:listener ref="listenerA" />
</batch:listeners>
</batch:tasklet>
</batch:step>
我相信这会给你一个适当的步骤监听器,用于“step1”步骤 - 如果你想要第二步的监听器那么类似的配置。