用shell脚本的输入重定向的方法修改用户密码

怎样用shell脚本和输入重定向修改用户的密码呢?

我在这里用的是标准输入重定向写的脚本,我们知道,在CentOS中可以用重定向的方式修改用户密码: passwd --stdin username,那么怎样利用这一特性写脚本修改呢?

#!/bin/bash
read -p "请输入你想修改密码的用户:" user  # 读取用户名
id $user  # 测试用户是否存在
if [ $? -eq 0 ];then  # 用户存在则修改密码
  read -p "请输入修改的密码:" pwd  
  echo $pwd | passwd --stdin $user >& /dev/null  #把修改的结果重定向
  if [ $? -eq 0 ];then
    echo "$user 的密码已经修改为:$pwd"
  fi
else
  echo "该用户不存在"  # 用户不存在时提示
fi

这就是今天我要分享的内容,希望可以帮到你~

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
昨天一个网友问如何能够将输入密码的工作在shell里面自动完成,研究了一下,发现这种交互式的工作,普通的shell实现不了,据说可以借助expect来搞定,所以初步学习了一下expect,成果和大家分享一下: 应用一: 实现从普通用户“test”切换到root用户,自动输入root的密码,不用在终端提示符下执行密码输入操作。 步骤: (1)vi autosu.sh (2)#! /usr/bin/expect -f //指定expect工具的路径,如果不清楚具体路径,可以用"which expect"命令来查看。 spawn su - // 在expect 中用"spawn"关键字来调用命令“su - ” expect ":" //在执行了su - 命令之后,提示输入密码的提示符。例如你在执行了su - 命令之后,终端里面会出现提示“口令:”,那么你就可以在这里写expect ":",或者expect -exact "口令:" send "rootpasswd\r" //这里expect用send将你的root密码自动输入到上面的提示符之后。 interact //操作完成。 注意:这里强调一下执行脚本时要注意的地方,不能按照习惯来用sh ***.sh来这行expect的程序,会提示找不到命令,因为expect用的不是bash所以会报错。执行的时候直接./***.sh就可以了。~切记! 应用二: 从普通用户切换到root之后,执行“ls”操作,调用执行aaa.sh,返回执行结果,间隔10S。 #/usr/bin/expect -f spawn su - // 在expect 中用"spawn"关键字来调用命令“su - ” expect ":" //在执行了su - 命令之后,提示输入密码的提示符。例如你在执行了su - 命令之后,终端里面会出现提示“口令:”,那么你就可以在这里写expect ":",或者expect -exact "口令:" send "rootpasswd\r" //这里expect用send将你的root密码自动输入到上面的提示符之后。 expect "#" //当遇到提示符以#结尾时,即为root权限时; send "ls\r" //expect 用spend方法调用ls 命令,并且回车(“\r”) expect "#" send "sh aaa.sh\r" //调用sh aaa.sh,即执行一个脚本文件aaa.sh。 expect "#" send "echo $?\r" sleep 10 interact
### 回答1: shell脚本输出重定向是指将脚本中的输出结果重定向到指定的文件或设备中,而不是输出到终端。这样可以方便地将脚本的输出结果保存到文件中,或者将其发送到其他设备中。常用的输出重定向符号包括">"和">>",其中">"表示覆盖原文件,而">>"表示在原文件末尾追加内容。例如,将脚本的输出结果保存到文件中可以使用以下命令: ./my_script.sh > output.txt 这样,脚本的输出结果就会被保存到名为output.txt的文件中。如果想要将输出结果追加到文件末尾,可以使用以下命令: ./my_script.sh >> output.txt 这样,脚本的输出结果就会被追加到output.txt文件的末尾。 ### 回答2: shell脚本是一种脚本语言,用于执行命令序列和控制流,并可以使用输出重定向来控制输出的位置和格式。输出重定向是指将标准输出(stdout)或标准错误(stderr)从屏幕或终端重定向到文件或管道。 输出重定向有三种类型: 1.标准输出重定向(stdout):使用“>”符号将标准输出重定向到指定文件中。例如,将echo命令的输出内容重定向到test.txt文件可以使用命令“echo 'hello' > test.txt”,这将把“hello”写入到test.txt文件中。如果test.txt文件不存在,它将被创建,如果存在,则覆盖原有内容。 2.标准错误重定向(stderr):使用“2>”符号将标准错误重定向到指定文件中。例如,将cat命令的标准错误重定向到error.log文件可以使用命令“cat /path/to/file 2> error.log”。如果/path/to/file文件不存在,则会将错误信息写入到error.log文件中。 3.标准输出和标准错误重定向(stdout和stderr):使用“>&”符号可以将标准输出和标准错误一起重定向到指定文件中。例如,将脚本的标准输出和标准错误重定向到log文件可以使用命令“./script.sh >& log”。如果log文件不存在,它将被创建,如果存在,则覆盖原有内容。 输出重定向还可以将命令的输出作为另一个命令的输入,这称为管道。使用“|”符号可以将一个命令的输出重定向到另一个命令的输入中。例如,将ls命令的输出重定向到grep命令的输入中可以使用命令“ls | grep keyword”。 在shell脚本中,输出重定向可以用于记录脚本的执行结果或将脚本的输出转发到其他程序中。如果使用正确,它可以帮助程序员更好地管理和记录他们的程序输出。 ### 回答3: Shell脚本输出重定向是指将一个命令的输出结果输出到文件或者其他命令中,而不是输出到屏幕上。这样做可以方便我们将一些数据保存下来或者将数据传递给其他命令进行处理。 Shell脚本的输出重定向主要包括两种方式,分别为标准输出重定向和错误输出重定向。 标准输出重定向可以使用>符号将命令的标准输出结果重定向到文件中。例如,ls > file.txt命令将ls命令的结果输出到file.txt文件中,这样就可以方便地查看和分析命令的输出结果。 错误输出重定向则可以使用2>符号将命令的错误输出结果重定向到文件中。例如,ls not_exist 2> error.txt命令将ls命令执行时出现的错误信息输出到error.txt文件中。这样可以方便地查看命令出现的错误及其原因。 除了重定向输出到文件中,我们还可以使用管道符号将一个命令的输出结果传递给另一个命令进行处理。例如,ls | grep keyword命令将ls命令的结果传递给grep命令进行关键字的匹配,从而得到我们需要的结果。 在Shell脚本中,我们还可以使用tee命令将输出结果同时输出到文件和屏幕上,这样可以方便我们在屏幕上查看输出结果的同时保存输出结果。 总之,Shell脚本输出重定向是一个很实用的功能,可以方便我们对命令的输出结果进行保存和处理。我们可以善加利用这一功能,提高我们的工作效率和操作便捷性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值