<h1><a name="PE结构学习与沙箱模拟"></a><span></span>PE结构学习与沙箱模拟</h1><p>cs新生成一个shanque.exe用Everedit打开</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/12898/7fa44446c35675c4405ff6ef99938979_92632.png" alt=""><br>在分析之前先说几个概念<br>pe结构：可执行文件的头部结构</p>
<p><strong>分类</strong><br>DWORD：8个位置，4字节</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/12898/9e984c39268d891bf8ff3e6d2356b5e5_90415.png" alt=""></p>
<p>WORD：4个位置，2字节</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/12898/27c01ef0e8229660586d2f8b0eb7207a_31129.png" alt=""></p>
<p>BYTE：2个位置，1字节</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/12898/cc794d0b44b8ef1e6bc2838a50cfb5a2_77378.png" alt=""></p>
<p>大概有DOS头，NT头组成。</p>
<h2><a name="第一部分DOS头"></a><span></span>第一部分DOS头</h2><p>用来支持在dos操作系统上来运行</p>
<pre><code>typedef struct _IMAGE_DOS_HEADER {      // DOS .EXE header
    WORD   e_magic;                     // Magic number 
    WORD   e_cblp;                      // Bytes on last page of file
    WORD   e_cp;                        // Pages in file
    WORD   e_crlc;                      // Relocations
    WORD   e_cparhdr;                   // Size of header in paragraphs
    WORD   e_minalloc;                  // Minimum extra paragraphs needed
    WORD   e_maxalloc;                  // Maximum extra paragraphs needed
    WORD   e_ss;                        // Initial (relative) SS value
    WORD   e_sp;                        // Initial SP value
    WORD   e_csum;                      // Checksum
    WORD   e_ip;                        // Initial IP value
    WORD   e_cs;                        // Initial (relative) CS value
    WORD   e_lfarlc;                    // File address of relocation table
    WORD   e_ovno;                      // Overlay number
    WORD   e_res[4];                    // Reserved words
    WORD   e_oemid;                     // OEM identifier (for e_oeminfo)
    WORD   e_oeminfo;                   // OEM information; e_oemid specific
    WORD   e_res2[10];                  // Reserved words
    LONG   e_lfanew;                    // File address of new exe header
  } IMAGE_DOS_HEADER, *PIMAGE_DOS_HEADER;
