https://www.dbs724.com/146055.html

一招制敌:学会Linux查看二进制文件

在Linux操作系统中,二进制文件是一种常见的文件类型。如果你想深入了解一个二进制文件,可能需要查看其内容。但是,二进制文件是一种机器可读的文件,可能很难直接理解,因此需要特殊的工具来解析和查看。本文将介绍一些Linux下的工具,帮助你查看二进制文件。

1. file命令

file命令可以用来确定一个文件的类型,包括二进制文件、纯文本文件、图像文件等等。在Linux中,file命令是一个很有用的工具,用来辅助文件分类和归档。

例如,输入命令file /bin/bash可以获知bash的类型:

$ file /bin/bash
/bin/bash: ELF 64-bit LSB executable, x86-64, version 1 (SYSV), dynamically linked (uses shared libs), for GNU/Linux 2.6.24, BuildID[sha1]=66d6244d15847e7c0e39d7dbe4c4b19d177361d9, stripped

可以看到这是一个ELF 64-bit LSB的可执行文件。

2. hexdump命令

hexdump命令可以将文件的二进制数据以十六进制格式输出。这样可以帮助人们更好地理解二进制文件的结构。

例如,输入命令hexdump -C /bin/bash可以输出bash的十六进制数据:

$ hexdump -C /bin/bash | head -n 5
00000000 7f 45 4c 46 02 01 01 00 00 00 00 00 00 00 00 00 |.ELF............|
00000010 03 00 3e 00 01 00 00 00 e8 6a 40 00 00 00 00 00 |..>......j@.....|
00000020 40 00 00 00 00 00 00 00 00 40 00 00 00 00 00 00 |@........@......|
00000030 00 00 00 00 40 00 38 00 09 00 40 00 1b 00 1a 00 |....@.8...@.....|
00000040 06 00 00 00 05 00 00 00 40 00 00 00 00 00 00 00 |........@.......|

可以看到bash二进制文件中的数据是以十六进制格式展现的。

3. Strings命令

Strings命令可用于在二进制文件中查找ASCII字符串。该命令可以帮助我们找到字面上的秘密——二进制文件中的字符串。在某些情况下,这些字符串可能透露出相关的信息。

例如,输入命令strings /bin/bash可以输出bash文件中所有的ASCII字符串:

$ strings /bin/bash | head -n 5
/lib64/ld-linux-x86-64.so.2
libc.so.6
setlocale
bindtextdomain
__ctype_get_mb_cur_max

我们可以看到输出的内容就是ASCII字符串。

4. Objdump命令

Objdump是一个强大的工具,可以解析目标文件、可执行文件、动态链接库等二进制文件。它可以查看文件的目标代码、符号表、重定位表、代码段、数据段等信息。

例如,输入命令objdump -d /bin/bash可以查看bash中的汇编代码:

$ objdump -d /bin/bash
/bin/bash: file format elf64-x86-64

Disassembly of section .init:

0000000000400c48 :
400c48: 48 83 ec 08 sub $0x8,%rsp
400c4c: 48 8b 05 f9 2e 2c 00 mov 0x2c2ef9(%rip),%rax # 6cf148

可以看到输出了bash中的汇编代码,这样就有助于理解程序的内部结构和工作原理。

总结

本文介绍了Linux下的四个二进制文件查看工具:file、hexdump、strings、objdump。这些工具可以帮助你更好地理解和分析二进制文件,从而更好地理解程序的内部结构和工作原理。谨记此招,以便在需要时取得更好的效果。

