我有一个流,它通过正则表达式过滤SFTP文件。我使用属性文件使用SFTP连接器的许多设置。我无法使用的一个设置是文件中的regex模式属性:filename regex filter元素。
这是我的SFTP连接器。
<!-- Get the HiTrack files via SFTP -->
<sftp:inbound-endpoint name="HiTrackInboundSFTPEndpoint"
doc:name="Get SFTP"
user="${sftp.origin.user}"
password="${sftp.origin.password}"
port="${sftp.origin.port}"
path="${sftp.origin.path}"
host="${sftp.origin.host}"
pollingFrequency="${sftp.origin.pollingFrequency}"
fileAge="${sftp.origin.fileAge}"
responseTimeout="${sftp.origin.responseTimeout}"
tempDir="${sftp.origin.tempDir}"
archiveDir="${local.archive.directory}"
archiveTempReceivingDir="${local.archive.receiveDir}"
archiveTempSendingDir="${local.archive.sendingDir}"
useTempFileTimestampSuffix="true">
<!-- Use RegEx filter to filter only HiTrack files with within the proper date format YYYYMMdd
Range of dates are from 19000101 to 20991231 -->
<file:filename-regex-filter
pattern="hitrack_(19|20)dd(0[1-9]|1[012])(0[1-9]|[12][0-9]|3[01])_(.*).xml"
caseSensitive="false" />
</sftp:inbound-endpoint>
对于模式属性,我尝试了以下两种方法,但都没有成功。
pattern="#[${regex.filter}]"
和
pattern="${regex.filter}"
我的属性文件包含所有列出的值,除了regex过滤器模式外,其他文件都非常有效。
regex.filter的属性文件如下:
regex.filter=hitrack_(19|20)dd(0[1-9]|1[012])(0[1-9]|[12][0-9]|3[01])_(.*).xml
我没有任何错误;它只是在使用属性表达式时不传递任何有效的文件。只有当显式使用regex表达式时,它才起作用。
我将感谢对这个问题的任何建议或更好的解决方案。
如果您正在读取spring属性,则需要转义某些字符,如\。所以试试:
regex.filter=hitrack_(19|20)\\d\\d(0[1-9]|1[012][0-9]|3[01])_(.*).xml