Shell脚本实现SFTP传输文件,通过密码形式

发布时间 2023-12-26 14:07:30作者: 技术颜良

读取SFTP连接信息
cat 读取文件内容
grep server : 查找文件内容中包含server字符的,行内容
awk -F ‘=’ :实现字符串分割,分割字符’‘=’
${print $2}: 其中$2 表示切割后数组中第几值
base -d :解码base64字符串,转为可识别字符串

#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

————————————————
版权声明:本文为CSDN博主「swg321321」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/swg321321/article/details/126560378