【转帖】Linux查看二进制文件:一招制敌(linux二进制查看文件)的更多相关文章

  1. 一招制敌 - 玩转 AngularJS 指令的 Scope (作用域),讲得特别好

    学习了AngularJS挺长时间,最近再次回首看看指令这部分的时候,觉得比自己刚开始学习的时候理解的更加深入了,尤其是指令的作用域这部分. 步入正题: 每当一个指令被创建的时候,都会有这样一个选择,是 ...

  2. Linux下查看二进制文件命令

    一.在Linux下查看二进制文件的软件: xxd hexdump 二.编辑: 1.biew 2.hexedit 3.vim Vim 来编辑二进制文件.Vim 本非为此而设计的,因而有若干局限.但你能读 ...

  3. 怎么查看二进制文件内容?linux下nm命令告诉你!

    linux下强大的文件分析工具 -- nm 什么是nm nm命令是linux下自带的特定文件分析工具,一般用来检查分析二进制文件.库文件.可执行文件中的符号表,返回二进制文件中各段的信息. 目标文件. ...

  4. 使用strings查看二进制文件中的字符串

    使用strings查看二进制文件中的字符串 今天介绍的这个小工具叫做strings,它实现功能很简单,就是找出文件内容中的可打印字符串.所谓可打印字符串的涵义是,它的组成部分都是可打印字符,并且以nu ...

  5. Linux Kernel 排程機制介紹

    http://loda.hala01.com/2011/12/linux-kernel-%E6%8E%92%E7%A8%8B%E6%A9%9F%E5%88%B6%E4%BB%8B%E7%B4%B9/ ...

  6. Linux下如何查看高CPU占用率线程 LINUX CPU利用率计算

    目录(?)[-] proc文件系统 proccpuinfo文件 procstat文件 procpidstat文件 procpidtasktidstat文件 系统中有关进程cpu使用率的常用命令 ps ...

  7. Linux常用基础命令整理:关机命令、查看目录下文件命令等

    Linux常用基础命令整理:关机命令.查看目录下文件命令等 整理了一些Linux常用基础命令,欢迎指正. 首先记住四个热键,学会这四个键,收益一辈子. Tab按键---命令补齐功能Ctrl+c按键-- ...

  8. Linux GPT分区表16进制实例分析

    Linux GPT分区表16进制实例分析 GPT分区表随着win10的普及,已经在越来越多的新电脑上开始使用了.前段时间的新闻有看到说Intel会在后面的新平台中完全取消CSM支持,这也大概相当于后面 ...

  9. 【转帖】Linux上搭建Samba,实现windows与Linux文件数据同步

    Linux上搭建Samba,实现windows与Linux文件数据同步 2018年06月09日 :: m_nanle_xiaobudiu 阅读数 15812更多 分类专栏: Linux Samba 版 ...

  10. 如何在屏幕上查看命令的输出以及在Linux中写入文件

    在Linux中输出命令可以做很多事情(http://www.nanke0834.com) 您可以将命令的输出分配给变量,将其发送到另一个命令/程序以通过管道进行处理或将其重定向到文件以进行进一步分析. ...

随机推荐

  1. 带你认识一下多模态对比语言图像预训练CLIP

    本文分享自华为云社区<多模态对比语言图像预训练CLIP:打破语言与视觉的界限>,作者:汀丶. 一种基于多模态(图像.文本)对比训练的神经网络.它可以在给定图像的情况下,使用自然语言来预测最 ...

  2. 云原生批量计算引擎 Volcano社区v1.8.0版本正式发布

    本文分享自华为云社区<云原生批量计算引擎 Volcano社区v1.8.0版本正式发布>,作者: 云容器大未来. 北京时间2023年8月17日,Volcano 社区 v1.8.0 版本正式发 ...

  3. 数据库运维家中常备:上限约400MB/s,比COPY等工具还好用的数据利器

    摘要:随着数据仓库业务的发展,GDS使用场景日益增多,这就要求GDS仍要不断迭代,充分深入挖掘用户需求,提高产品化程度. 1. GDS定位 GDS是GaussDB(DWS)提供的一个数据导入导出工具, ...

  4. 带你了解VXLAN网络中报文的转发机制

    摘要:本节以集中式VXLAN网络(手工方式建立VXLAN隧道)为例,分别介绍相同子网内.不同子网间是如何进行通信的.在了解转发机制的前提下,我们先来看下VXLAN网关有哪些种类. VXLAN二层网关与 ...

  5. “/usr/bin/hdp-select”, line 226 print “ERROR: Invalid package – “ + name ^ SyntaxError: Missing parentheses in call to ‘print’. Did you mean print(“ERROR: Invalid package

    spark-submit时报错 python升级3.7引起 恢复2.7正常

  6. Mac 向日葵设置

  7. Jenkins Blue Ocean

    介绍 Blue Ocean 是 pipeline 的可视化UI.同时兼容经典的自由模式的 job.Jenkins Pipeline 从头开始设计,但仍与自由式作业兼容,Blue Ocean 减少了经典 ...

  8. pytest参数化及应用

    Pytest 安装pytest #安装pytest pip install pytest #检查是否安装 pytest --version 创建第一个测试 def func(x): return x ...

  9. gunicorn 高性能wsgi服务器

    参考: https://zhuanlan.zhihu.com/p/102716258 Gunicorn是什么 Gunicorn Green Unicorn 是一个 UNIX 下的 WSGI HTTP ...

  10. Django rest_framework使用自定义异常

    完整代码 https://gitee.com/mom925/django-system 在settings.py中配置 REST_FRAMEWORK = { "EXCEPTION_HANDL ...