标签:
有时候经常用到FTP的上传下载,本身代码相对比较简单,但有时需要考虑到文件上传下载进行验证。大体思路是上传时将FTP日志重定向到本地文件,再根据FTP返回码进行检查,这样有个缺点就是不能检验文件上传的完整性;下载时利用ls,ll命令查看是否存在。
uploadFile() {
ftp -i -v -n <<! >/tmp/ftp.log
open $FTP_IP $FTP_PORT
user $USER_ID $PASSWORD
prompt
cd $FTP_PATH
lcd $LAB_CFG_PATH
put $LAB_CFG_FILE
close
bye
!
local res=`grep "Transfer complete" /tmp/ftp.log`
if [ -z "$res" ];then
echo "Finishing upload $LAB_CFG_FILE failure ...."
return 1
fi
echo "Finishing upload $LAB_CFG_FILE success ...."
return 0
}
downloadFile() {
ftp -i -n <<!
open $FTP_IP $FTP_PORT
user $USER_ID $PASSWORD
binary
prompt
cd $FTP_PATH
lcd $LAB_CFG_PATH
prompt
get $LAB_CFG_FILE
close
bye
!
ls $LAB_CFG_PATH$LAB_CFG_FILE
if [ $? != 0 ]; then
{
echo "download $LAB_CFG_FILE failure."
return 1
}
fi
echo "download $LAB_CFG_FILE success."
return 0
}
其中-i,-v,-n等参数可以能过man ftp命令进行详细查看。
110 重新启动标记应答。
120 服务在多久时间内ready。
125 数据链路埠开启,准备传送。
150 文件状态正常,开启数据连接端口。
200 命令执行成功。
202 命令执行失败。
211 系统状态或是系统求助响应。
212 目录的状态。
213 文件的状态。
214 求助的讯息。
215 名称系统类型。
220 新的联机服务ready。
221 服务的控制连接埠关闭,可以注销。
225 数据连结开启,但无传输动作。
226 关闭数据连接端口,请求的文件操作成功。
227 进入passive mode。
230 使用者登入。
250 请求的文件操作完成。
257 显示目前的路径名称。
331 用户名称正确,需要密码。
332 登入时需要账号信息。
350 请求的操作需要进一部的命令。
421 无法提供服务,关闭控制连结。
425 无法开启数据链路。
426 关闭联机,终止传输。
450 请求的操作未执行。
451 命令终止:有本地的错误。
452 未执行命令:磁盘空间不足。
500 格式错误,无法识别命令。
501 参数语法错误。
502 命令执行失败。
503 命令顺序错误。
504 命令所接的参数不正确。
530 未登入。
532 储存文件需要账户登入。
550 未执行请求的操作。
551 请求的命令终止,类型未知。
552 请求的文件终止,储存位溢出。
553 未执行请求的的命令,名称不正确
标签:
原文地址:http://blog.csdn.net/mao_2110901055/article/details/51355089