</code></pre>
<p>关注两个地方<br>1.e_magic<br>标志位，看到5A4D就说明是PE结构（MZ是一个什么创始人的吊签名），是一个可执行文件。</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/12898/c4f825aad0860c1bd83d128658bc7a0e_79002.png" alt=""></p>
<ol>
<li>e_lfanew<br>偏移位，表示DOS头结束的地方<br><img src="https://nc0.cdn.zkaq.cn/md/12898/f8c2a49b9f0d7afc5e01f47e567fbca8_24959.png" alt=""></li></ol>
<h1><a name="第二部分NT头"></a><span></span>第二部分NT头</h1><pre><code>typedef struct _IMAGE_NT_HEADERS {
    DWORD Signature;          //文件签名
    IMAGE_FILE_HEADER FileHeader; //标准的NT头
    IMAGE_OPTIONAL_HEADER32 OptionalHeader; //可选的NT头
} IMAGE_NT_HEADERS32, *PIMAGE_NT_HEADERS32;
</code></pre>
<p> DWORD Signature</p>
<h2><a name="文件签名"></a><span></span>文件签名</h2><p><img src="https://nc0.cdn.zkaq.cn/md/12898/d7ba3074cfa216b852521c53d6e47c48_12714.png" alt=""><br>4550，PE，表示NT头开始的地方</p>
<p> IMAGE_FILE_HEADER FileHeader;</p>
<h2><a name="标准NT头"></a><span></span>标准NT头</h2><pre><code>typedef struct _IMAGE_FILE_HEADER {
    WORD    Machine;
    WORD    NumberOfSections;
    DWORD   TimeDateStamp;
    DWORD   PointerToSymbolTable;
    DWORD   NumberOfSymbols;
    WORD    SizeOfOptionalHeader;
    WORD    Characteristics;
} IMAGE_FILE_HEADER, * PIMAGE_FILE_HEADER;
</code></pre>
<ol>
<li>WORD    Machine;<br>这个文件支持在什么计算机上运行<br><img src="https://nc0.cdn.zkaq.cn/md/12898/cb73a0d34b066601583885ff5f6a4090_84733.png" alt=""><br>014c,在下面可以查到是Intel 386。</li></ol>
<h1><a name="define IMAGE_SIZEOF_FILE_HEADER             20"></a><span></span>define IMAGE_SIZEOF_FILE_HEADER             20</h1><h1><a name="define IMAGE_FILE_RELOCS_STRIPPED           0x0001  // Relocation info stripped from file."></a><span></span>define IMAGE_FILE_RELOCS_STRIPPED           0x0001  // Relocation info stripped from file.</h1><h1><a name="define IMAGE_FILE_EXECUTABLE_IMAGE          0x0002  // File is executable  (i.e. no unresolved external references)."></a><span></span>define IMAGE_FILE_EXECUTABLE_IMAGE          0x0002  // File is executable  (i.e. no unresolved external references).</h1><h1><a name="define IMAGE_FILE_LINE_NUMS_STRIPPED        0x0004  // Line nunbers stripped from file."></a><span></span>define IMAGE_FILE_LINE_NUMS_STRIPPED        0x0004  // Line nunbers stripped from file.</h1><h1><a name="define IMAGE_FILE_LOCAL_SYMS_STRIPPED       0x0008  // Local symbols stripped from file."></a><span></span>define IMAGE_FILE_LOCAL_SYMS_STRIPPED       0x0008  // Local symbols stripped from file.</h1><h1><a name="define IMAGE_FILE_AGGRESIVE_WS_TRIM         0x0010  // Aggressively trim working set"></a><span></span>define IMAGE_FILE_AGGRESIVE_WS_TRIM         0x0010  // Aggressively trim working set</h1><h1><a name="define IMAGE_FILE_LARGE_ADDRESS_AWARE       0x0020  // App can handle &gt;2gb addresses"></a><span></span>define IMAGE_FILE_LARGE_ADDRESS_AWARE       0x0020  // App can handle &gt;2gb addresses</h1><h1><a name="define IMAGE_FILE_BYTES_REVERSED_LO         0x0080  // Bytes of machine word are reversed."></a><span></span>define IMAGE_FILE_BYTES_REVERSED_LO         0x0080  // Bytes of machine word are reversed.</h1><h1><a name="define IMAGE_FILE_32BIT_MACHINE             0x0100  // 32 bit word machine."></a><span></span>define IMAGE_FILE_32BIT_MACHINE             0x0100  // 32 bit word machine.</h1><h1><a name="define IMAGE_FILE_DEBUG_STRIPPED            0x0200  // Debugging info stripped from file in .DBG file"></a><span></span>define IMAGE_FILE_DEBUG_STRIPPED            0x0200  // Debugging info stripped from file in .DBG file</h1><h1><a name="define IMAGE_FILE_REMOVABLE_RUN_FROM_SWAP   0x0400  // If Image is on removable media, copy and run from the swap file."></a><span></span>define IMAGE_FILE_REMOVABLE_RUN_FROM_SWAP   0x0400  // If Image is on removable media, copy and run from the swap file.</h1><h1><a name="define IMAGE_FILE_NET_RUN_FROM_SWAP         0x0800  // If Image is on Net, copy and run from the swap file."></a><span></span>define IMAGE_FILE_NET_RUN_FROM_SWAP         0x0800  // If Image is on Net, copy and run from the swap file.</h1><h1><a name="define IMAGE_FILE_SYSTEM                    0x1000  // System File."></a><span></span>define IMAGE_FILE_SYSTEM                    0x1000  // System File.</h1><h1><a name="define IMAGE_FILE_DLL                       0x2000  // File is a DLL."></a><span></span>define IMAGE_FILE_DLL                       0x2000  // File is a DLL.</h1><h1><a name="define IMAGE_FILE_UP_SYSTEM_ONLY            0x4000  // File should only be run on a UP machine"></a><span></span>define IMAGE_FILE_UP_SYSTEM_ONLY            0x4000  // File should only be run on a UP machine</h1><h1><a name="define IMAGE_FILE_BYTES_REVERSED_HI         0x8000  // Bytes of machine word are reversed."></a><span></span>define IMAGE_FILE_BYTES_REVERSED_HI         0x8000  // Bytes of machine word are reversed.</h1><h1><a name="define IMAGE_FILE_MACHINE_UNKNOWN           0"></a><span></span>define IMAGE_FILE_MACHINE_UNKNOWN           0</h1><h1><a name="define IMAGE_FILE_MACHINE_TARGET_HOST       0x0001  // Useful for indicating we want to interact with the host and not a WoW guest."></a><span></span>define IMAGE_FILE_MACHINE_TARGET_HOST       0x0001  // Useful for indicating we want to interact with the host and not a WoW guest.</h1><h1><a name="define IMAGE_FILE_MACHINE_I386              0x014c  // Intel 386."></a><span></span>define IMAGE_FILE_MACHINE_I386              0x014c  // Intel 386.</h1><h1><a name="define IMAGE_FILE_MACHINE_R3000             0x0162  // MIPS little-endian, 0x160 big-endian"></a><span></span>define IMAGE_FILE_MACHINE_R3000             0x0162  // MIPS little-endian, 0x160 big-endian</h1><h1><a name="define IMAGE_FILE_MACHINE_R4000             0x0166  // MIPS little-endian"></a><span></span>define IMAGE_FILE_MACHINE_R4000             0x0166  // MIPS little-endian</h1><h1><a name="define IMAGE_FILE_MACHINE_R10000            0x0168  // MIPS little-endian"></a><span></span>define IMAGE_FILE_MACHINE_R10000            0x0168  // MIPS little-endian</h1><h1><a name="define IMAGE_FILE_MACHINE_WCEMIPSV2         0x0169  // MIPS little-endian WCE v2"></a><span></span>define IMAGE_FILE_MACHINE_WCEMIPSV2         0x0169  // MIPS little-endian WCE v2</h1><h1><a name="define IMAGE_FILE_MACHINE_ALPHA             0x0184  // Alpha_AXP"></a><span></span>define IMAGE_FILE_MACHINE_ALPHA             0x0184  // Alpha_AXP</h1><h1><a name="define IMAGE_FILE_MACHINE_SH3               0x01a2  // SH3 little-endian"></a><span></span>define IMAGE_FILE_MACHINE_SH3               0x01a2  // SH3 little-endian</h1><h1><a name="define IMAGE_FILE_MACHINE_SH3DSP            0x01a3"></a><span></span>define IMAGE_FILE_MACHINE_SH3DSP            0x01a3</h1><h1><a name="define IMAGE_FILE_MACHINE_SH3E              0x01a4  // SH3E little-endian"></a><span></span>define IMAGE_FILE_MACHINE_SH3E              0x01a4  // SH3E little-endian</h1><h1><a name="define IMAGE_FILE_MACHINE_SH4               0x01a6  // SH4 little-endian"></a><span></span>define IMAGE_FILE_MACHINE_SH4               0x01a6  // SH4 little-endian</h1><h1><a name="define IMAGE_FILE_MACHINE_SH5               0x01a8  // SH5"></a><span></span>define IMAGE_FILE_MACHINE_SH5               0x01a8  // SH5</h1><h1><a name="define IMAGE_FILE_MACHINE_ARM               0x01c0  // ARM Little-Endian"></a><span></span>define IMAGE_FILE_MACHINE_ARM               0x01c0  // ARM Little-Endian</h1><h1><a name="define IMAGE_FILE_MACHINE_THUMB             0x01c2  // ARM Thumb/Thumb-2 Little-Endian"></a><span></span>define IMAGE_FILE_MACHINE_THUMB             0x01c2  // ARM Thumb/Thumb-2 Little-Endian</h1><h1><a name="define IMAGE_FILE_MACHINE_ARMNT             0x01c4  // ARM Thumb-2 Little-Endian"></a><span></span>define IMAGE_FILE_MACHINE_ARMNT             0x01c4  // ARM Thumb-2 Little-Endian</h1><h1><a name="define IMAGE_FILE_MACHINE_AM33              0x01d3"></a><span></span>define IMAGE_FILE_MACHINE_AM33              0x01d3</h1><h1><a name="define IMAGE_FILE_MACHINE_POWERPC           0x01F0  // IBM PowerPC Little-Endian"></a><span></span>define IMAGE_FILE_MACHINE_POWERPC           0x01F0  // IBM PowerPC Little-Endian</h1><h1><a name="define IMAGE_FILE_MACHINE_POWERPCFP         0x01f1"></a><span></span>define IMAGE_FILE_MACHINE_POWERPCFP         0x01f1</h1><h1><a name="define IMAGE_FILE_MACHINE_IA64              0x0200  // Intel 64"></a><span></span>define IMAGE_FILE_MACHINE_IA64              0x0200  // Intel 64</h1><h1><a name="define IMAGE_FILE_MACHINE_MIPS16            0x0266  // MIPS"></a><span></span>define IMAGE_FILE_MACHINE_MIPS16            0x0266  // MIPS</h1><h1><a name="define IMAGE_FILE_MACHINE_ALPHA64           0x0284  // ALPHA64"></a><span></span>define IMAGE_FILE_MACHINE_ALPHA64           0x0284  // ALPHA64</h1><h1><a name="define IMAGE_FILE_MACHINE_MIPSFPU           0x0366  // MIPS"></a><span></span>define IMAGE_FILE_MACHINE_MIPSFPU           0x0366  // MIPS</h1><h1><a name="define IMAGE_FILE_MACHINE_MIPSFPU16         0x0466  // MIPS"></a><span></span>define IMAGE_FILE_MACHINE_MIPSFPU16         0x0466  // MIPS</h1><h1><a name="define IMAGE_FILE_MACHINE_AXP64             IMAGE_FILE_MACHINE_ALPHA64"></a><span></span>define IMAGE_FILE_MACHINE_AXP64             IMAGE_FILE_MACHINE_ALPHA64</h1><h1><a name="define IMAGE_FILE_MACHINE_TRICORE           0x0520  // Infineon"></a><span></span>define IMAGE_FILE_MACHINE_TRICORE           0x0520  // Infineon</h1><h1><a name="define IMAGE_FILE_MACHINE_CEF               0x0CEF"></a><span></span>define IMAGE_FILE_MACHINE_CEF               0x0CEF</h1><h1><a name="define IMAGE_FILE_MACHINE_EBC               0x0EBC  // EFI Byte Code"></a><span></span>define IMAGE_FILE_MACHINE_EBC               0x0EBC  // EFI Byte Code</h1><h1><a name="define IMAGE_FILE_MACHINE_AMD64             0x8664  // AMD64 (K8)"></a><span></span>define IMAGE_FILE_MACHINE_AMD64             0x8664  // AMD64 (K8)</h1><h1><a name="define IMAGE_FILE_MACHINE_M32R              0x9041  // M32R little-endian"></a><span></span>define IMAGE_FILE_MACHINE_M32R              0x9041  // M32R little-endian</h1><h1><a name="define IMAGE_FILE_MACHINE_ARM64             0xAA64  // ARM64 Little-Endian"></a><span></span>define IMAGE_FILE_MACHINE_ARM64             0xAA64  // ARM64 Little-Endian</h1><h1><a name="define IMAGE_FILE_MACHINE_CEE               0xC0EE"></a><span></span>define IMAGE_FILE_MACHINE_CEE               0xC0EE</h1><p>//<br>// Directory format.<br>//</p>
<p>-</p>
<p>  WORD    NumberOfSections;<br>区节数</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/12898/00bf7b5a5fa46ef4d7886009f070bf39_19886.png" alt=""><br>0007,7节<br>用Exeinfo PE打开看一下</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/12898/c8ec55354b7daeb29ab58e93c118e1ef_82765.png" alt=""></p>
<p> DWORD   TimeDateStamp;<br> 时间戳，5AC57562</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/12898/eb07b773589a7806a9f3cdbc706a4db6_80715.png" alt=""></p>
<p><img src="https://nc0.cdn.zkaq.cn/md/12898/ff4f5e56c5934b18d266a23548bbefc4_69605.png" alt=""><br>1522890082</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/12898/c85ec8a30f48355dd493499c309493ab_68791.png" alt=""><br>卧槽，exe是我昨晚生成的，我这是穿越啦</p>
<p> DWORD PointerToSymbolTable;标志表指针（被废除 不用管）</p>
<p> DWORD NumberOfSymbols;标志表数量（被废除 不用管）</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/12898/c11f9d9e0bce8bd48a04afe070eb5c83_54391.png" alt=""></p>
<p>  WORD    SizeOfOptionalHeader;<br>  可选头大小</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/12898/abd27b4df4671b426159ec465343f56f_81906.png" alt=""><br>00E0，可以判断是32位还是64位，32位文件是224,64是240</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/12898/beb12db24f8b567288411748ff59d4ca_56529.png" alt=""></p>
<p>WORD    Characteristics;<br>文件特征，030F，30F就是300+F，100+200+F,F=1+2+4+8，然后对照下面的表看特征就可以。</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/12898/f56fc5aeeac09019cb53ebfbe2faa96a_97279.png" alt=""></p>
<p><img src="https://nc0.cdn.zkaq.cn/md/12898/1291b9f7b2934af68724e83844753a97_30956.png" alt=""></p>
<h2><a name="可选的NT头"></a><span></span>可选的NT头</h2><p>IMAGE_OPTIONAL_HEADER32 OptionalHeader</p>
<pre><code>typedef struct _IMAGE_OPTIONAL_HEADER {
    //
    // Standard fields.
    //

    WORD    Magic;
    BYTE    MajorLinkerVersion;
    BYTE    MinorLinkerVersion;
    DWORD   SizeOfCode;
    DWORD   SizeOfInitializedData;
    DWORD   SizeOfUninitializedData;
    DWORD   AddressOfEntryPoint;
    DWORD   BaseOfCode;
    DWORD   BaseOfData;

    //
    // NT additional fields.
    //

    DWORD   ImageBase;
    DWORD   SectionAlignment;
    DWORD   FileAlignment;
    WORD    MajorOperatingSystemVersion;
    WORD    MinorOperatingSystemVersion;
    WORD    MajorImageVersion;
    WORD    MinorImageVersion;
    WORD    MajorSubsystemVersion;
    WORD    MinorSubsystemVersion;
    DWORD   Win32VersionValue;
    DWORD   SizeOfImage;
    DWORD   SizeOfHeaders;
    DWORD   CheckSum;
    WORD    Subsystem;
    WORD    DllCharacteristics;
    DWORD   SizeOfStackReserve;
    DWORD   SizeOfStackCommit;
    DWORD   SizeOfHeapReserve;
    DWORD   SizeOfHeapCommit;
    DWORD   LoaderFlags;
    DWORD   NumberOfRvaAndSizes;
    IMAGE_DATA_DIRECTORY DataDirectory[IMAGE_NUMBEROF_DIRECTORY_ENTRIES];
} IMAGE_OPTIONAL_HEADER32, *PIMAGE_OPTIONAL_HEADER32;
</code></pre>
<p> WORD    Magic;<br>文件类型标识,010B,32位镜像文件</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/12898/c019848ba68b161cd15b5d25db513e84_48575.png" alt=""><br>0x10B：32位镜像文件</p>
<p>0x107：rom镜像文件</p>
<p>0x20B：62位镜像文件</p>
<p>BYTE    MajorLinkerVersion;（链接器主版本号）<br>BYTE    MinorLinkerVersion;（链接器副版本号）<br>不重要</p>
<p> DWORD   SizeOfCode;<br> 功能代码的大小（.text段的大小） 1E00，7680字节</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/12898/c5884b1688f3b256ead76abc9ee4c4a4_55495.png" alt=""></p>
<p><img src="https://nc0.cdn.zkaq.cn/md/12898/b2c0d37d7348d0831cd3232f312e5776_62883.png" alt=""></p>
<p> DWORD   SizeOfInitializedData;<br> .data段的大小，3400</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/12898/070d5b446b2d0973f8329b1933954896_89889.png" alt=""></p>
<p> DWORD   SizeOfUninitializedData;<br> .bss段的总大小，600</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/12898/bb2305af27e10c11a1263d98dd4ca403_95750.png" alt=""></p>
<p>DWORD   AddressOfEntryPoint;<br>程序的虚拟入口地址，就是程序运行时候的第一行代码，不是整个文件的第一行</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/12898/e4edefb3d62099af0d897a5f151a63bb_14044.png" alt=""></p>
<p><img src="https://nc0.cdn.zkaq.cn/md/12898/f452c3dd98a57c5d312b130462e92cac_34372.png" alt=""><br>就是紫色的这一行</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/12898/f1c11e1754367777c55a99337292d088_21602.png" alt=""><br>这一行才是文件的第一行，叫做代码基址。</p>
<p>DWORD   BaseOfCode;<br>代码基址，第一行代码的内存地址，1000</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/12898/aba15f95a67b9369669b0a6f6b44231a_11191.png" alt=""></p>
<p> DWORD   BaseOfData;<br> 数据基址</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/12898/415d9ca7e59634f294105b9f6cdb9621_98605.png" alt=""></p>
<p>DWORD   ImageBase;<br>入口点<br>入口点，当加载进内存时镜像的第1个字节的首选地址。它必须是64K的倍 数。</p>
<p>这里可以判断是exe还是dll：DLL默认是10000000H。Windows CE 的EXE默认是00010000H。Windows 系列的EXE默认是 00400000H。</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/12898/d84e7ee378e78898287a4fd81028e748_69690.png" alt=""></p>
<p>整个的分析笔记我放在附件了，篇幅太大容我偷个懒，感兴趣的小伙伴看到这里应该也知道怎么去分析了。</p>
<h1><a name="第二部分沙箱模拟"></a><span></span>第二部分沙箱模拟</h1><p>把shanque.exe丢到微步的沙箱里看看分析除了什么PE特征，通过pefile来复现猜测一下沙箱是怎么去检测的。</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/12898/456eba401c1932cdb8a739af3c15b2c6_82414.png" alt=""></p>
<p>1.判断是否有完整的PE结构,判据为DOS头的e_magic</p>
<pre><code>import pefile
pe = pefile.PE(&#39;shanque.exe&#39;)
if pe.DOS_HEADER.dump_dict()[&#39;e_magic&#39;][&#39;Value&#39;] == 23117:
    print(&quot;这是个PE结构的文件&quot;)
else:
    print(&#39;not&#39;)
</code></pre>
<p><img src="https://nc0.cdn.zkaq.cn/md/12898/6ba381841e88434d2b795d5e34b33fca_56378.png" alt=""></p>
<p>2.判断文件类型，判据可选NT头IMAGEBASE</p>
<pre><code>import pefile
pe = pefile.PE(&#39;shanque.exe&#39;)
if pe.OPTIONAL_HEADER.dump_dict()[&#39;ImageBase&#39;][&#39;Value&#39;] == 4194304:
    print(&#39;这是一个windows系列的exe程序&#39;)
else:
    print(&#39;这是一个dll文件&#39;)
</code></pre>
<p><img src="https://nc0.cdn.zkaq.cn/md/12898/9a1170875b6c239194902b44f1f2bfbe_58236.png" alt=""></p>
<p><img src="https://nc0.cdn.zkaq.cn/md/12898/59f7334403d369846f0e216bac49289c_31696.png" alt=""></p>
<p>3.判断是32位还是64位,判据标准NT头WORD    SizeOfOptionalHeader;</p>
<pre><code>import pefile
pe = pefile.PE(&#39;shanque.exe&#39;)
if pe.FILE_HEADER.dump_dict()[&#39;SizeOfOptionalHeader&#39;][&#39;Value&#39;] == 224:
    print(&#39;这是一个32位文件&#39;)
else:
    print(&#39;这是一个64位文件&#39;)
</code></pre>
<p><img src="https://nc0.cdn.zkaq.cn/md/12898/f0ea809c8fa72ca157f5d47f12957a6f_16660.png" alt=""></p>
<p>4.平台，判据NT头WORD machine</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/12898/e5694d5db2ac0b8afa6fc1b0f9314c54_22308.png" alt=""></p>
<pre><code>import pefile
pe = pefile.PE(&#39;shanque.exe&#39;)
if pe.FILE_HEADER.dump_dict()[&#39;Machine&#39;][&#39;Value&#39;] == 332:
    print(&#39;intel 386&#39;)
else:
    print(0)
</code></pre><p><img src="https://nc0.cdn.zkaq.cn/md/12898/eb6cd590bb491ddacf70f93969171beb_71177.png" alt=""></p>
<p>5.子系统，判据可选NT头 WORD    Subsystem；</p>
<p><img src="https://nc0.cdn.zkaq.cn/md/12898/1fa487dd6a0dd203d8f071b360c2b27f_99959.png" alt=""></p>
<pre><code>import pefile
pe = pefile.PE(&#39;shanque.exe&#39;)
if pe.OPTIONAL_HEADER.dump_dict()[&#39;Subsystem&#39;][&#39;Value&#39;] == 2:
    print(&#39;Windows图形用户界面（GUI）子系统（一般程序）&#39;)
else:
    print(&#39;0&#39;)
</code></pre>
<p><img src="https://nc0.cdn.zkaq.cn/md/12898/10e4a4c8d615a3326c237a89d410f2bc_66593.png" alt=""></p>
<p>6.节区数量，标准NT头 WORD    NumberOfSections</p>
<pre><code>import pefile
pe = pefile.PE(&#39;shanque.exe&#39;)
print(pe.FILE_HEADER.dump_dict()[&#39;NumberOfSections&#39;][&#39;Value&#39;])
</code></pre>
<p><img src="https://nc0.cdn.zkaq.cn/md/12898/3bfaa2a098bd2789b127737976fc93d3_29765.png" alt=""></p>
<p>7.程序的入口点 可选NT头DWORD   AddressOfEntryPoint;</p>
<pre><code>import pefile
pe = pefile.PE(&#39;shanque.exe&#39;)
if pe.OPTIONAL_HEADER.dump_dict()[&#39;AddressOfEntryPoint;&#39;][&#39;Value&#39;]
</code></pre>
seraphim
发表于 2023-4-23
评论列表
加载数据中...