发布网友 发布时间:2022-04-25 14:00
共2个回答
热心网友 时间:2022-05-14 05:08
展开1全部只要用户能登录到系统的shell,就可以执行shell集成的若干命令,如export, set等,另外他还可以通过在环境变量PATH中添加/bin目录,获得/bin下的所有执行文件的执行权(系统已放开给所有用户执行)。追答复杂一点吧:
一、方法一:
1、建立用户
useradd test -s /home/test/bin/login.sh -m
2、创建用户的命令目录
mkdir /home/test/bin
chown test.test -R /home/test
3、创建登录脚本
vim /home/test/bin/login.sh
#!/bin/sh
stty erase ^H
stty kill ^U
echo -en "SSH to Host :"
read host
echo -en "UserName: "
read username
/usr/bin/ssh $host -l $username
给脚本加上执行权限:
chmod +x /home/test/bin/login.sh
注意:
^U 是Ctrl+v、Ctrl+u组合输入的
^H 是Ctrl+v、Ctrl+Backspace输入的
这2个命令是为ssh登录时编辑输入的内容用的。
这个login.sh中可以增加其它参数,修改它还可以运行其它命令。
二、方法二
用这个登录脚本的内容覆盖其他用户的home目录下的.profile文件,就可以*那个用户了,需要注意的是在输入状态用户用Ctrl+C可以退出脚本,进入Shell,所以还要加上信号处理:
#!/bin/sh
stty erase ^H
stty kill ^U
# signal handler
exit_()
{
echo -e "\nSSH Interrupted."
logout
}
# Signal handler
trap exit_ SIGINT SIGTERM SIGQUIT
echo -en "SSH to Host :"
read host
echo -en "UserName: "
read username
/usr/bin/ssh $host -l $username
logout
热心网友 时间:2022-05-14 06:26
把用户登录的shell改成那维一的 telnet程序可以.