读取SFTP连接信息
cat 读取文件内容
grep server : 查找文件内容中包含server字符的,行内容
awk -F ‘=’ :实现字符串分割,分割字符’‘=’
${print $2}: 其中$2 表示切割后数组中第几值
base -d :解码base64字符串,转为可识别字符串文章来源地址https://www.toymoban.com/news/detail-518358.html
#sftp配置文件
sftp_conf_path=/etc/sftp.conf
#获取sftp的IP地址
sftp_ip=`cat ${sftp_conf_path} | grep server | awk -F '=' '${print $2}'`
#获取sftp的端口
sftp_port=`cat ${sftp_conf_path} | grep port | awk -F '=' '${print $2}'`
#获取sftp的用户名
sftp_user=`cat ${sftp_conf_path} | grep server | awk -F '=' '${print $2}'`
#获取sftp的密码
sftp_password=`cat ${sftp_conf_path} | grep server | awk -F '=' '${print $2}' | base64 -d`
#实现SFTP传输
/usr/bin/expect << EOP
#每次执行sftp命令超时时间,如果设置过小会导致大文件传输不完整, 单位:秒
set timeout 10000
#执行连接SFTP
spawn sftp -oPort=${sftp_port} ${sftp_user}@${sftp_ip}
#反馈字符串包含 passowrd,则发送密码
expect {
"*password:" { send "${sftp_password}\r" }
}
#SFTP cd到本地文件目录
expect "sftp>"
send "lcd ${out_path}\r"
#SFTP cd到sftp服务器下
expect "sftp>"
send "cd ${sftp_path}\r"
#SFTP 将lcd目录下文件,传输到cd目录下
expect "sftp>"
send "put ${gz_file}\r"
#关闭SFTP连接
expect "sftp>"
send "bye \r"
EOF
if [ $? -eq 0 ]; then
echo "文件传输成功”
else
echo "文件传输失败!"
fi
#退出sh脚本
exit 0
文章来源:https://www.toymoban.com/news/detail-518358.html
到了这里,关于Shell脚本实现SFTP传输文件,通过密码形式的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!