热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Shell脚本实现FTP/SFTP上传下载文件

Linux下使用Shell脚本实现FTP自动上传和下载文件登录FTP实现下载文件功能FTP服务器:10.11.10.11FTP路径:Down本地路径&#

Linux下使用Shell脚本实现FTP自动上传和下载文件
登录FTP实现下载文件功能
FTP服务器:10.11.10.11 
FTP路径:Down 
本地路径: ./ 
将文件从FTP下载到本地的脚本如下:

批量下载脚本代码:

#从FTP上批量下载文件到本地
#!/bin/sh
ftp -v -n 10.11.10.11<user ftpuser ftppwd
binary
cd Down
lcd ./
prompt
mget *
bye
EOF
echo "download from ftp successfully"

下载单个文件脚本代码:

#从FTP上下载单文件到本地
#!/bin/sh
ftp -v -n 10.11.10.11<user ftpuser ftppwd
binary
cd Down
lcd ./
prompt
#get down.txt
get down.txt note.txt
bye
EOF
echo "download from ftp successfully"

登录FTP实现上传文件功能
FTP服务器&#xff1a;10.11.10.11 
FTP路径&#xff1a;Up 
本地路径&#xff1a; ./ 
将文件从本地传到FTP的脚本如下&#xff1a;

批量上传脚本代码:

#从本地向FTP批量上传文档
#!/bin/sh
ftp -v -n 10.11.10.11<user ftpuser ftppwd
binary
hash
cd Up
lcd ./
prompt
mput *
bye
#here document
EOF
echo "commit to ftp successfully"

上传单个文件脚本代码:

#从本地向FTP上传单个文档
#!/bin/sh
PUTFILE &#61; up.txt
ftp -v -n 10.11.10.11<user ftpuser ftppwd
binary
cd Up
lcd ./
prompt
put $PUTFILE
bye
#here document
EOF
echo "commit to ftp successfully"

命令解释
登录FTP
ftp -i -n 10.11.10.11 <
1
<<是使用即时文件重定向输入 
EOF是即时文件的标志它必须成对出现&#xff0c;以标识即时文件的开始和结尾。 
ftp常见的几个标志有&#xff1a;

-d&#xff1a;使用调试模式&#xff0c;但必须编辑 /etc/syslog.conf 文件并添加以下中的一项&#xff1a;user.info FileName 或 user.debug FileName。 
-g&#xff1a;禁用文件名中的元字符拓展&#xff0c;即取消全局文件名。 
-i &#xff1a;关闭多文件传输中的交互式提示。 
-n&#xff1a;防止在起始连接中的自动登录。否则&#xff0c; ftp 命令会搜索 $HOME/.netrc 登录项&#xff0c;该登录项描述了远程主机的登录和初始化过程。 
-v&#xff1a;显示远程服务器的全部响应&#xff0c;并提供数据传输的统计信息&#xff0c;即在程序运行时显示详细的处理信息。

输入FTP用户名和密码
user ftpuser ftppwd
1
ftpuser&#xff1a;登录FTP时的用户名 
ftppwd&#xff1a;登录FTP时的密码

通过binary命令传输文件
binary
1
FTP文件传输类型有&#xff1a; ascii、binary、ebcdic、image、local M 和 tenex。

– ascii&#xff1a;将文件传输类型设置为网络 ASCII。此类型为缺省值&#xff0c;即默认使用ascii方式进行传输。 
– binary&#xff1a;将文件传输类型设置为二进制映像。需要使用binary方式传输的文件类型有ISO文件、可执行文件、压缩文件、图片等。此类型可能比 ASCII 传送更有效。 
– ebcdic&#xff1a;将文件传输类型设为 EBCDIC。 
– image&#xff1a;将文件传输类型设置为二进制映像。此类型可能比 ASCII 传送更有效。 
– local M&#xff1a;将文件传输类型设置为本地。M 参数定义每计算机字位的十进制数。此参数没有缺省值。 
– tenex&#xff1a;将文件传输类型设为 TENEX 机器需要的类型。

切换散列符号 &#xff08;#&#xff09; 打印
hash


当用get或put命令传送一个数据块时&#xff0c;让FTP显示一个#&#xff0c;这是看得见的确定数据在传输的信号&#xff0c;在用户不确信网络是否工作时有用。当传输很大的文件时&#xff0c;如果FTP已显示这种信息&#xff0c;表示传输正在进行。hash命令是一个布尔变量式的命令&#xff0c;用hash命令打开显示#开关&#xff0c;再用hash命令关闭显示。

切换目录
分别在本地和FTP上进入对应文件夹下&#xff1a; 
到FTP上对应路径&#xff08;这里表示进入Dwon文件夹下&#xff09;&#xff1a;

