Похоже, у вас есть файл, который вам нужен для доступа, но только после того, как пароль его разблокировал, правильно?
Если это так, я настоятельно рекомендую вам взглянуть на использование TrueCrypt - http: / /www.truecrypt.org/. Вы можете установить его как в Windows, так и в Ubuntu и использовать один и тот же пароль для разблокировки одного и того же файла в любой системе.
Единственным недостатком вашей ситуации является то, что вы конкретно указываете «защиту паролей файлов», но TrueCrypt создает том с зашифрованным содержимым внутри тома.
У меня есть другое решение, в котором вам не нужно добавлять sudo в качестве псевдонима. Я запускаю Linux Mint 17.3, но он должен быть очень похож на Ubuntu.
Когда вы являетесь пользователем root, тогда .profile запускается из его домашнего каталога. Если вы не знаете, что такое домашний каталог под root, вы можете проверить:
sudo su
echo $HOME
Как вы можете видеть, дом root - /root/. Проверьте его содержимое:
cd $HOME
ls -al
Должен быть файл .profile. Откройте файл и добавьте следующие строки:
if [ "$BASH" ]; then
if [ -f ~/.bash_aliases];then
. ~/.bash_aliases
fi
fi
В основном, этот скрипт bash выполняет проверку файла с именем .bash_aliases. Если файлы присутствуют, он выполняет файл.
Сохраните файл .profile и создайте свои псевдонимы в .bash_aliases. Если вы уже подготовили файл псевдонимов, скопируйте файл в это место
Перезапустите терминал, и вы готовы к работе!
У меня есть еще одно приятное решение, которое добавляет немного доверия:
Использовать завершение bash, чтобы автоматически заменить слова позади sudo своими псевдонимами при нажатии вкладки.
Сохранить это как /etc/bash_completion.d/sudo-alias.bashcomp, и он должен автоматически загружаться при запуске интерактивной оболочки:
_comp_sudo_alias() { from="$2"; COMPREPLY=()
if [[ $COMP_CWORD == 1 ]]; then
COMPREPLY=( "$( alias -p | grep "^ *alias $from=" | sed -r "s/^ *alias [^=]+='(.*)'$/\1/" )" )
return 0
fi
return 1
}
complete -o bashdefault -o default -F _comp_sudo_alias sudo
Затем войдите в новый терминал, и вам должно быть хорошо идти.
Ответ @Alvins является самым коротким. Без сомнений! : -)
Однако я подумал о решении командной строки для выполнения команды aliased в sudo, где нет необходимости переопределять sudo с помощью команды alias.
Здесь мое предложение для тех, кому это может быть интересно:
type -a <YOUR COMMAND HERE> | grep -o -P "(?<=\`).*(?=')" | xargs sudo
В случае команды ll
type -a ll | grep -o -P "(?<=\`).*(?=')" | xargs sudo
, когда у вас есть псевдоним (например: ll), команда type -a возвращает выражение с псевдонимом:
$type -a ll
ll is aliased to `ls -l'
с grep вы выбираете текст между акцентом `и апострофом 'в этом случае ls -l
И xargs выполняет выделенный текст ls -l как параметр sudo.
Да, немного дольше, но выполняет команду aliased в sudo ;-) Нет необходимости переопределять sudo как псевдоним.
Псевдонимы специфичны для пользователя - вам нужно определить их в /root/.bashrc
я написал функцию bash, что тени sudo.
он проверяет, есть ли у меня псевдоним для данной команды и запускает псевдоним команды вместо литерала с [F4] и в этом случае.
вот моя функция как один-лайнер:
sudo() { if alias "$1" &> /dev/null ; then $(type "$1" | sed -E 's/^.*`(.*).$/\1/') "${@:2}" ; else command sudo $@ ; fi }
или красиво отформатировано:
sudo() {
if alias "$1" &> /dev/null ; then
$(type "$1" | sed -E 's/^.*`(.*).$/\1/') "${@:2}"
else
command sudo "$@"
fi
}
Вы может добавить его в свой файл .bashrc, не забудьте источник его или перезагрузить терминальную сессию потом применять изменения.
Ответ на главный голос - отличный. Однако, если вы наберете sudo -i и поднимите сообщение sudo (#), вы не будете использовать псевдонимы, которые хотите использовать.
Чтобы использовать ваши псевдонимы (и все остальное) в # prompt, use:
sudo cp "$PWD"/.bashrc /root/.bashrc
Где «$ PWD» автоматически расширяется в «/ home / YOUR_USER_NAME»
У меня есть другое решение, в котором вам не нужно добавлять sudo в качестве псевдонима. Я запускаю Linux Mint 17.3, но он должен быть очень похож на Ubuntu.
Когда вы являетесь пользователем root, тогда .profile запускается из его домашнего каталога. Если вы не знаете, что такое домашний каталог под root, вы можете проверить:
sudo su
echo $HOME
Как вы можете видеть, дом root - /root/. Проверьте его содержимое:
cd $HOME
ls -al
Должен быть файл .profile. Откройте файл и добавьте следующие строки:
if [ "$BASH" ]; then
if [ -f ~/.bash_aliases];then
. ~/.bash_aliases
fi
fi
В основном, этот скрипт bash выполняет проверку файла с именем .bash_aliases. Если файлы присутствуют, он выполняет файл.
Сохраните файл .profile и создайте свои псевдонимы в .bash_aliases. Если вы уже подготовили файл псевдонимов, скопируйте файл в это место
Перезапустите терминал, и вы готовы к работе!
У меня есть еще одно приятное решение, которое добавляет немного доверия:
Использовать завершение bash, чтобы автоматически заменить слова позади sudo своими псевдонимами при нажатии вкладки.
Сохранить это как /etc/bash_completion.d/sudo-alias.bashcomp, и он должен автоматически загружаться при запуске интерактивной оболочки:
_comp_sudo_alias() { from="$2"; COMPREPLY=()
if [[ $COMP_CWORD == 1 ]]; then
COMPREPLY=( "$( alias -p | grep "^ *alias $from=" | sed -r "s/^ *alias [^=]+='(.*)'$/\1/" )" )
return 0
fi
return 1
}
complete -o bashdefault -o default -F _comp_sudo_alias sudo
Затем войдите в новый терминал, и вам должно быть хорошо идти.
Ответ @Alvins является самым коротким. Без сомнений! : -)
Однако я подумал о решении командной строки для выполнения команды aliased в sudo, где нет необходимости переопределять sudo с помощью команды alias.
Здесь мое предложение для тех, кому это может быть интересно:
type -a <YOUR COMMAND HERE> | grep -o -P "(?<=\`).*(?=')" | xargs sudo
В случае команды ll
type -a ll | grep -o -P "(?<=\`).*(?=')" | xargs sudo
, когда у вас есть псевдоним (например: ll), команда type -a возвращает выражение с псевдонимом:
$type -a ll
ll is aliased to `ls -l'
с grep вы выбираете текст между акцентом `и апострофом 'в этом случае ls -l
И xargs выполняет выделенный текст ls -l как параметр sudo.
Да, немного дольше, но выполняет команду aliased в sudo ;-) Нет необходимости переопределять sudo как псевдоним.
псевдонимы конкретного пользователя - нужно их определять в /root/.bashrc
Я написал для него функцию Bash, которая затеняет sudo.
Он проверяет, есть ли у меня псевдоним для данной команды и запускается команда aliased вместо литеральной с sudo в этом case
Вот моя функция как однострочный:
sudo() { if alias "$1" &> /dev/null ; then $(type "$1" | sed -E 's/^.*`(.*).$/\1/') "${@:2}" ; else command sudo $@ ; fi }
Или красиво отформатирован:
sudo() {
if alias "$1" &> /dev/null ; then
$(type "$1" | sed -E 's/^.*`(.*).$/\1/') "${@:2}"
else
command sudo "$@"
fi
}
Вы можете добавить его в свой .bashrc, не забудьте указать его или перезапустить сеанс терминала после этого, чтобы применить изменения.
Ответ на главный голос - отличный. Однако, если вы наберете sudo -i и поднимите сообщение sudo (#), вы не будете использовать псевдонимы, которые хотите использовать.
Чтобы использовать ваши псевдонимы (и все остальное) в # prompt, use:
sudo cp "$PWD"/.bashrc /root/.bashrc
Где «$ PWD» автоматически расширяется в «/ home / YOUR_USER_NAME»
У меня есть другое решение, в котором вам не нужно добавлять sudo в качестве псевдонима. Я запускаю Linux Mint 17.3, но он должен быть очень похож на Ubuntu.
Когда вы являетесь пользователем root, тогда .profile запускается из его домашнего каталога. Если вы не знаете, что такое домашний каталог под root, вы можете проверить:
sudo su
echo $HOME
Как вы можете видеть, дом root - /root/. Проверьте его содержимое:
cd $HOME
ls -al
Должен быть файл .profile. Откройте файл и добавьте следующие строки:
if [ "$BASH" ]; then
if [ -f ~/.bash_aliases];then
. ~/.bash_aliases
fi
fi
В основном, этот скрипт bash выполняет проверку файла с именем .bash_aliases. Если файлы присутствуют, он выполняет файл.
Сохраните файл .profile и создайте свои псевдонимы в .bash_aliases. Если вы уже подготовили файл псевдонимов, скопируйте файл в это место
Перезапустите терминал, и вы готовы к работе!
У меня есть еще одно приятное решение, которое добавляет немного доверия:
Использовать завершение bash, чтобы автоматически заменить слова позади sudo своими псевдонимами при нажатии вкладки.
Сохранить это как /etc/bash_completion.d/sudo-alias.bashcomp, и он должен автоматически загружаться при запуске интерактивной оболочки:
_comp_sudo_alias() { from="$2"; COMPREPLY=()
if [[ $COMP_CWORD == 1 ]]; then
COMPREPLY=( "$( alias -p | grep "^ *alias $from=" | sed -r "s/^ *alias [^=]+='(.*)'$/\1/" )" )
return 0
fi
return 1
}
complete -o bashdefault -o default -F _comp_sudo_alias sudo
Затем войдите в новый терминал, и вам должно быть хорошо идти.
@Элвинами ответ самый короткий. Без сомнения! :-)
однако я думал, что решения командную строку для выполнения псевдонима команды в команду sudo, где нет необходимости переосмысления sudo с помощью команды alias.
вот мое предложение для тех, кого это может заинтересовать:
решениеtype -a <YOUR COMMAND HERE> | grep -o -P "(?<=\`).*(?=')" | xargs sudo
в случае ll команда
type -a ll | grep -o -P "(?<=\`).*(?=')" | xargs sudo
, когда у вас есть псевдоним (например: ll) команды нажать [F8] возвращает искаженные выражения:
$type -a ll
ll is aliased to `ls -l'
с [F9] и вы выделите текст между акцентом и апостроф ' в таком случае ls -l
и xargs выполняет выбранный текст ls -l, а параметр [от f13].
да, немного дольше, но выполнить псевдонима команды в судо ;-) не нужно переопределять sudo в качестве псевдонима.
Псевдонимы специфичны для пользователя - вам нужно определить их в /root/.bashrc
Я написал для него функцию Bash, которая затеняет sudo.
Он проверяет, есть ли у меня псевдоним для данной команды и запускается команда aliased вместо литеральной с sudo в этом case
Вот моя функция как однострочный:
sudo() { if alias "$1" &> /dev/null ; then $(type "$1" | sed -E 's/^.*`(.*).$/\1/') "${@:2}" ; else command sudo $@ ; fi }
Или красиво отформатирован:
sudo() {
if alias "$1" &> /dev/null ; then
$(type "$1" | sed -E 's/^.*`(.*).$/\1/') "${@:2}"
else
command sudo "$@"
fi
}
Вы можете добавить его в свой .bashrc, не забудьте указать его или перезапустить сеанс терминала после этого, чтобы применить изменения.
Ответ на главный голос - отличный. Однако, если вы наберете sudo -i и поднимите сообщение sudo (#), вы не будете использовать псевдонимы, которые хотите использовать.
Чтобы использовать ваши псевдонимы (и все остальное) в # prompt, use:
sudo cp "$PWD"/.bashrc /root/.bashrc
Где «$ PWD» автоматически расширяется в «/ home / YOUR_USER_NAME»
У меня есть другое решение, в котором вам не нужно добавлять sudo в качестве псевдонима. Я запускаю Linux Mint 17.3, но он должен быть очень похож на Ubuntu.
Когда вы являетесь пользователем root, тогда .profile запускается из его домашнего каталога. Если вы не знаете, что такое домашний каталог под root, вы можете проверить:
sudo su
echo $HOME
Как вы можете видеть, дом root - /root/. Проверьте его содержимое:
cd $HOME
ls -al
Должен быть файл .profile. Откройте файл и добавьте следующие строки:
if [ "$BASH" ]; then
if [ -f ~/.bash_aliases];then
. ~/.bash_aliases
fi
fi
В основном, этот скрипт bash выполняет проверку файла с именем .bash_aliases. Если файлы присутствуют, он выполняет файл.
Сохраните файл .profile и создайте свои псевдонимы в .bash_aliases. Если вы уже подготовили файл псевдонимов, скопируйте файл в это место
Перезапустите терминал, и вы готовы к работе!
У меня есть еще одно приятное решение, которое добавляет немного доверия:
Использовать завершение bash, чтобы автоматически заменить слова позади sudo своими псевдонимами при нажатии вкладки.
Сохранить это как /etc/bash_completion.d/sudo-alias.bashcomp, и он должен автоматически загружаться при запуске интерактивной оболочки:
_comp_sudo_alias() { from="$2"; COMPREPLY=()
if [[ $COMP_CWORD == 1 ]]; then
COMPREPLY=( "$( alias -p | grep "^ *alias $from=" | sed -r "s/^ *alias [^=]+='(.*)'$/\1/" )" )
return 0
fi
return 1
}
complete -o bashdefault -o default -F _comp_sudo_alias sudo
Затем войдите в новый терминал, и вам должно быть хорошо идти.
@Элвинами ответ самый короткий. Без сомнения! :-)
однако я думал, что решения командную строку для выполнения псевдонима команды в команду sudo, где нет необходимости переосмысления sudo с помощью команды alias.
вот мое предложение для тех, кого это может заинтересовать:
решениеtype -a <YOUR COMMAND HERE> | grep -o -P "(?<=\`).*(?=')" | xargs sudo
в случае ll команда
type -a ll | grep -o -P "(?<=\`).*(?=')" | xargs sudo
, когда у вас есть псевдоним (например: ll) команды нажать [F8] возвращает искаженные выражения:
$type -a ll
ll is aliased to `ls -l'
с [F9] и вы выделите текст между акцентом и апостроф ' в таком случае ls -l
и xargs выполняет выбранный текст ls -l, а параметр [от f13].
да, немного дольше, но выполнить псевдонима команды в судо ;-) не нужно переопределять sudo в качестве псевдонима.
Псевдонимы специфичны для пользователя - вам нужно определить их в /root/.bashrc
Я написал для него функцию Bash, которая затеняет sudo.
Он проверяет, есть ли у меня псевдоним для данной команды и запускается команда aliased вместо литеральной с sudo в этом case
Вот моя функция как однострочный:
sudo() { if alias "$1" &> /dev/null ; then $(type "$1" | sed -E 's/^.*`(.*).$/\1/') "${@:2}" ; else command sudo $@ ; fi }
Или красиво отформатирован:
sudo() {
if alias "$1" &> /dev/null ; then
$(type "$1" | sed -E 's/^.*`(.*).$/\1/') "${@:2}"
else
command sudo "$@"
fi
}
Вы можете добавить его в свой .bashrc, не забудьте указать его или перезапустить сеанс терминала после этого, чтобы применить изменения.
топ-проголосовали ответ будет один большой. Однако, если вы Тип [F2] и поднять на суда оперативную (#) Вы не будете иметь псевдонимы, которую вы хотите использовать.
, чтобы использовать свои псевдонимы (и все остальное) на клавиши [F4] подскажите, использование:
sudo cp "$PWD"/.bashrc /root/.bashrc
, где "$ФРД" автоматически раскладывается в положение "/Home/ВАШЕ_ИМЯ_ПОЛЬЗОВАТЕЛЯ"
У меня есть другое решение, в котором вам не нужно добавлять sudo в качестве псевдонима. Я запускаю Linux Mint 17.3, но он должен быть очень похож на Ubuntu.
Когда вы являетесь пользователем root, тогда .profile запускается из его домашнего каталога. Если вы не знаете, что такое домашний каталог под root, вы можете проверить:
sudo su
echo $HOME
Как вы можете видеть, дом root - /root/. Проверьте его содержимое:
cd $HOME
ls -al
Должен быть файл .profile. Откройте файл и добавьте следующие строки:
if [ "$BASH" ]; then
if [ -f ~/.bash_aliases];then
. ~/.bash_aliases
fi
fi
В основном, этот скрипт bash выполняет проверку файла с именем .bash_aliases. Если файлы присутствуют, он выполняет файл.
Сохраните файл .profile и создайте свои псевдонимы в .bash_aliases. Если вы уже подготовили файл псевдонимов, скопируйте файл в это место
Перезапустите терминал, и вы готовы к работе!
У меня есть еще одно приятное решение, которое добавляет немного доверия:
Использовать завершение bash, чтобы автоматически заменить слова позади sudo своими псевдонимами при нажатии вкладки.
Сохранить это как /etc/bash_completion.d/sudo-alias.bashcomp, и он должен автоматически загружаться при запуске интерактивной оболочки:
_comp_sudo_alias() { from="$2"; COMPREPLY=()
if [[ $COMP_CWORD == 1 ]]; then
COMPREPLY=( "$( alias -p | grep "^ *alias $from=" | sed -r "s/^ *alias [^=]+='(.*)'$/\1/" )" )
return 0
fi
return 1
}
complete -o bashdefault -o default -F _comp_sudo_alias sudo
Затем войдите в новый терминал, и вам должно быть хорошо идти.
Ответ @Alvins является самым коротким. Без сомнений! : -)
Однако я подумал о решении командной строки для выполнения команды aliased в sudo, где нет необходимости переопределять sudo с помощью команды alias.
Здесь мое предложение для тех, кому это может быть интересно:
type -a <YOUR COMMAND HERE> | grep -o -P "(?<=\`).*(?=')" | xargs sudo
В случае команды ll
type -a ll | grep -o -P "(?<=\`).*(?=')" | xargs sudo
, когда у вас есть псевдоним (например: ll), команда type -a возвращает выражение с псевдонимом:
$type -a ll
ll is aliased to `ls -l'
с grep вы выбираете текст между акцентом `и апострофом 'в этом случае ls -l
И xargs выполняет выделенный текст ls -l как параметр sudo.
Да, немного дольше, но выполняет команду aliased в sudo ;-) Нет необходимости переопределять sudo как псевдоним.
Псевдонимы специфичны для пользователя - вам нужно определить их в /root/.bashrc
Я написал для него функцию Bash, которая затеняет sudo.
Он проверяет, есть ли у меня псевдоним для данной команды и запускается команда aliased вместо литеральной с sudo в этом case
Вот моя функция как однострочный:
sudo() { if alias "$1" &> /dev/null ; then $(type "$1" | sed -E 's/^.*`(.*).$/\1/') "${@:2}" ; else command sudo $@ ; fi }
Или красиво отформатирован:
sudo() {
if alias "$1" &> /dev/null ; then
$(type "$1" | sed -E 's/^.*`(.*).$/\1/') "${@:2}"
else
command sudo "$@"
fi
}
Вы можете добавить его в свой .bashrc, не забудьте указать его или перезапустить сеанс терминала после этого, чтобы применить изменения.
топ-проголосовали ответ будет один большой. Однако, если вы Тип [F2] и поднять на суда оперативную (#) Вы не будете иметь псевдонимы, которую вы хотите использовать.
, чтобы использовать свои псевдонимы (и все остальное) на клавиши [F4] подскажите, использование:
sudo cp "$PWD"/.bashrc /root/.bashrc
, где "$ФРД" автоматически раскладывается в положение "/Home/ВАШЕ_ИМЯ_ПОЛЬЗОВАТЕЛЯ"