Поэтому я просматривал веб-страницу на днях и наткнулся на несколько мест, в которых мне нужно было загружать .deb
файлы - и поскольку они устанавливаются пользователем root (и поэтому имеют «полномочия» и возможности root), я не был уверен в этом.
Поэтому я просматривал веб-страницу на днях и наткнулся на несколько мест, в которых мне нужно было загружать .deb
файлы - и поскольку они устанавливаются пользователем root (и поэтому имеют «полномочия» и возможности root), я не был уверен в этом.
Что нужно учитывать:
Насколько хорошо известен сайт? Например, это был случайный блог, покрытый рекламой, случайный пользователь на каком-либо форуме или это хорошо известный, уважаемый сайт?
Что он утверждает, чтобы установить? Например, он утверждает, что устанавливает ядро или набор иконок, но он имеет размер всего 1 МБ?
Насколько «важно», что у вас есть содержание этого .deb
?
Способы безопасного тестирования:
Я использую arkose
( в стандартных репозиториях
) песочницу с моими дэбами (и другими вещами) - использую это примерно так:
sudo arkose -n -c "cd $PWD; $SHELL"
Что это дает мне «песочницу» (также известную как «YAY I CAN SCREW UP!») С доступом копирования на запись ко всему на моем компьютере, включая мой домашний каталог - так что, если это .deb
делает неприятная неприятность sudo rm -rf /*
, я не делаю ТЕРЯЕТ ЛЮБЫХ ДАННЫХ!
Еще одна вещь, которая недостаточно подчеркнута, СДЕЛАТЬ РЕЗЕРВНЫЕ КОПИИ . Это очень полезно, и у нас есть много вопросов по этой теме.
Короче говоря, просто убедитесь, что вы думаете об этом, а не просто скачать случайный деб и установить его.
.deb
ролик с файлом и посмотрите, что внутри. Хотя я должен сказать, что я скачал случайный дебат от случайного пользователя в случайной ветке на форумах Ubuntu, чтобы исправить мои проблемы с принтером, это сработало.Если вы загружаете пакет из ненадежных или сомнительных источников, будьте параноиком. На популярных форумах, таких как ubuntuforums.org, если пользователь делает свой первый пост, содержащий только краткий текст типа «установить это, работает для меня!», За которым следует ссылка, будьте осторожны с этой ссылкой и / или инструкциями.
Не используйте бинарные пакеты, если это возможно, особенно из ненадежных источников. Получите исходный код (для официальных пакетов Ubuntu это можно сделать
apt-get source package-name
) и посмотрите на него.Если рассматриваемый пакет небольшой, возможно, стоит проанализировать его. Я предпочитаю использовать терминал для этого , потому что я тогда иметь быстрый доступ к другим инструментам мощной командной строки , как
ls
,find
,file
,less
,vim
,grep
,sed
,dpkg
и много других. Используйте завершение табуляции (т. Е. TabВвод команд и имен файлов), это действительно экономит время!Чтобы загрузить файл .deb, вы можете использовать браузер, но копирование и последующее использование ссылки
wget
происходит быстрее, поскольку вы уже можете экспериментировать с ним.Далее пришло время проверить сам файл.
less
(черезlesspipe
) может предоставить быстрый обзор содержимого файла. Клавиши со стрелками, страница вверх / вниз, домой / конец могут быть полезны для навигации, Qвыход из программы.После этого вы получите обзор зависимостей пакета и того, какие файлы он может содержать. Время для извлечения файлов и анализа содержимого с помощью
dpkg-deb
. Первая команда извлекает дерево файлов во вновь созданном каталогеfs
, вторая извлекает его,DEBIAN
потому что никакая другая цель не указана:Мы будем использовать
less
еще раз проанализировать содержание сценариев сопровождающего (то есть файлы , которые будут использоваться / работают во время установки (и удаление).prerm
,preinst
,postrm
,postinst
Скрипты запуска перед / после удаления / установки , которые являются наиболее важными для анализа файлов Используйте:n
и:p
для переключения между файлами. Нажав=
, вы получите текущее имя файла и номер строки, а также количество файлов в списке.Если скрипты пакета выглядят вменяемыми, самое время проанализировать установленное содержимое (используйте tab-завершение). Для сценариев оболочки и интерпретируемых сценариев (таких как Python) анализ проще (при условии, что вы знакомы с языком).
Обратите особое внимание на файлы конфигурации, особенно если они используют такие каталоги, как
/etc/init
(для сценариев запуска) или/etc/modprobe.d
(варианты загрузки модулей ядра).Для двоичных файлов
ldd
может дать представление о том, для чего может использоваться программа. Приведенная ниже программа выглядит как графическая программа, использующая OpenGL.После того, как вы уверены , что пакет выглядит действительно, вы можете перейти установить его в VirtualBox загрузке с Live CD и использования
ps aux
,top
,strace -f -o logfile.txt programname
для дальнейшего анализа.источник