Как повысить привилегии nautilus для перемещения или копирования папки от имени root?


11

Скажем, у меня в Nautilus открыта папка, которая находится в моем /home/user/tempкаталоге. Я хотел бы переместить папку оттуда в мой /optкаталог (это программа). Есть ли способ, которым я могу поднять команду копирования до sudoтак, чтобы я мог скопировать папку, не запуская новый экземпляр Nautilus из командной строки?

Ответы:


6

Насколько я могу сказать, основываясь на том, что я знаю и испытал:

sudoиспользуется для приложений / команд командной строки и gksudoполезен, когда вы пытаетесь запустить программу, используя диалоговое окно « Запустить приложение », нажав Alt + F2.

Я прочитал, что gksudoэто просто графическая версия sudo.

В любом случае, вы можете оставить sudo nautilusи / или gksu nautilus в терминале сделать то, что вы хотите, с одинаковым эффектом обеих команд. Но если вы хотите опустить терминал и запустить его напрямую с помощью диалогового окна « Запустить приложение », просто нажмите Alt + F2 и gksu nautilusвведите команду, после чего вам будет предложено ввести пароль, после чего откроется браузер файлов nautilus. с правами root.

Кроме того, вы можете открыть файлы / папки как root одним щелчком мыши, используя опцию «Открыть как администратор», щелкнув правой кнопкой мыши. Что в любом случае откроет новый экземпляр nautilus для данной папки и откроет файлы как root, это также может открывать / запускать приложения как root, но я еще не тестировал его.

введите описание изображения здесь

Вы можете получить опцию «Открыть как администрация» в своем контекстном меню, установив nautilus-gksu через командную строку: sudo apt-get install nautilus-gksuили используя synaptic, как показано на следующем рисунке:

введите описание изображения здесь

Удачи!


Похоже, мне нужно что-то добавить, чтобы получить команду «Открыть как». Вы помните, что это было? Я в Ub 11.
Jcollum

nautilus-gksu, через synaptic (изображение добавлено) или из командной строки (также предоставлено в ответе)
Geppettvs D'Constanzo

3
Вот почему мы должны использовать gksu nautilusне sudo: askubuntu.com/q/11760
Takkat

2
Двигался наутилус-гксу? Исчезают? Я не могу найти его в USC или apt-get.
Jcollum

2
@jcollum nautilus-gksuбольше не существует в репозитории с Ubuntu 12.04.
IQAndreas

5

вам нужно запустить Nautilus от имени пользователя root

введите это в терминале

gksu nautilus

Теперь вы можете двигаться с помощью графического интерфейса.

или используйте эту команду

sudo mv -r /home/user/temp/<foldername>/ /opt/

1
Таким образом, ответ «Вы не можете без перезапуска Nautilus»?
jcollum

вам не нужно перезапускать nautilus, просто откройте другой экземпляр с помощью команды gksu. Но если вы имеете в виду «открыть nautilus с моим пользователем, а затем получить права root в этом случае для перемещения файлов», возможно, это то, что вам нужно upubuntu.com/2011/12/…
zurdo

Вам нужно будет открыть новое окно nautilus, но чтобы упростить задачу, вы копируете местоположение из панели и запускаете команду: gksu nautilus "/path/to/dir/pasted/here"(цитаты вокруг пути важны)
IQAndreas

1

Вот скрипт nautilus, который я использую, чтобы открыть окно администратора Nautilus (root):

#!/bin/bash
# This Nautilus script opens the current nautilus window in admin mode.
# Requires: perl, liburi-perl

ERROR_NEED_PERL="This script requires the liburi-perl package. Install it and try again."
GKSUDO_MESSAGE="Enter your password to open an admin window on: "
ERROR_BROKEN_LINK="Broken link."

## Check for liburi-perl (and hence perl)
let PERLOK=$(dpkg-query -W --showformat='${Status}\n' liburi-perl|grep "install ok installed")
if [ "" == "$PERLOK" ]; then
   zenity --error --text "$ERROR_NEED_PERL"
   exit 1
fi

