设为首页 收藏本站
查看: 1111|回复: 0

[经验分享] Java上传下载FTP服务器代码

[复制链接]

尚未签到

发表于 2016-6-9 10:41:00 | 显示全部楼层 |阅读模式
Java上传下载FTP服务器代码

import java.io.*;
import java.util.*;
import java.sql.*;
import java.net.Socket;
import java.net.ServerSocket;
import java.net.InetAddress;
import sun.net.ftp.*;
import sun.net.TelnetInputStream;
import sun.net.TelnetOutputStream;

/*
* 用于连接到FTP服务器上
* @return String 若失败则返回失败信息,成功返回空字符串
*/
private String connectToFtpServer(){
if ((this.ftpserver==null)||(this.ftpserver.equals(""))) return "FTP服务器名设置不正确!";

try{
fc.openServer(this.ftpserver);
fc.login(this.ftpuser,this.ftppwd);
fc.ascii();
}catch(FtpLoginException e){
return "没有与FTP服务器连接的权限,或用户名密码设置不正确!";
}catch(IOException e){
return "与FTP服务器连接失败!";
}catch(SecurityException e){
return "没有权限与FTP服务器连接";
}
return "";
}
/*
* 用于关闭与FTP服务器的连接
*/
private void closeFtpConnect(){
if (fc.serverIsOpen()){
try{
fc.closeServer();
}catch(Exception e){
}finally{
fc = null;
}
}
}
public String downloadFile(String fileName){
//只下载文本文件或XML文件
if (!this.isTextFile(fileName)) return fileName + "不是XML文件或文本文件";
String retMessage = "";

if (!fc.serverIsOpen()){
retMessage = this.connectToFtpServer();
if (!retMessage.equals("")) return "下载文件:" + fileName + "时无法和FTP服务器连接";
}

//if (conn == null) return "下载文件:" + fileName + "时无法连接到数据库";

String chkSql = "select 1 from t_trans_log where file_name = '" + fileName + "'";
if (sqlbean.checkQueryRowCount(chkSql) > 0) return retMessage;

if (this.dldir==null) this.dldir = "";

try{


TelnetInputStream is = fc.get(this.dldir + "/" + fileName);
BufferedReader br = new BufferedReader(new InputStreamReader(is));

//读取文件内容到stringbuffer
StringBuffer sb = new StringBuffer();
int length;

char buffer[] = new char[1];
while((length = br.read(buffer,0,1)) != -1) sb.append(buffer);

//构造sql语句插入记录
//String ls_lsh = get_lsh(12);
String ls_lsh = ah.getAutoID("xf_lsh",12);

String ls_sql = "insert into t_trans_log(tran_id,tran_flag,file_name,file_content)values('"
ls_sql += ls_lsh + "','0','" + fileName + "','" + sb.toString() + "')";

conn = connmanager.getConnection();
conn.setAutoCommit(false);

sqlbean.executeUpdate(conn,ls_sql);


//将stringbuffer写入文件中
byte buf[] = sb.toString().getBytes();

OutputStream f1 = new FileOutputStream(this.bdldir + "/" + fileName);
f1.write(buf);
f1.close();

is.close();
br.close();

//删除文件
this.deleteFile(this.dldir + "/" + fileName);

conn.commit();
conn.setAutoCommit(true);
connmanager.close(conn);
}catch(SQLException e){
retMessage = "下载文件:" + fileName + "时发生数据库错误:" + e.getMessage();
}catch(IOException e){
retMessage = "下载文件:" + fileName + "时发生文件读写错误:" + e.getMessage();
}
return retMessage;
}


//下载指定目录下的所有文件
public String downloadFiles(String dirName){
String retMessage = "";

if ((dirName == null)||(dirName.equals(""))) dirName = this.dldir;
String[] sa = this.list();
for (int i = 0;i < sa.length;i++){
retMessage = this.downloadFile(sa);
if (!retMessage.equals("")) return retMessage;
}

return retMessage;
}

//下载FTP服务器上的所有文件
public String downloadFiles(){
return downloadFiles(this.dldir);
}