cd ./Down

到本地的对应路径&#xff08;这里表示在当前文件夹下&#xff09;&#xff1a;

lcd ./

切换交互式提示
prompt

使用mget或mput时&#xff0c;prompt命令让FTP在传输每个文件前进行提示&#xff0c;这样防止覆盖已有的文件。若发出prompt命令时已经启动了提示&#xff0c;FTP将把提示关掉&#xff0c;此时再传输所有的文件则不会有任何提问。

文件传输
下载文件
下载多个文件&#xff1a; 
格式&#xff1a;mget [remote-files] 
例如&#xff1a;获取远端所在文件夹下所有文件

mget *
#或
mget *.*

注&#xff1a;mget . 每下载一个文件&#xff0c;都会有提示。如果要除掉提示&#xff0c;则在mget . 命令前先执行:prompt off。

下载单个文件&#xff1a; 
格式&#xff1a;get [remote-file] [local-file] 
例如&#xff1a;获取远端FTP上的a.txt文件

get a.txt


上传文件
上传多个文件&#xff1a; 
格式&#xff1a;mput local-files 
例如&#xff1a;将所在文件夹下所有文件上传到FTP上

mput *

上传单个文件&#xff1a; 
格式&#xff1a;put local-file [remote-file] 
例如&#xff1a;将本地a.txt文件上传到远端FTP上

put a.txt

断开连接
bye

结束文件传输会话并退出 ftp 命令&#xff0c;与quit命令相同。

分界符标志
... < #execute shell
EOF
EOF只是一个分界符标志&#xff0c;完全可以用abc, ! 等替换&#xff0c;也一样的功能&#xff0c;只是大家都习惯用EOF来表示。 
<<用法&#xff1a;当shell看到<<的时候&#xff0c;它就会知道下一个词是一个分界符。在该分界符以后的内容都被当作输入&#xff0c;直到shell又看到该分界符(位于单独的一行)。因此分界符可以是定义的任何字符串。

--------------------- 

使用linux 的shell脚本进行sftp文件上传与下载

批量上传&#xff1a;

#!/bin/bash#SFTP配置信息
#用户名
USER&#61;root
#密码
PASSWORD&#61;5EYS40T04BMF
#待上传文件根目录
SRCDIR&#61;/u02/dab/sftpFiles
#FTP目录
DESDIR&#61;/u01/sftpFiles
#IP
IP&#61;192.168.10.11
#端口
PORT&#61;22022#获取文件
cd ${SRCDIR} ;
#目录下的所有文件
#FILES&#61;&#96;ls&#96; 
#修改时间在执行时间五分钟之前的xml文件
FILES&#61;&#96;find ${SRCDIR} -mmin -50 -name &#39;*.xml&#39;&#96;for FILE in ${FILES}
doecho ${FILE}
#发送文件 (关键部分&#xff09;
lftp -u ${USER},${PASSWORD} sftp://${IP}:${PORT} <cd ${DESDIR}/
lcd ${SRCDIR}
put ${FILE}
by
EOFdone

单文件下载&#xff1a;

#!/bin/bashUSER&#61;root
#密码
PASSWORD&#61;5EYS40T04BMF
#下载文件目录
SRCDIR&#61;/u02/dab
#FTP目录(待下载文件目录)
DESDIR&#61;/u01/sftpFiles
#银联IP
IP&#61;192.168.1.10
#端口
PORT&#61;22022lftp -u ${USER},${PASSWORD} sftp://${IP}:${PORT}<cd ${DESDIR}
lcd ${SRCDIR}
#需要下载的文件为text.xml
get text.xml
by
EOF
--------------------- 

 


