Shell编程之免交互的实现示例
作者:与苟富贵
一,Here Document 免交互
1:Here Document概述
Here Document,简称Heredoc,是Shell脚本中一种特殊的输入重定向方式,允许你插入多行文本到命令中,作为输入数据源。它由一个起始标记界定开始,以相同标记结束(通常该标记位于一行的开始),并且在结束标记前可以包含任意文本,甚至是变量和命令的输出。
2:Here Document 免交互
Heredoc设计用于简化向脚本或命令提供多行数据的过程,避免了手动输入或交互式对话的需求,特别适用于自动化脚本的编写。
(1).通过read命令接收输入并打印
虽然read
命令直接与Here Document无关,但提到免交互,可以对比说明。常规使用read
时需要用户逐行输入,而使用Heredoc,可以预先定义好要输入的多行文本,实现自动化:
# 使用Here Document代替read的交互过程 cat <<EOF This is the first line. This is the second line. EOF
(2).通过passwd给用户设置密码
Here Document在非交互式地设置用户密码时非常有用,避免了手动输入密码的步骤:
sudo passwd username <<EOF newPassword123 newPassword123 # 确认密码 EOF
注意:出于安全考虑,某些系统或版本的passwd
命令可能不接受来自stdin的密码输入。
3:Here Document 变量设定
在Heredoc中,可以方便地插入和使用变量,实现动态内容生成:
greeting="Hello" name="Alice" cat <<EOF ${greeting}, ${name}! EOF
4:Here Document 格式控制
Heredoc支持所有文本格式化控制,包括转义序列(如\n
换行、\t
制表符)和多行文本,适用于生成格式化输出,如配置文件、HTML等:
#bash cat <<EOF <html> <head> <title>Welcome</title> </head> <body> <h1>Hello, World!</h1> </body> </html> EOF
5:Here Document 多行注释
尽管不推荐作为主要的注释方式,但Here Document可以用作多行注释的一种非传统方法:
: <<'COMMENT' 这是一个 多行注释 不会展开变量 COMMENT
注意:使用单引号包围结束标记以阻止变量展开,保持注释内容原样输出。然而,标准的井号#
仍然是推荐的单行或多行注释方式。
二,expect 免交互
1:expect 概述
Expect 是一个强大的自动化和测试工具,它使用Tcl语言编写,专为处理交互式程序设计,如那些需要用户输入密码或对提示做出响应的程序。通过期望(expect)特定的输出并发送(send)相应的回复,expect脚本能模拟人类与命令行应用程序的交互,从而实现自动化操作,无需人工介入。
2:expect 安装
在Linux系统中,expect通常作为一个独立的软件包存在,可以通过包管理器安装:
- Debian/Ubuntu:
sudo apt-get install expect
- Fedora/RHEL/CentOS:
sudo yum install expect
或sudo dnf install expect
- macOS: 可以通过Homebrew安装,
brew install expect
3:基本命令介绍
(1)脚本解释器
每个expect脚本通常以#!/usr/bin/expect
作为第一行,指定了脚本的解释器。
(2)expect/send
- expect: 等待从进程接收到的输出匹配给定的模式,然后执行后续命令。
- send: 向进程发送字符串,模拟用户输入。通常需要
\r
来模拟回车键。
(3)spawn
- 用于启动一个新的子进程,并将该进程与expect脚本连接起来,以便对其进行交互。
(4)结束符
expect可以使用-exact
, -glob
, -regexp
等选项来指定匹配模式的类型。
(5)set
用于设置变量,如set variable value
。
(6)exp_continue
在满足expect条件后,使用exp_continue
可以继续执行下一次expect,而不是退出当前循环。
(7)send_user
类似于print或echo,但只输出到控制台,不发送给进程,用于调试或状态反馈。
(8)接收参数
脚本可以通过1,2等变量获取命令行参数,如set arg1 [lindex $argv 0]
。
4:expect 语法
(1)语法结构
基本结构包括spawn启动进程,一系列expect和send交互,以及最后的流程控制。
(2)expect 执行方式
脚本可以直接执行,或在shell脚本中调用expect命令执行。
5:expect 案例
(1)创建用户并设置密码
#!/usr/bin/expect set username "newuser" set password "secretpassword" spawn useradd $username expect "Enter new UNIX password:" send "$password\r" expect "Retype new UNIX password:" send "$password\r" interact
(2)实现ssh自动登录
#!/usr/bin/expect set user "remote_username" set host "remote_host" set password "remote_password" spawn ssh $user@$host expect { "(yes/no)?" { send "yes\r"; exp_continue } "password:" { send "$password\r" } } interact
(3)利用 expect 完成 FTP 登录过程
#!/usr/bin/expect set ftp_server "ftp.example.com" set ftp_user "ftp_username" set ftp_password "ftp_password" spawn ftp $ftp_server expect "Name .*:" send "$ftp_user\r" expect "Password:" send "$ftp_password\r" expect "ftp>" send "ls\r" expect "ftp>" send "quit\r"
这些案例展示了expect在自动化管理任务,如用户管理、远程登录和文件传输等方面的强大功能,通过模拟用户交互,实现无须人工干预的脚本执行。
到此这篇关于Shell编程之免交互的文章就介绍到这了,更多相关Shell 免交互内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!