let LEN_NSSFP=${#NAUTILUS_SCRIPT_SELECTED_FILE_PATHS}-1
[ $LEN_NSSFP -lt 0 ] && let LEN_NSSFP=0
let LEN_NSSU=${#NAUTILUS_SCRIPT_SELECTED_URIS}-1
[ $LEN_NSSU -lt 0 ] && let LEN_NSSU=0

## if clicking happens on the Desktop (or a file or folder on it),
## $1 will be a path (i.e. with "/" in it); otherwise (in a folder
## window) $1 will be just a file or folder name (without path).
## Note that selecting the home desktop namespace extension yields
## a $# of zero but NAUTILUS_SCRIPT_SELECTED_FILE_PATHS pointing to the
## target (in the computer (computer:///) and trash (trash:///) desktop
## namespace extension cases, ...PATHS is empty).

## Initially, we stripped the file:// prefix from NAUTILUS...CURRENT_URI,
## yielding the full path, and then retrofit spaces, like this:
#OBJECT="`echo -n $NAUTILUS_SCRIPT_CURRENT_URI | cut -d'/' -f3- | sed 's/%20/ /g'`"
## However, this fails if any special characters other than spaces are in the path,
## such as accented letters, etc. We need to convert not just spaces, but any
## UTF-8 embedded in there...The URI<->path conversion requires perl (and liburi-perl):
OBJECT=$( echo "$NAUTILUS_SCRIPT_CURRENT_URI" | perl -MURI -le 'print URI->new(<>)->dir' )
## ->file is to be used for file URIs instead of ->dir, which is for directory URIs

CONTEXT="$OBJECT"
## Add the selection to the path, if defined and unique
if [ $# -eq 1 ] ; then
   ## If a single Desktop object, override
   if echo $1 | grep -q "/" ; then ## Desktop (or object on desktop)
      OBJECT="$1"
      CONTEXT=""
   else ## $1 is a simple file or folder name, without a path
      ## The container could be root (/)
      OBJECT="${OBJECT%/}/$1"
   fi
# elif [ $# -eq 0 -a -n "$NAUTILUS_SCRIPT_SELECTED_FILE_PATHS" ] ; then
elif [ $# -eq 0 ] ; then
   ## desktop name space extension selected?
   if [ -n "$NAUTILUS_SCRIPT_SELECTED_FILE_PATHS" ] ; then ## Home
      OBJECT="${NAUTILUS_SCRIPT_SELECTED_FILE_PATHS:0:LEN_NSSFP}"
   elif [ -n "$NAUTILUS_SCRIPT_SELECTED_URIS" ] ; then ## Computer, Trash
      ## These typically map to root (/)
#     OBJECT="`echo ${NAUTILUS_SCRIPT_SELECTED_URIS:0:LEN_NSSU} | cut -d'/' -f3- | sed 's/%20/ /g'`"
      OBJECT="${NAUTILUS_SCRIPT_SELECTED_URIS:0:LEN_NSSU}"
      OBJECT=$( echo "$OBJECT" | perl -MURI -le 'print URI->new(<>)->dir' )
   fi
   CONTEXT=""
fi
## Note that a desktop shortcut (.desktop file) does not trip -h
if [ -h "$OBJECT" ] ; then ## symbolic link
   ## readlink has no "follow symlinks as far as they exist" option
   OBJECT=`readlink -e "$OBJECT"`
   if [ -z "$OBJECT" ] ; then
      zenity --error --text "$ERROR_BROKEN_LINK"
      exit 1
   fi
fi

# zenity --info --text "\$OBJECT is « $OBJECT »"
if [ -f "$OBJECT" ] ; then
   ## Regular file
   DIR=`dirname "$OBJECT"`
else
   ## Directory (or no object)
   DIR="$OBJECT"
fi

## If DIR is empty, gnome-open opens in the default (home) directory (i.e. "~") anyway
#if [ -z "$DIR" ] ; then
#   DIR=~
#fi

## At this point, the test [ ! "$CONTEXT" = "$DIR" ] serves to indicate
## that the target directory is not matched to the one the script was
## invoked from (if any).

gksudo --message "$GKSUDO_MESSAGE$DIR" gnome-open "$DIR"

exit $?

0

Еще одно отличное решение - запустить еще одну копию Nautilus с привилегиями root (sudo) из командной строки:

gksudo xdg-open <path> &

Закрытие &означает, что команда выполняется как фоновое задание; следовательно, использование gksudo(использование sudoбудет означать невидимое приглашение, на которое вы не сможете ответить). xdg-openзаботится о запуске окна обозревателя ( nautilusили другого).

Вам может понадобиться установить xdg-utilsи gksuпакеты заранее.

Вы можете получить кучу предупреждений и Gtk-CRITICALи Glib-GObject-CRITICALсообщений при закрытии повышенной Nautilus окна, но они безвредны, насколько я могу судить. Я хотел бы избавиться от них, если кто-нибудь знает, как.


-1
sudo mv /home/user/temp/[Filename] /opt

Вместо этого [Filename]введите имя вашего файла без скобок [].


2
-1, не касается вопроса ... Я не спрашивал, как использовать команду mv.
Jcollum

3
Использование только одной команды в качестве пользователя root лучше использовать, чем открывать графический Nautilus в качестве пользователя root.
Агменор

-2

Еще один простой способ

sudo gnome-open foldername

Или я бы порекомендовал установить файловый менеджер nemo. В контекстном меню правой кнопки мыши «открыть как корень»

Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.