Spring 使用StatxeventitemWriter时无法创建动态文件名

Spring 使用StatxeventitemWriter时无法创建动态文件名,spring,spring-batch,itemwriter,Spring,Spring Batch,Itemwriter,我正在扩展StatxeventitemWriter以编写自定义ItemWriter,以便可以在运行时动态创建文件名。 文件名创建得很好,但是我在试图写入数据时遇到了以下问题 org.springframework.batch.core.step.tasklet.UncheckedTransactionException: java.lang.reflect.InvocationTargetException at org.springframework.batch.core.step.t

我正在扩展StatxeventitemWriter以编写自定义ItemWriter,以便可以在运行时动态创建文件名。 文件名创建得很好,但是我在试图写入数据时遇到了以下问题

org.springframework.batch.core.step.tasklet.UncheckedTransactionException: java.lang.reflect.InvocationTargetException
    at org.springframework.batch.core.step.tasklet.TaskletStep$ChunkTransactionCallback.doInTransaction(TaskletStep.java:486)
    at org.springframework.batch.core.step.tasklet.TaskletStep$ChunkTransactionCallback.doInTransaction(TaskletStep.java:330)
    at org.springframework.transaction.support.TransactionTemplate.execute(TransactionTemplate.java:133)
    at org.springframework.batch.core.step.tasklet.TaskletStep$2.doInChunkContext(TaskletStep.java:272)
    at org.springframework.batch.core.scope.context.StepContextRepeatCallback.doInIteration(StepContextRepeatCallback.java:81)
    at org.springframework.batch.repeat.support.RepeatTemplate.getNextResult(RepeatTemplate.java:374)
    at org.springframework.batch.repeat.support.RepeatTemplate.executeInternal(RepeatTemplate.java:215)
    at org.springframework.batch.repeat.support.RepeatTemplate.iterate(RepeatTemplate.java:144)
    at org.springframework.batch.core.step.tasklet.TaskletStep.doExecute(TaskletStep.java:257)
    at org.springframework.batch.core.step.AbstractStep.execute(AbstractStep.java:200)
    at org.springframework.batch.core.job.SimpleStepHandler.handleStep(SimpleStepHandler.java:148)
    at org.springframework.batch.core.job.flow.JobFlowExecutor.executeStep(JobFlowExecutor.java:64)
    at org.springframework.batch.core.job.flow.support.state.StepState.handle(StepState.java:67)
    at org.springframework.batch.core.job.flow.support.SimpleFlow.resume(SimpleFlow.java:169)
    at org.springframework.batch.core.job.flow.support.SimpleFlow.start(SimpleFlow.java:144)
    at org.springframework.batch.core.job.flow.FlowJob.doExecute(FlowJob.java:134)
    at org.springframework.batch.core.job.AbstractJob.execute(AbstractJob.java:306)
    at org.springframework.batch.core.launch.support.SimpleJobLauncher$1.run(SimpleJobLauncher.java:135)
    at org.springframework.core.task.SyncTaskExecutor.execute(SyncTaskExecutor.java:50)
    at org.springframework.batch.core.launch.support.SimpleJobLauncher.run(SimpleJobLauncher.java:128)
    at com.santanderuk.carde.gassaudittransform.GassAuditTransformApplication.main(GassAuditTransformApplication.java:24)
Caused by: java.lang.reflect.InvocationTargetException: null
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:498)
    at org.springframework.batch.item.xml.StaxUtils.getResult(StaxUtils.java:116)
    at org.springframework.batch.item.xml.StaxEventItemWriter.createStaxResult(StaxEventItemWriter.java:532)
    at org.springframework.batch.item.xml.StaxEventItemWriter.write(StaxEventItemWriter.java:739)
    at com.santanderuk.carde.gassaudittransform.writer.IncomeExpenditureStaxWriter.write(IncomeExpenditureStaxWriter.java:67)
    at org.springframework.batch.core.step.item.SimpleChunkProcessor.writeItems(SimpleChunkProcessor.java:175)
    at org.springframework.batch.core.step.item.SimpleChunkProcessor.doWrite(SimpleChunkProcessor.java:151)
    at org.springframework.batch.core.step.item.SimpleChunkProcessor.write(SimpleChunkProcessor.java:274)
    at org.springframework.batch.core.step.item.SimpleChunkProcessor.process(SimpleChunkProcessor.java:199)
    at org.springframework.batch.core.step.item.ChunkOrientedTasklet.execute(ChunkOrientedTasklet.java:75)
    at org.springframework.batch.core.step.tasklet.TaskletStep$ChunkTransactionCallback.doInTransaction(TaskletStep.java:406)
    ... 20 common frames omitted
Caused by: java.lang.IllegalArgumentException: StAXResult(XMLEventWriter) with XMLEventWriter == null
    at javax.xml.transform.stax.StAXResult.<init>(StAXResult.java:90)
    at org.springframework.util.xml.StaxUtils.createStaxResult(StaxUtils.java:145)
    ... 34 common frames omitted
