wrong login shell prevent root login
Hi,
When I play with my home linux and place a wrong shell for root user in the /etc/passwd file like this: root:.....:/sbin/wrongshell now when I want to be root via su, it display following msg: su: using restricted shell /sbin/wrongshell su: /sbin/wrongshell: No such file or directory even the command: su --shell=/bin/bash doesn't work since it still need to call the /bin/wrongshell after login. How can I override the /sbin/wrongshell without reboot and into the single user mode? Tks, Hong |
Have you got sudo installed? Or any write access to /sbin? If so, create a symlink to /bin/bash at the /sbin/wrongshell location:
ln -sf /bin/bash /sbin/wrongshell |
Hi,
Neither I can execute with sudo nor the /sbin directory is writable for me. I just wonder, since su --shell allow me to specifiy a shell to use instead of the shell specified in /etc/passwd, is it possible for me to tell "su" to ignore the shell specified in /etc/passwd? Tks, Hong |
The Man Page for SU,
NAME su - Change user ID or become super-user SYNOPSIS su [OPTS] [-] [username [ARGS]] DESCRIPTION su is used to become another user during a login session. Invoked without a username, su defaults to becoming the super user. The optional argument - may be used to provide an environment similiar to what the user would expect had the user logged in directly. The user will be prompted for a password, if appropriate. Invalid passwords will produce an error message. All attempts, both valid and invalid, are logged to detect abuses of the system. An optional command can be executed. This is done by the shell speci- fied in /etc/passwd for the target user unless the -s or -m options are used. Any arguments supplied after the username will be passed to the invoked shell (shell must support the -c command line option in order for a command to be passed to it). Unless the -m or -p options are used, the current environment is passed to the new shell with alterations. The value of $PATH is reset to /bin:/usr/bin for normal users, or /sbin:/bin:/usr/sbin:/usr/bin for the super user. This may be changed with the ENV_PATH and ENV_SUPATH definitions in /etc/login.defs. $IFS, if is set, is reset to contain space, tab, and newline. $USER is set to the name of the target user, $HOME is set to the home directory of the target user, and $SHELL is set to the shell of the target user. When using the -m or -p options, the user's environment is not changed. A subsystem login is indicated by the presense of a "*" as the first character of the login shell. The given home directory will be used as the root of a new filesystem which the user is actually logged into. OPTIONS - make this a login shell -c, --commmand=<command> pass command to the invoked shell using its -c option -m, -p, --preserve-environment do not reset environment variables, and keep the same shell -s, --shell=<shell> use shell instead of the default in /etc/passwd NOTES The -m, -p and -s options are restricted by the target user's shell being listed in /etc/shells. If it's not listed, then it's assumed to be a restricted account, a normal su is performed, and those options are ignored silently. A subsystem login is indicated by the presense of a "*" as the first character of the login shell. The given home directory will be used as the root of a new filesystem which the user is actually logged into. Much of the behavior of this command can be altered via its pam config- uration - see pam(7) CAVEATS This version of su has many compilation options, only some of which may be in use at any particular site. FILES /etc/passwd - user account information /etc/shadow - encrypted passwords and age information /etc/shells - valid user shells $HOME/.profile - initialization script for default shell |
reboot and in the grup boot prompt type
linux init=/bin/bash that will take you into the single user raw mode. edit /etc/passwd file to refflect /bin/bash as the login shell and reboot Regards Manjunath |
All times are GMT -5. The time now is 12:17 PM. |