public String uploadFile(String fileName){
String retMessage = "";

if (!fc.serverIsOpen()){
retMessage = this.connectToFtpServer();
if (!retMessage.equals("")) return "上传文件:" + fileName + "时无法和FTP服务器连接";
}
//if (conn == null) return "上传文件:" + fileName + "时无法连接到数据库";

//String chkSql = "select 1 from t_trans_log where file_name = '" + fileName + "'";
//if (Utils.checkQueryRowCount(conn,chkSql) > 0) return retMessage;

try{
if (this.uldir==null) this.uldir = "";
if (this.buldir==null) this.buldir = "";

TelnetOutputStream os = fc.put(this.uldir + "/" + fileName);
BufferedWriter wr = new BufferedWriter(new OutputStreamWriter(os));

StringBuffer sb = new StringBuffer();
InputStream f1 = new FileInputStream(this.buldir + "/" + fileName);
int size = f1.available();
byte b[] = new byte[size];
while(f1.read(b)!= -1) sb.append(new String(b,0,b.length));

//构造sql语句插入记录
//String ls_sql = "insert into t_trans_log(tran_id,file_name,file_content)values('" + get_lsh(12) + "','" + fileName + "','" + sb.toString() + "')";
String ls_sql = "insert into t_trans_log(tran_id,file_name,file_content)values('" + ah.getAutoID("xf_lsh",12) + "','" + fileName + "','" + sb.toString() + "')";
conn = connmanager.getConnection();
conn.setAutoCommit(false);

sqlbean.executeUpdate(conn,ls_sql);

//写入文件
wr.write(sb.toString());

f1.close();
wr.close();
os.close();

//删除本地文件

File ls_file = new File(this.buldir + "/" + fileName);

ls_file.delete();

conn.commit();
conn.setAutoCommit(true);
connmanager.close(conn);
}catch(SQLException e){
retMessage = "上传文件:" + fileName + "时发生数据库错误:" + e.getMessage();
}catch(IOException e){
retMessage = "上传文件:" + fileName + "时发生文件读写错误:" + e.getMessage();
}

return retMessage;
}

/**
* 功能:获取指定目录文件列表并上传每一个文件
*/
public String uploadFiles(){
String retMessage = "";

if (this.buldir == null) this.buldir = "";

File ls_file = new File(this.buldir);
File[] entries = ls_file.listFiles();

for(int i=0; i this.uploadFile(entries.getName());
if (!retMessage.equals("")) return retMessage;
}
return retMessage;
}

public String deleteFile(String fileName){
String retMessage = "";
try{
Socket socket = new Socket(this.ftpserver,this.ftpport);
BufferedReader reader = new BufferedReader(new InputStreamReader(socket.getInputStream()));
if (!reader.readLine().startsWith("220")) return "DELE 无法连接到指定的FTP服务器";
Writer writer = new OutputStreamWriter(socket.getOutputStream());
writer.write("USER " + this.ftpuser + "rn");
writer.flush();
if (!reader.readLine().startsWith("331")) return "DELE 指定的登录FTP用户名无效";
writer.write("PASS " + this.ftppwd + "rn");
writer.flush();
if (!reader.readLine().startsWith("230")) return "DELE FTP用户的登录口令错误";
writer.write("DELE " + fileName + "rn");
writer.flush();
if (!reader.readLine().startsWith("250")) return "无法删除指定文件" + fileName;
writer.close();
reader.close();
socket.close();
}catch(Exception e){
retMessage = "删除文件" + fileName + "时发生错误" + e.getMessage();
}
return retMessage;
}

/**
* 功能:获取指定目录下以分号分隔的文件名列表
*/
public String getDownloadFileList(String dirName){
StringBuffer sb = new StringBuffer();
String[] sa = list(dirName);
int saLength = sa.length;

for (int i = 0; i < saLength; i++) sb.append(sa).append(";");

return sb.toString();
}

/**
* 功能:获取默认下载目录下以分号分隔的文件名列表
*/
public String getDownloadFileList(){
return getDownloadFileList(this.dldir);
}

/**
* 功能:以数组的形式返回服务器上指定目录下的文件名列表
*/
public String[] list(String dirName){
String[] fileNameList = new String[0];
Vector lines = new Vector();
String line = null;

if (fc.serverIsOpen()){
try{
fc.cd(dirName.equals("")?this.dldir:dirName);
TelnetInputStream ins = fc.list();
fc.cd("/");

LineNumberReader in = new LineNumberReader(new InputStreamReader(ins));
line = in.readLine();
while((line != null)&&!(line.trim().equals(""))&&!(line.trim().equals("/n"))){
lines.add(line.substring(line.lastIndexOf(" ") + 1,line.length()));
line = in.readLine();
}

in.close();
ins.close();
}catch(Exception e){
}

if (!lines.isEmpty()) fileNameList = (String[])lines.toArray(fileNameList);
}

return fileNameList;
}

/**
* 功能:以数组的形式返回服务器上默认下载目录下的文件名列表
*/
public String[] list(){
return this.list(this.dldir);
}

public String getDlDir(){return this.dldir;}

/**
* 功能:用于判断文件是否是XML或TXT文件
*/
private boolean isTextFile(String fileName){
return (fileName.toLowerCase().endsWith(".xml")||fileName.toLowerCase().endsWith(".txt"));
}
}

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-228152-1-1.html 上篇帖子: FileZilla FTP server 架设和FileZilla FTP 客户端使用说明 下篇帖子: ftp文件上传下载工具类及用法
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表