org.springframework.batch.core.step.tasklet.UncheckedTransactionException:java.lang.reflect.InvocationTargetException
位于org.springframework.batch.core.step.tasklet.TaskletStep$ChunkTransactionCallback.doInTransaction(TaskletStep.java:486)
位于org.springframework.batch.core.step.tasklet.TaskletStep$ChunkTransactionCallback.doInTransaction(TaskletStep.java:330)
位于org.springframework.transaction.support.TransactionTemplate.execute(TransactionTemplate.java:133)
位于org.springframework.batch.core.step.tasklet.TaskletStep$2.doInChunkContext(TaskletStep.java:272)
位于org.springframework.batch.core.scope.context.StepContextRepeatCallback.doInitation(StepContextRepeatCallback.java:81)
位于org.springframework.batch.repeat.support.RepeatTemplate.getNextResult(RepeatTemplate.java:374)
位于org.springframework.batch.repeat.support.RepeatTemplate.executeInternal(RepeatTemplate.java:215)
位于org.springframework.batch.repeat.support.RepeatTemplate.iterate(RepeatTemplate.java:144)
位于org.springframework.batch.core.step.tasklet.TaskletStep.doExecute(TaskletStep.java:257)
位于org.springframework.batch.core.step.AbstractStep.execute(AbstractStep.java:200)
位于org.springframework.batch.core.job.simplestphandler.handleStep(simplestphandler.java:148)
位于org.springframework.batch.core.job.flow.JobFlowExecutor.ExecuteTEP(JobFlowExecutor.java:64)
位于org.springframework.batch.core.job.flow.support.state.StepState.handle(StepState.java:67)
位于org.springframework.batch.core.job.flow.support.SimpleFlow.resume(SimpleFlow.java:169)
位于org.springframework.batch.core.job.flow.support.SimpleFlow.start(SimpleFlow.java:144)
位于org.springframework.batch.core.job.flow.FlowJob.doExecute(FlowJob.java:134)
位于org.springframework.batch.core.job.AbstractJob.execute(AbstractJob.java:306)
位于org.springframework.batch.core.launch.support.simplejoblancher$1.run(simplejoblancher.java:135)
位于org.springframework.core.task.SyncTaskExecutor.execute(SyncTaskExecutor.java:50)
位于org.springframework.batch.core.launch.support.simplejoblancher.run(simplejoblancher.java:128)
位于com.santanderuk.carde.gassaudittransform.GassAuditTransformApplication.main(GassAuditTransformApplication.java:24)
原因:java.lang.reflect.InvocationTargetException:null
在sun.reflect.NativeMethodAccessorImpl.invoke0(本机方法)处
位于sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
在sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)中
位于java.lang.reflect.Method.invoke(Method.java:498)
位于org.springframework.batch.item.xml.StaxUtils.getResult(StaxUtils.java:116)
位于org.springframework.batch.item.xml.StateVentitemWriter.createStaxResult(StateVentitemWriter.java:532)
位于org.springframework.batch.item.xml.statxeventitemwriter.write(statxeventitemwriter.java:739)
在com.santanderuk.carde.gassaudittransform.writer.IncomeExpenditureStaxWriter.write(IncomeExpenditureStaxWriter.java:67)
位于org.springframework.batch.core.step.item.SimpleChunkProcessor.writeItems(SimpleChunkProcessor.java:175)
位于org.springframework.batch.core.step.item.SimpleChunkProcessor.doWrite(SimpleChunkProcessor.java:151)
位于org.springframework.batch.core.step.item.SimpleChunkProcessor.write(SimpleChunkProcessor.java:274)
位于org.springframework.batch.core.step.item.SimpleChunkProcessor.process(SimpleChunkProcessor.java:199)
位于org.springframework.batch.core.step.item.ChunkOrientedTasklet.execute(ChunkOrientedTasklet.java:75)
位于org.springframework.batch.core.step.tasklet.TaskletStep$ChunkTransactionCallback.doInTransaction(TaskletStep.java:406)
... 省略20个公共框架
由以下原因引起:java.lang.IllegalArgumentException:XMLEventWriter==null的StAXResult(XMLEventWriter)
位于javax.xml.transform.stax.StAXResult.(StAXResult.java:90)
位于org.springframework.util.xml.StaxUtils.createStaxResult(StaxUtils.java:145)
... 省略了34个公共框架
添加了下面的代码,但它不工作

@Override
public void write(List<? extends Employee> items) throws Exception {
StaxEventItemWriter<AuditRecordsData> xmlFileWriter = new StaxEventItemWriter<>();
    xmlFileWriter.setResource(new FileSystemResource(filepath));
xmlFileWriter.setRootTagName("employee");
   Jaxb2Marshaller jaxb2Marshaller = new Jaxb2Marshaller();
  Result res = createStaxResult();
  jaxb2Marshaller.setClassesToBeBound(Employee.class);
    jaxb2Marshaller.marshal(data, res);
    xmlFileWriter.setMarshaller(jaxb2Marshaller);
    xmlFileWriter.write(items);
@覆盖

public void write(ListRemove
axb2Marshaller.marshall
,并与之一起使用
Result res=createStaxResult()
。它到底为什么在那里。@M.Deinum..所以我不必为writer设置封送拆收器??是的,但这两行没有意义。我也不明白为什么你似乎要将writer包含在writer中?那是什么写入方法?如果我删除xmlFileWriter.write(items);的过程完成,文件名为file:output/xml/Employee_20191107,但我在任何地方都找不到这个xml文件。你的代码很奇怪,你似乎把一个writer包装在一个writer中。省略write会使它成为一个noop,什么也不会发生。我不明白你为什么要包装它。