实验环境: windbg+win7x86家庭普通版+vmware9
kd> x /n nt!*keservice*
83fbd9c0 nt!KeServiceDescriptorTable = <no type information>
83fbda00 nt!KeServiceDescriptorTableShadow = <no type information>
kd> dd KeServiceDescriptorTable 83fbd9c0 83ed1d9c 00000000 00000191 83ed23e4 83fbd9d0 00000000 00000000 00000000 00000000 83fbd9e0 83f306af 00000000 03276d53 00000bb8 83fbd9f0 00000011 00000100 5385d2ba d717548f 83fbda00 83ed1d9c 00000000 00000191 83ed23e4 83fbda10 924c6000 00000000 00000339 924c702c 83fbda20 00000000 00000000 83fbda24 00000340 83fbda30 00000340 855c7b10 00000007 00000000
得到
ntoskrnel->ServiceTableBase = 83ed1d9c;
ntoskrnel->NumberOfService = 0x00000191;
将ntoskrnel的0x191个API列出:
kd> dd 83ed1d9c L191 83ed1d9c 840cdc28 83f1440d 8405db68 83e7888a 83ed1dac 840cf4ff 83f513fa 8413fb05 8413fb4e 83ed1dbc 840523bd 84159368 8415a5c1 84048b95 83ed1dcc 840d9b35 84132963 84085a56 840556cc 83ed1ddc 83feb928 84124898 8403c14e 8407ea62 83ed1dec 840cadf1 8402c238 840ca1fe 84049c0c 83ed1dfc 840db5bc 8404c28f 840db39c 840d3afc 83ed1e0c 8405e0f0 8411f657 840d0ec9 840db7ee 83ed1e1c 840b41fc 840cef2e 84060d15 84054cf3 83ed1e2c 84046b70 840b4a83 8411f77f 840a6f0a 83ed1e3c 84054702 8406621b 840220e3 84053ed1 83ed1e4c 83ed28bc 8401d5c3 84051ce7 8410bfb0 83ed1e5c 83e7ed56 84080b5f 8409937a 840cf42e 83ed1e6c 84147412 84147132 840289b9 840f1013 83ed1e7c 8404fc9d 84054ce9 840f127f 840ccd09 83ed1e8c 83e94d0c 84101c79 84057505 83ff9a55 83ed1e9c 84095671 8415f068 840a41e4 840af667 83ed1eac 84046977 841346de 84055e2a 84064d1e 83ed1ebc 84026a36 8405a32f 84065196 840d54f9 83ed1ecc 83fe1406 8404675f 8402857f 84130df9 83ed1edc 84130e44 8415fafb 8415fac1 83ffc35f 83ed1eec 84077f2b 8405a98d 840567f5 84130c02 83ed1efc 840c5124 84053304 84059ac8 84024e62 83ed1f0c 83ffc16b 840c3056 83ff9134 84064f39 83ed1f1c 84102b36 841031f3 8407d96f 8404107b 83ed1f2c 8415939b 8415a5f3 83fed6ad 84040911 83ed1f3c 840df9df 840e86f6 84032328 840c83ca 83ed1f4c 8411c4da 841575ef 83f68259 840864f0 83ed1f5c 840c0974 8411c5bb 8415959d 8415a7f3 83ed1f6c 840bba59 8415917b 84147f4c 840bdebf 83ed1f7c 84122a0f 84039d81 840458ff 8405d117 83ed1f8c 83fe990f 840544c2 840339cd 83e791b1 83ed1f9c 8402f130 841259b7 84125039 83f0d4db 83ed1fac 83f276fc 8414839a 840aa6a2 840e9dc1 83ed1fbc 840e9d56 8412de37 84065daf 84132b54 83ed1fcc 840e1c0a 8402e5c6 841484f4 84013e67 83ed1fdc 83f3e5c7 8404a7ca 8411e7a1 840ce5fc 83ed1fec 840b0f0d 83fed1ca 840e45c3 840e5cdd 83ed1ffc 8412de1e 83fe7de9 83fe4c75 8401ab78 83ed200c 83fe6426 83fd3a1c 83ff6e72 8405832b 83ed201c 83fcd026 83fc86d5 83e78191 8401b1b1 83ed202c 84060851 8406535b 84123b57 8412412d 83ed203c 8409b394 8415956c 8415a7c4 8404adb6 83ed204c 8404ee17 8404df39 84014d6b 84097584 83ed205c 84146995 84064b92 8415f169 84086b10 83ed206c 8410bca5 84134057 840a0642 84064add 83ed207c 8415f49f 84024169 840240f9 840b60e2 83ed208c 8402d4b2 8402ef07 840669dc 840b8fff 83ed209c 840a6b37 83fd20c7 840be674 8403a0c6 83ed20ac 840db977 840a2b6f 840b2d87 840cd2e4 83ed20bc 840a6c4e 8415ee0f 841476f1 84148989 83ed20cc 84038506 84095970 841472a2 84146fc2 83ed20dc 8414735a 8414707a 8404b93f 8401af60 83ed20ec 84035a51 841490e4 841491aa 84097403 83ed20fc 840e85a7 840ac9a1 84159a3e 84159e83 83ed210c 83f17d34 840cbb8c 83ff7f5c 84088d11 83ed211c 840ad9f0 8415a381 83fe6b4a 8404f81e 83ed212c 840d55d5 8404124c 84146ba2 840aa6d5 83ed213c 840e10ff 8411e7d4 8408b644 841485fe 83ed214c 840b1d6d 840a706e 841478e4 83fd1bcf 83ed215c 83f68e81 84033c3f 8415fe6b 8410bd68 83ed216c 840a0cae 84056e8d 84035cc0 8415f57c 83ed217c 84055ed6 840f0b05 840dedf8 84065277 83ed218c 841312c4 8410d349 840cb9e6 8404b2d0 83ed219c 8404ee4c 841583fc 840a2c15 841585d3 83ed21ac 84158bc7 84084cd4 840bdddd 840cbaf7 83ed21bc 8415eece 84041729 8409f405 840b06a7 83ed21cc 840ab2c8 84050caa 8404ce67 83e94d54 83ed21dc 8402c0a3 840b6c8c 83fec6a7 84147580 83ed21ec 8411e8b9 840b482c 84146b46 83ffc88c 83ed21fc 83ffe128 84148f38 8413209c 840850ed 83ed220c 8407d873 84067b6a 83ed7c28 8405aa8e 83ed221c 84055a8e 84102c81 840f0d4b 84148bd4 83ed222c 840f0898 83f303d3 84045a3d 8408d5e2 83ed223c 8408d165 8411ea85 840d5435 840928d9 83ed224c 84030ec3 83f3ec18 840e6904 841328fd 83ed225c 840c534b 84147636 841471ea 83ffac7c 83ed226c 84148d36 840e8176 840e791c 840efbbb 83ed227c 840b2dbc 83fdff07 84159c7f 8415a16b 83ed228c 84131cff 83fc59bd 83fe3895 83ff7ce1 83ed229c 83ff8250 8415abf5 8410cdda 8407e6de 83ed22ac 841580b7 8415f435 8415f367 841033b9 83ed22bc 84146dea 840ab75c 84050cce 840f03ad 83ed22cc 8405d314 8408d603 8414880c 840beaaf 83ed22dc 84058780 84148146 84148dfb 83f01362 83ed22ec 8415fe48 84038b82 8410be8e 84133d17 83ed22fc 8415f3d2 8415f2fc 8410d95f 84056626 83ed230c 841588cd 84158edf 840a30ee 84175d7a 83ed231c 840e4e70 840ebb4d 83ed7d52 83eea4b9 83ed232c 84045b3e 83fe72d7 8405f427 8410d979 83ed233c 841575ad 840679b7 83f21701 841474ca 83ed234c 8415fb84 8415fd7b 8413289f 840e9e2d 83ed235c 840da464 8404736f 840af9bf 840cd334 83ed236c 840c4afa 83f2775f 84148478 840a49bb 83ed237c 83f1a6a0 8415adf9 8411e74b 8410e1cf 83ed238c 840dd503 840dd51d 840efd53 8405aeaf 83ed239c 83e70b17 840b963a 8414c769 84102ed7 83ed23ac 84084e16 8407d435 84128904 8407cae7 83ed23bc 83ed77b1 8415f293 8415f22a 83f104b4 83ed23cc 840c3f2b 83ff42f7 8411e926 840b471c 83ed23dc 83e7f5c5
查看ntoskrnel.exe中的导出API:
开始的几个API:
kd> u 840cdc28 nt!NtAcceptConnectPort:
kd> u 83f1440d nt!NtAccessCheck:
kd> u 8405db68 nt!NtAccessCheckAndAuditAlarm:
kd> u 83e7888a nt!NtAccessCheckByType:
最后的几个API
kd> u 840c3f2b nt!NtWriteFile: kd> u 83ff42f7 nt!NtWriteFileGather: kd> u 8411e926 nt!NtWriteRequestData: kd> u 840b471c nt!NtWriteVirtualMemory: kd> u 83e7f5c5 nt!NtYieldExecution: