评论

收藏

[Java] Spring boot项目集成Camel FTP的方法示例

编程语言 编程语言 发布于:2021-10-08 13:11 | 阅读数:510 | 评论:0

这篇文章主要介绍了Spring boot项目集成Camel FTP的方法示例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
1、spring 中集成camel-ftp
近期项目中涉及到定期获取读取并解析ftp服务器上的文件,自己实现ftp-client的有些复杂,因此考虑集成camel-ftp的方式来解决ftp文件的下载问题。自己则专注于文件的解析工作.
demo: https://github.com/luckydl/ftp-camel-demo
1.1、pom引用
<dependency>
  <groupid>org.apache.camel</groupid>
  <artifactid>camel-spring-boot-starter</artifactid>
  <version>2.22.1</version>
</dependency>
<dependency>
  <groupid>org.apache.camel</groupid>
  <artifactid>camel-ftp</artifactid>
  <version>2.22.1</version>
</dependency>
注意:在选择版本的时候,如果springboot版本是1.5.10.release的话,那么camel的版本最高只能使用2.21.2,使用2.22版本将会报错。经测试的配套关系如下:
srpingbootcamel1.5<=2.21.22.0>=2.22.x其他情况都会出现错误.
1.2、springboot application.yml配置
ftp:
 addr: 172.18.18.19:21  # ftp地址、端口
 name: ftpuser
 password: ftp2018
 options: password=${ftp.password}&readlock=rename&delay=10s&binary=true&filter=#zipfilefilter&noop=true&recursive=true
 url: ftp://${ftp.name}@${ftp.addr}/?${ftp.options}
 # 本地下载目录
 local-dir: /var/data
 
# 后台运行进程
camel:
 springboot:
  main-run-controller: true
 
management:
 endpoint:
  camelroutes:
   enabled: true
   read-only: true
配置说明:

  • delay:每次读取时间间隔
  • filter: 指定文件过滤器
  • noop:读取后对源文件不做任何处理
  • recursive:递归扫描子目录,需要在过滤器中允许扫描子目录
  • readlock:对正在写入的文件的处理机制
更多参数配置见官方手册
1.3、配置路由
要配置从远端服务器下载文件到本地,格式如下,from内部为我们在上面配置的url,to为本地文件路径。
@component
public class downloadroute extends routebuilder {
  /** logger */
  private static final logger logger = loggerfactory.getlogger(downloadroute.class);
 
  @value("${ftp.server.info}")
  private string sftpserver;
  
  @value("${ftp.local.dir}")
  private string downloadlocation;
  
  @autowired
  private dataprocessor dataprocessor;
 
  @override
  public void configure() throws exception{
  from(sftpserver)
    .to(downloadlocation)
    .process(dataprocessor)
    .log(logginglevel.info, logger, "download file ${file:name} complete.");
  }
}
说明:
若将from配置为本地地址,to配置为远端地址,则可以实现向远端服务器上传文件
process是数据处理器,如果仅仅是下载文件到本地,那么就不需要该配置。
也可以配置多条路由也处理不同的业务:
@override
  public void configure() throws exception{
  // route1
  from(sftpserver)
    .to(downloadlocation)
    .process(dataprocessor)
    .log(logginglevel.info, logger, "download file ${file:name} complete.");
  // route2
  from(xxx).to(xxxx);
  
  // route3
  from(xxxx).to(xxx).process(xxx);
  }
1.4、配置文件过滤
如果ftp服务器上有很多文件,但是我们需要的只是其中的一种,全部下载下来,有业务层来实现过滤肯定不合适,我们可以使用camel-ftp的文件过滤器,通过url中的filter来指定,如“filter=#zipfilefilter”,
用户需要实现genericfilefilter接口的accept方法。
例如我们只需要下载后缀名为.zip的压缩包到本地,过滤器的编写方法如下,因为我要递归扫描子目录,因此类型为目录的文件也需要允许通过。
/**
 * camel ftp zip文件过滤器
 */
@component
public class zipfilefilter implements genericfilefilter {
  
  @override
  public boolean accept(genericfile file) {
  return file.getfilename().endswith(".zip") || file.isdirectory();
  }
}
1.5、文件处理器
文件处理器就是我们对下载到本地的文件进行处理的操作,比如我们可能需要对下载的文件重新规划目录;或者解析文件并进行入库操作等。这就需要通过实现processer的process方法。
本文中的demo就是通过processor来解析zip包中的文件内容:
@component
public class dataprocessor implements processor {
 
  /** logger */
  private static final logger logger = loggerfactory.getlogger(dataprocessor.class);
 
 
  @value("${ftp.local-dir}")
  private string filedir;
 
  @override
  public void process(exchange exchange) throws exception {
  genericfilemessage<randomaccessfile> infilemessage = (genericfilemessage<randomaccessfile>) exchange.getin();
  string filename = infilemessage.getgenericfile().getfilename();
  string file_path = filedir + '/' + filename;
  readzip(file_path);
  }
  
  ...  // 省略数据处理方法
}
2、参考资料
关于camel ftp的各个参数配置,参见官方手册:http://camel.apache.org/ftp2.html
此处需要注意的是,camel ftp手册里面只写了ftp独有的一些配置项,camel-ftp组件继承自camel-file,手册里面有说明,就一句话,不注意就可能忽略了,笔者就是没注意,被递归扫描子目录的问题折腾了2天(阅读要细心o(╥﹏╥)o)。。。因此有一些参数配置项可能在camel-ftp手册里面找不到,请移步至:http://camel.apache.org/file2.html
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持CodeAE代码之家
原文链接:http://www.cnblogs.com/donlin-zhang/p/9755403.html

关注下面的标签,发现更多相似文章