實現原理:服務器端安裝 Serv-U 服務器,環境配置好後通過Java程序訪問(讀、寫、刪除等操作)目錄。
Serv-U下載地址:http://download.csdn.net/detail/for_china2012/6574769
package com.ftp.util;
import java.io.IOException;
import java.io.InputStream;
import java.util.Properties;
import org.apache.commons.net.ftp.FTPClient;
import org.apache.commons.net.ftp.FTPReply;
/**
* FTP服務器工具類
*
* @author 碼農先生
* @version 1.0
* @date 2013-11-18
*/
public class FTPUtils {
private static FTPUtils ftpUtils;
private FTPClient ftpClient;
private String port; // 服務器端口
private String username; // 用戶登錄名
private String password; // 用戶登錄密碼
private InputStream is; // 文件下載輸入流
/**
* 私有構造方法
*/
private FTPUtils() {
initConfig();
if (null == ftpClient) {
ftpClient = new FTPClient();
}
}
/**
* 獲取FTPUtils對象實例
* @return
* FTPUtils對象實例
*/
public synchronized static FTPUtils getInstance () {
if (null == ftpUtils) {
ftpUtils = new FTPUtils();
}
return ftpUtils;
}
/**
* 初始化FTP服務器連接屬性
*/
public void initConfig () {
// 構造Properties對象
Properties properties = new Properties();
// 定義配置文件輸入流
InputStream is = null;
try {
// 獲取配置文件輸入流
is = FTPUtils.class.getResourceAsStream("/ftp.properties");
// 加載配置文件
properties.load(is);
// 讀取配置文件
port = (String) properties.get("port"); // 設置端口
username = (String) properties.get("username"); // 設置用戶名
password = (String) properties.get("password"); // 設置密碼
} catch (IOException e) {
e.printStackTrace();
} finally {
// 判斷輸入流是否爲空
if (null != is) {
try {
// 關閉輸入流
is.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
}
/**
* 連接(配置通用連接屬性)至服務器
*
* @param serverName
* 服務器名稱
* @param remotePath
* 當前訪問目錄
* @return
* <b>true</b>:連接成功
* <br/>
* <b>false</b>:連接失敗
*/
public boolean connectToTheServer (String serverName, String remotePath) {
// 定義返回值
boolean result = false;
try {
// 連接至服務器,端口默認爲21時,可直接通過URL連接
ftpClient.connect(serverName, Integer.parseInt(port));
// 登錄服務器
ftpClient.login(username, password);
// 判斷返回碼是否合法
if (!FTPReply.isPositiveCompletion(ftpClient.getReplyCode())) {
// 不合法時斷開連接
ftpClient.disconnect();
// 結束程序
return result;
}
// 設置文件操作目錄
result = ftpClient.changeWorkingDirectory(remotePath);
// 設置文件類型,二進制
result = ftpClient.setFileType(FTPClient.BINARY_FILE_TYPE);
// 設置緩衝區大小
ftpClient.setBufferSize(3072);
// 設置字符編碼
ftpClient.setControlEncoding("UTF-8");
} catch (IOException e) {
e.printStackTrace();
}
return result;
}
/**
* 上傳文件至FTP服務器
*
* @param serverName
* 服務器名稱
* @param storePath
* 上傳文件存儲路徑
* @param fileName
* 上傳文件存儲名稱
* @param is
* 上傳文件輸入流
* @return
* <b>true</b>:上傳成功
* <br/>
* <b>false</b>:上傳失敗
*/
public boolean storeFile (String serverName, String storePath, String fileName, InputStream is) {
boolean result = false;
try {
// 連接至服務器
result = connectToTheServer(serverName, storePath);
// 判斷服務器是否連接成功
if (result) {
// 上傳文件
result = ftpClient.storeFile(fileName, is);
}
// 關閉輸入流
is.close();
} catch (IOException e) {
e.printStackTrace();
} finally {
// 判斷輸入流是否存在
if (null != is) {
try {
// 關閉輸入流
is.close();
} catch (IOException e) {
e.printStackTrace();
}
}
// 登出服務器並斷開連接
ftpUtils.logout();
}
return result;
}
/**
* 下載FTP服務器文件至本地<br/>
* 操作完成後需調用logout方法與服務器斷開連接
*
* @param serverName
* 服務器名稱
* @param remotePath
* 下載文件存儲路徑
* @param fileName
* 下載文件存儲名稱
* @return
* <b>InputStream</b>:文件輸入流
*/
public InputStream retrieveFile (String serverName, String remotePath, String fileName) {
try {
boolean result = false;
// 連接至服務器
result = connectToTheServer(serverName, remotePath);
// 判斷服務器是否連接成功
if (result) {
// 獲取文件輸入流
is = ftpClient.retrieveFileStream(fileName);
}
} catch (IOException e) {
e.printStackTrace();
}
return is;
}
/**
* 刪除FTP服務器文件
*
* @param serverName
* 服務器名稱
* @param remotePath
* 當前訪問目錄
* @param fileName
* 文件存儲名稱
* @return
* <b>true</b>:刪除成功
* <br/>
* <b>false</b>:刪除失敗
*/
public boolean deleteFile (String serverName, String remotePath, String fileName) {
boolean result = false;
// 連接至服務器
result = connectToTheServer(serverName, remotePath);
// 判斷服務器是否連接成功
if (result) {
try {
// 刪除文件
result = ftpClient.deleteFile(fileName);
} catch (IOException e) {
e.printStackTrace();
} finally {
// 登出服務器並斷開連接
ftpUtils.logout();
}
}
return result;
}
/**
* 檢測FTP服務器文件是否存在
*
* @param serverName
* 服務器名稱
* @param remotePath
* 檢測文件存儲路徑
* @param fileName
* 檢測文件存儲名稱
* @return
* <b>true</b>:文件存在
* <br/>
* <b>false</b>:文件不存在
*/
public boolean checkFile (String serverName, String remotePath, String fileName) {
boolean result = false;
try {
// 連接至服務器
result = connectToTheServer(serverName, remotePath);
// 判斷服務器是否連接成功
if (result) {
// 默認文件不存在
result = false;
// 獲取文件操作目錄下所有文件名稱
String[] remoteNames = ftpClient.listNames();
// 循環比對文件名稱,判斷是否含有當前要下載的文件名
for (String remoteName: remoteNames) {
if (fileName.equals(remoteName)) {
result = true;
}
}
}
} catch (IOException e) {
e.printStackTrace();
} finally {
// 登出服務器並斷開連接
ftpUtils.logout();
}
return result;
}
/**
* 登出服務器並斷開連接
*
* @param ftp
* FTPClient對象實例
* @return
* <b>true</b>:操作成功
* <br/>
* <b>false</b>:操作失敗
*/
public boolean logout () {
boolean result = false;
if (null != is) {
try {
// 關閉輸入流
is.close();
} catch (IOException e) {
e.printStackTrace();
}
}
if (null != ftpClient) {
try {
// 登出服務器
result = ftpClient.logout();
} catch (IOException e) {
e.printStackTrace();
} finally {
// 判斷連接是否存在
if (ftpClient.isConnected()) {
try {
// 斷開連接
ftpClient.disconnect();
} catch (IOException e) {
e.printStackTrace();
}
}
}
}
return result;
}
}
Demo下載地址:http://download.csdn.net/detail/for_china2012/6575341
【參考文章】
http://lavasoft.blog.51cto.com/62575/93883/
http://blog.csdn.net/hbcui1984/article/details/2720204
http://commons.apache.org/proper/commons-net/apidocs/org/apache/commons/net/ftp/FTPClient.html