当前位置: 代码网 > 服务器>服务器>Linux > Shell编程之免交互的实现示例

Shell编程之免交互的实现示例

2024年07月03日 Linux 我要评论
一,here document 免交互1:here document概述here document,简称heredoc,是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/ubuntusudo apt-get install expect
  • fedora/rhel/centossudo 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 免交互内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com