ftp 根据特定正则匹配文件名 下载到本地 并且上传文件到ftp java *** 最爱那水货
/**
* 建立FTP链接,FTP服务器地址、端口、登陆用户信息都在配置里配置即可。
* @throws IOException
*/
public boolean connectFtp(String ftpAddress, String ftpPort, String frpUserName, String frpPassword) throws IOException{
log.info("*****连接FTP服务器...*****");
try{
ftpClient.connect(ftpAddress, Integer.valueOf(ftpPort).intValue());
ftpClient.setControlEncoding("GB2312");
int reply = ftpClient.getReplyCode();
if(FTPReply.isPositiveCompletion(reply)){
if(ftpClient.login(frpUserName,frpPassword)){
log.info("*****连接FTP服务器成功!*****");
return true;
}
}else{
log.error("*****连接失败!响应代码为【"+ reply+"】*****");
}
disconnect();
}catch (Exception e) {
log.error("*****连接失败:" + e.getMessage());
}
return false;
} /**
* 设置FTP客户端 被动模式、数据模式为二进制、字符编码GBK
*/
public void setConnectType(){
try {
ftpClient.enterLocalPassiveMode();
ftpClient.setDefaultTimeout(1000 * 120);//120秒
ftpClient.setFileType(FTP.BINARY_FILE_TYPE);
ftpClient.setControlEncoding("GB2312");
} catch (IOException e) {
e.printStackTrace();
}
} /**
* 断开与远程服务器的连接
* @throws IOException
*/
public void disconnect() {
if(ftpClient.isConnected()){
try {
ftpClient.disconnect();
} catch (IOException e) {
e.printStackTrace();
}
}
} /**
* 过滤不符合的文件并批量下载
* @param remoteFileReg 文件前缀的正则表达式
* @param localPath 本地路径 .property 文件配置
* @param remote_down_path ftp文件路径
* @return List 下载到本地的文件路径 集合
* @throws IOException
*/
@SuppressWarnings("unchecked")
public List downloads(String remoteFileReg,String localPath,String remote_down_path) throws IOException{
List<String> fileNames = new ArrayList<String>();
log.info("*****转移到服务器目录:" + remote_down_path);
setConnectType();
boolean changeFlag = ftpClient.changeWorkingDirectory(remote_down_path);
FTPFile[] files = ftpClient.listFiles();
//String[] names = ftpClient.listNames();
log.info("*****改变目录是否成功:" + changeFlag);
log.info("*****服务器上report目录下所有校验报告的文件数为:【" +files.length + "】" );
if(files.length == 0){
log.info("*****未在服务器上找到文件!*****");
return null;
}else{//目录下有文件
//把 bak文件的前缀找出来 ,区分读取和未读取的xls 和 xlsx ,只下载 未读取的文件
List<String> bakList = new ArrayList<String>();
List<String> list = new ArrayList<String>(); for (int i = 0; i < files.length; i++) {
FTPFile ftpFile = files[i];
String fileName = ftpFile.getName(); if(!fileName.endsWith(".bak") && ftpFile == null){
log.info("******* "+ fileName + "文件无数据!");
continue;
}
//匹配指定的文件前缀 和后缀 为 .bak 格式的文件
//bak 文件是文件读取完毕后生成的标记文件
Pattern bak = Pattern.compile("^"+remoteFileReg+"\\.bak");
Matcher m = bak.matcher(fileName);
if (m.find()) {
//取.bak文件的 前缀
//System.out.println(fileName);
//System.out.println(fileName.split("\\.")[0]);
bakList.add(fileName.split("\\.")[0]);
continue;
} //匹配指定的文件前缀 和后缀 为 .xls .xlsx 格式的文件
//TODO 以后遇到其他的格式文件 需要把后缀抽出来作为参数传入
Pattern xls = Pattern.compile("^"+remoteFileReg+"\\.xls$"+"|"+"^"+remoteFileReg+"\\.xlsx$"+"|"+"^"+remoteFileReg+"\\.csv$");
Matcher mm = xls.matcher(fileName);
if(mm.find()){
list.add(fileName);
continue;
}
} Iterator<String> it = list.iterator();
while (it.hasNext()) {
String xls = it.next();
for (int i = 0; i < bakList.size(); i++) {
String bak = bakList.get(i);
//bak文件存在 , 去掉此文件
if (xls.indexOf(bak) !=-1) {
it.remove();
bakList.remove(i);
}
}
} for (String fFile : list) {
//下载未读取的文件
File downFile = new File(localPath + fFile);
//System.out.println(localPath);
File downPath = new File(localPath);
if(!downPath.exists()){
downPath.mkdirs();
}
String fileDir = remote_down_path + fFile;
OutputStream os = new FileOutputStream(downFile);
ftpClient.retrieveFile(new String(fileDir.getBytes("GB2312"),"ISO-8859-1"), os);
log.info("*****文件已下载到:" + downFile.getAbsolutePath() + "******");
fileNames.add(downFile.getAbsolutePath());
os.close();
}
log.info("**** 此次共下载了【"+list.size()+"】个文件! *****");
}
return fileNames;
} /**
* 上传标志文件
* @param remoteFile
* @param localFile
* @return
*/
public boolean upload(String localFileName,String remoteFileName){ boolean b = false;
try {
File file = new File(localFileName);
FileInputStream input = new FileInputStream(file);
b = ftpClient.changeWorkingDirectory(remoteFileName);
log.info("*****改变目录是否成功:" + b);
String remoteFile = remoteFileName + file.getName();
b = ftpClient.storeFile(new String(remoteFile.getBytes("GB2312"),"ISO-8859-1"), input);
if(b){
log.info(" ****** 标志文件"+localFileName+"上传成功!");
}
input.close();
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
return b;
}
ftp 根据特定正则匹配文件名 下载到本地 并且上传文件到ftp java *** 最爱那水货的更多相关文章
- .Net 上传文件到ftp服务器和下载文件
突然发现又很久没有写博客了,想起哎呦,还是写一篇博客记录一下吧,虽然自己还是那个渣渣猿. 最近在做上传文件的功能,上传到ftp文件服务器有利于管理上传文件. 前面的博客有写到layui如何上传文件,然 ...
- java 上传文件到 ftp 服务器
1. java 上传文件到 ftp 服务器 package com.taotao.common.utils; import java.io.File; import java.io.FileInpu ...
- java 上传文件到FTP(centos中的ftp服务)
ftp服务器系统:centos7 提供ftp的服务:vsftpd pom.xml 依赖 <dependency> <groupId>commons-net</groupI ...
- JAVA上传文件到FTP上
添加maven <!-- https://mvnrepository.com/artifact/commons-net/commons-net --> <dependency> ...
- Linux上F上传文件到FTP服务器
Linux上上传跟Windows上上传不一样,在Windows上测试没问题,但是放到Linux服务器上跑,上传的文件中文显示乱码.解决方案: FtpUtil.java红色标记处 package cn. ...
- Android上传文件之FTP
android客户端实现FTP文件(包括图片)上传应该没什么难度.写下来就了为了记录一下,望能帮到新手. 需要用到 commons-net-3.0.1.jar,后面附上jar包. 直接上代码: /** ...
- Android 上传文件到 FTP 服务器
实现背景 近期接触到一个需求,就是将文件从Android系统上传到FTP服务器,虽然之前接触过FTP服务器,了解基本的使用流程,但是将此流程从使用习惯转化为代码实现还是有一定难度的.但是基本的流程还是 ...
- asp.net 服务器 上传文件到 FTP服务器
private string ftpServerIP = "服务器ip";//服务器ip private string ftpUserID = "ftp的用户名" ...
- 【python】用python脚本Paramiko实现远程执行命令、下载、推送/上传文件功能
Paramiko: paramiko模块,基于SSH用于连接远程服务器并执行相关操作. SSHClient: 用于连接远程服务器并执行基本命令 SFTPClient: 用于连接远程服务器并执行上传下载 ...
随机推荐
- ASP.NET MVC 路由(二)
ASP.NET MVC路由(二) 前言 在上一篇中,提及了Route.RouteCollection对象的一些信息,以及它们的结构所对应的关系.按照处理流程走下来还有遗留的疑问没有解决这个篇幅就来讲 ...
- MySQL数据库数据存放位置修改
MySQL数据库数据存放位置修改 MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,目前属于 Oracle 旗下产品.MySQL 最流行的关系型数据库管理系统,在 WEB 应用方 ...
- Eclipse启动参数
from 网络 eclipse 启动参数 -clean2013-- : eclipse 启动参数介绍(如添加插件时,如果不显示,则使用eclipse -clean启动) 其实,Eclipse是一个可以 ...
- xamarin uwp数字证书公钥私钥
对于数字证书存储导入到电脑中,采用如下方式: /// <summary> /// 导入证书 /// </summary> /// <param name="ra ...
- java继承、抽象和接口
package zdbExtends;public class Grandparent { public Grandparent(){ System.out ...
- 【原创】.NET平台机器学习组件-Infer.NET连载(一)介绍
Infer.NET机器学习翻译系列文章将进行连载,感兴趣的朋友请收藏或关注 本博客所有文章分类的总目录:http://www.cnblogs.com/asxinyu/p/428 ...
- Util应用程序框架公共操作类(九):Lambda表达式扩展
上一篇对Lambda表达式公共操作类进行了一些增强,本篇使用扩展方法对Lambda表达式进行扩展. 修改Util项目的Extensions.Expression.cs文件,代码如下. using Sy ...
- 使用Spire.Doc来转换文本
使用Spire.Doc来转换文本 前段时间,我为不熟悉这个产品的读者们写了一篇关于我对 Spire.Doc的初识印象.Spire.Doc是一个专业的Word .NET库,它是专门为开发人员设计的用来快 ...
- SQL Tuning 基础概述09 - SQL Access Advisor
Oracle官方文档对SQL Access Advisor的描述如下: SQL Access Advisor, which is a tuning tool that provides advice ...
- ASP.NET通过递归添加树(Treeview)
先来看看效果,基本上就是这样的. 所谓树,无非就是2点,第一个:根节点,第二:叶子节点,其中叶子节点中还可能有叶子节点,但是根节点始终只有一个. 下面贴上 各部分的代码 1.PAGE_LOAD载入事件 ...