Если вы хотите написать скрипт, который запускается от имени другого пользователя, то что-то вроде этого работает, хотя оно выводит слово «пароль» без перевода строки в стандартный формат.
su - username <<!
enterpasswordhere
enter commands to run as the new user
!
если у вас есть пользователь с именем fred с паролем 1234 и вы хотите получить домашний каталог ls of fred как fred, без отображаемой строки пароля, это будет выглядеть
su - fred <<! >/dev/null 2>&1
1234
whoami > /dev/tty
ls > /dev/tty
!
Получение ошибки: su: must be run from a terminal.
Абхишек Кашьяп
5
Я верю, что нет, и это не будет хорошей идеей. Вот почему:
если вы напишите пароль в подобной команде su <username> -p <password>, он будет сохранен в виде обычного текста в вашей истории bash. Это, безусловно, огромная проблема безопасности.
Если вам нужно запускать команды с su(или sudo) в автоматическом режиме, напишите сценарий, содержащий команды без suили, sudoи запуститеsu <username> script.sh
@DaiKaixian да, но он нигде не сохраняется, и никто не может его прочитать
Wayne_Yux
2
Вы можете попробовать что-то вроде:. echo <passwd> | sudo -S <command-line>Хотя это не безопасно, но это работает.
Дай
1
весь смысл моего ответа состоит в том, что не стоит сохранять пароль в команде. Поэтому я советую не делать этого
Wayne_Yux
-3
Если вы хотите выполнить некоторые конкретные команды от имени нового пользователя, используйте следующую команду: sudo -u {username} {command to be executed as the new user}
superuser
отсюда, superuser.com/questions/67765/…Ответы:
Если вы хотите написать скрипт, который запускается от имени другого пользователя, то что-то вроде этого работает, хотя оно выводит слово «пароль» без перевода строки в стандартный формат.
если у вас есть пользователь с именем fred с паролем 1234 и вы хотите получить домашний каталог ls of fred как fred, без отображаемой строки пароля, это будет выглядеть
источник
su: must be run from a terminal
.Я верю, что нет, и это не будет хорошей идеей. Вот почему:
если вы напишите пароль в подобной команде
su <username> -p <password>
, он будет сохранен в виде обычного текста в вашей истории bash. Это, безусловно, огромная проблема безопасности.Если вам нужно запускать команды с
su
(илиsudo
) в автоматическом режиме, напишите сценарий, содержащий команды безsu
или,sudo
и запуститеsu <username> script.sh
источник
su root script
все еще нужно ввести passwd.echo <passwd> | sudo -S <command-line>
Хотя это не безопасно, но это работает.Если вы хотите выполнить некоторые конкретные команды от имени нового пользователя, используйте следующую команду:
sudo -u {username} {command to be executed as the new user}
источник