Просто используйте file
:
$ file /usr/bin/add-apt-repository
/usr/bin/add-apt-repository: Python script, ASCII text executable
$ file /usr/bin/ab
/usr/bin/ab: ELF 64-bit LSB shared object, x86-64, version 1 (SYSV), dynamically linked (uses shared libs), for GNU/Linux 2.6.32, BuildID[sha1]=569314a9c4458e72e4ac66cb043e9a1fdf0b55b7, stripped
Как объяснено в man file
:
NAME
file — determine file type
DESCRIPTION
This manual page documents version 5.14 of the file command.
file tests each argument in an attempt to classify it. There are three
sets of tests, performed in this order: filesystem tests, magic tests,
and language tests. The first test that succeeds causes the file type to
be printed.
The type printed will usually contain one of the words text (the file
contains only printing characters and a few common control characters and
is probably safe to read on an ASCII terminal), executable (the file con‐
tains the result of compiling a program in a form understandable to some
UNIX kernel or another), or data meaning anything else (data is usually
“binary” or non-printable). Exceptions are well-known file formats (core
files, tar archives) that are known to contain binary data. When adding
local definitions to /etc/magic, make sure to preserve these keywords.
Users depend on knowing that all the readable files in a directory have
the word “text” printed. Don't do as Berkeley did and change “shell
commands text” to “shell script”.
Вы также можете использовать трюк, чтобы запустить это непосредственно от имени исполняемого файла в вашем $PATH
:
$ file $(type -p add-apt-repository | awk '{print $NF}')
/usr/local/bin/add-apt-repository: Python script, ASCII text executable
$ file $(type -p ab | awk '{print $NF}')
/usr/bin/ab: ELF 64-bit LSB shared object, x86-64, version 1 (SYSV), dynamically linked (uses shared libs), for GNU/Linux 2.6.32, BuildID[sha1]=569314a9c4458e72e4ac66cb043e9a1fdf0b55b7, stripped
Чтобы найти тип файла всех исполняемых файлов, которые можно найти в ваших каталогах $PATH
, вы можете сделать это:
find $(printf "$PATH" | sed 's/:/ /g') -type f | xargs file
И чтобы запустить file
все файлы в определенном каталоге ( /usr/bin
например), просто выполните
file /usr/bin/*
file
для каждого файла, чтобы увидеть, какой это тип файла. Есть ли какой-нибудь простой метод для всех файлов?file /usr/bin/*
. Как и любая другая команда.На самом деле, различия между ними не так велики.
В типичной системе Unix или Linux существует менее пяти реальных исполняемых файлов. На Ubuntu такие есть
/lib/ld-linux.so.2
и/sbin/ldconfig
.Все остальное, что помечено как исполняемое, запускается через интерпретатор , для которого поддерживаются два формата:
#!
будут иметь имя интерпретатора между этим и первым символом новой строки (это верно, нет требования, чтобы «сценарии» были текстовыми файлами).PT_INTERP
сегмент, который дает путь к интерпретатору (обычно/lib/ld-linux.so.2
).Когда такой файл выполняется, ядро находит имя интерпретатора и вместо этого вызывает его. Это может произойти рекурсивно, например, когда вы запускаете скрипт оболочки:
#! /bin/sh
в начале./bin/sh
, находитPT_INTERP
сегмент, указывающий на/lib/ld-linux.so.2
./lib/ld-linux.so.2
, обнаруживает, что у него нетPT_INTERP
сегмента, загружает свой текстовый сегмент и запускает его, передавая дескриптор open/bin/sh
и командную строку для вызова вашего скрипта.ld-linux.so.2
загружает сегменты кода/bin/sh
, разрешает ссылки на общую библиотеку и запускает ее основную функцию/bin/sh
затем снова открывает файл сценария и начинает интерпретировать его построчно.С точки зрения ядра, единственное отличие состоит в том, что для файла ELF передается дескриптор открытого файла, а не имя файла; это в основном оптимизация. Решает ли интерпретатор затем перейти к сегменту кода, загруженному из файла, или интерпретировать его построчно, решает только интерпретатор, и в основном это основано на соглашении.
источник
Файловая команда хороша , но для более профессионального инструмента анализа, я хотел бы, чтобы вы попробовали пакет TrID, который является инструментом Идентификатора файла.
TrID - это утилита, разработанная для идентификации типов файлов по их двоичным сигнатурам, и она проста в использовании.
Для получения дополнительной информации и пакета просто посетите: сайт
источник