推荐阅读
  • 该大学网站采用PHP和MySQL技术,在校内可免费访问某些外部收费资料数据库。为了方便学生校外访问,建议通过学校账号登录实现免费访问。具体方案可包括利用学校服务器作为代理,结合身份验证机制,确保合法用户在校外也能享受免费资源。 ... [详细]
  • 体积小巧的vsftpd与pureftpd Docker镜像在Unraid系统中的详细配置指南:支持TLS加密及IPv6协议
    本文详细介绍了如何在Unraid系统中配置体积小巧的vsftpd和Pure-FTPd Docker镜像,以支持TLS加密和IPv6协议。通过这些配置,用户可以实现安全、高效的文件传输服务,适用于各种网络环境。配置过程包括镜像的选择、环境变量的设置以及必要的安全措施,确保了系统的稳定性和数据的安全性。 ... [详细]
  • 2012年9月12日优酷土豆校园招聘笔试题目解析与备考指南
    2012年9月12日,优酷土豆校园招聘笔试题目解析与备考指南。在选择题部分,有一道题目涉及中国人的血型分布情况,具体为A型30%、B型20%、O型40%、AB型10%。若需确保在随机选取的样本中,至少有一人为B型血的概率不低于90%,则需要选取的最少人数是多少?该问题不仅考察了概率统计的基本知识,还要求考生具备一定的逻辑推理能力。 ... [详细]
  • 全面解析JavaScript代码注释技巧与标准规范
    在Web前端开发中,JavaScript代码的可读性和维护性至关重要。本文将详细介绍如何有效地使用注释来提高代码的可读性,并探讨JavaScript代码注释的最佳实践和标准规范。通过合理的注释,开发者可以更好地理解和维护复杂的代码逻辑,提升团队协作效率。 ... [详细]
  • 服务器部署中的安全策略实践与优化
    服务器部署中的安全策略实践与优化 ... [详细]
  • 本文介绍了如何利用Shell脚本高效地部署MHA(MySQL High Availability)高可用集群。通过详细的脚本编写和配置示例,展示了自动化部署过程中的关键步骤和注意事项。该方法不仅简化了集群的部署流程,还提高了系统的稳定性和可用性。 ... [详细]
  • 本文详细介绍了在CentOS 6.5 64位系统上使用阿里云ECS服务器搭建LAMP环境的具体步骤。首先,通过PuTTY工具实现远程连接至服务器。接着,检查当前系统的磁盘空间使用情况,确保有足够的空间进行后续操作,可使用 `df` 命令进行查看。此外,文章还涵盖了安装和配置Apache、MySQL和PHP的相关步骤,以及常见问题的解决方法,帮助用户顺利完成LAMP环境的搭建。 ... [详细]
  • 在开发过程中,我最初也依赖于功能全面但操作繁琐的集成开发环境(IDE),如Borland Delphi 和 Microsoft Visual Studio。然而,随着对高效开发的追求,我逐渐转向了更加轻量级和灵活的工具组合。通过 CLIfe,我构建了一个高度定制化的开发环境,不仅提高了代码编写效率,还简化了项目管理流程。这一配置结合了多种强大的命令行工具和插件,使我在日常开发中能够更加得心应手。 ... [详细]
  • 本文探讨了 Kafka 集群的高效部署与优化策略。首先介绍了 Kafka 的下载与安装步骤,包括从官方网站获取最新版本的压缩包并进行解压。随后详细讨论了集群配置的最佳实践,涵盖节点选择、网络优化和性能调优等方面,旨在提升系统的稳定性和处理能力。此外,还提供了常见的故障排查方法和监控方案,帮助运维人员更好地管理和维护 Kafka 集群。 ... [详细]
  • 七款高效编辑器与笔记工具推荐:KindEditor自动换行功能解析
    本文推荐了七款高效的编辑器与笔记工具,并详细解析了KindEditor的自动换行功能。其中,轻笔记QingBiJi是一款完全免费的记事本软件,用户可以通过其简洁的界面和强大的功能轻松记录和管理日常事务。此外,该软件还支持多平台同步,确保用户在不同设备间无缝切换。 ... [详细]
  • 本文详细介绍了 jQuery 的入门知识与实战应用,首先讲解了如何引入 jQuery 库及入口函数的使用方法,为初学者提供了清晰的操作指南。此外,还深入探讨了 jQuery 在实际项目中的多种应用场景,包括 DOM 操作、事件处理和 AJAX 请求等,帮助读者全面掌握 jQuery 的核心功能与技巧。 ... [详细]
  • 2016-2017学年《网络安全实战》第三次作业
    2016-2017学年《网络安全实战》第三次作业总结了教材中关于网络信息收集技术的内容。本章主要探讨了网络踩点、网络扫描和网络查点三个关键步骤。其中,网络踩点旨在通过公开渠道收集目标信息,为后续的安全测试奠定基础,而不涉及实际的入侵行为。 ... [详细]
  • 深入探索Node.js新框架:Nest.js第六篇
    在本文中,我们将深入探讨Node.js的新框架Nest.js,并通过一个完整的示例来展示其强大功能。我们将使用多个装饰器创建一个基本控制器,该控制器提供了多种方法来访问和操作内部数据,涵盖了常见的CRUD操作。此外,我们还将详细介绍Nest.js的核心概念和最佳实践,帮助读者更好地理解和应用这一现代框架。 ... [详细]
  • 本文详细介绍了使用响应文件在静默模式下安装和配置Oracle 11g的方法。硬件要求包括:内存至少1GB,具体可通过命令`grep -i memtotal /proc/meminfo`进行检查。此外,还提供了详细的步骤和注意事项,确保安装过程顺利进行。 ... [详细]
  • 如何将PHP文件上传至服务器及正确配置服务器地址 ... [详细]
author-avatar
小石头
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有