草庐IT

kernel-headers

全部标签

c++ - IMAGE_SECTION_HEADER的VirtualAddress和PointerToRawData的区别

在this文章,定义是DWORD虚拟地址InEXEs,thisfieldholdstheRVAtowheretheloadershouldmapthesection.Tocalculatetherealstartingaddressofagivensectioninmemory,addthebaseaddressoftheimagetothesection'sVirtualAddressstoredinthisfield.DWORDPointerToRawDataThisisthefile-basedoffsetofwheretherawdataemittedbythecompiler

windows - Win32 32位进程加载64位kernel32.dll

我发现32位Win32控制台应用程序正在一台运行WindowsServer2012R2Standard的特定机器上加载64位版本的kernel32.dll。使用DependencyWalker使用一个简单的HelloWorld应用程序,它看起来像这样:它在其他机器上正确加载32位kernel32。PATH的值即使不完全相同,但至少在不同机器上以完全相同的顺序包含相关路径。根据thispage来自Microsoft,DLL的搜索顺序是:当前进程的可执行模块所在的目录。当前目录。Windows系统目录。GetSystemDirectory函数检索此目录的路径。Windows目录。GetWi

python3使用restype定义kernel32.GetModuleHandleA的返回值,但是python输出的值很大

我正在研究《Python灰帽》这本书,这是我的一个功能,这个问题我找了很久还是没有解决。deffunc_resolve(self,dll,function):GetModuleHandle=kernel32.GetModuleHandleAGetModuleHandle.argtypes=[c_char_p]GetModuleHandle.restype=c_void_phandle=GetModuleHandle(dll)print(handle)GetProcAddress=kernel32.GetProcAddressGetProcAddress.argtypes=[c_void

c++ - 如何使用 Winsock 从数据报的 IP header 中获取源 IP 地址?

我有一个绑定(bind)到INADDR_ANY的端口。我正在成功接收数据报。接收后,需要读取IP头,获取源IP地址。 最佳答案 如果您使用标准的recv或read函数调用,我认为您无法获得它。recvfrom调用如下:intrecvfrom(__inSOCKETs,__outchar*buf,__inintlen,__inintflags,__outstructsockaddr*from,__inout_optint*fromlen);包含一个结构(上面倒数第二个字段),它将接收源地址,您可以出于任何需要检查该地址。

windows - 如果我尝试将 header 编译为没有换行符的包含,为什么 MSVC++ 会给我一个错误? (C++/Windows )

我正在使用MSVC++编写一个简单的窗口,并且我包含了一个菜单的资源文件:MYMENUMENUDISCARDABLE//etc.然后我创建了一个头文件“resourcedef.h”,其定义如下#defineID_MYMENU_FILE_CLOSE1002我可以将它包含在我的main.cpp文件中而不会出错,但是,当我将它包含在资源文件中时,我得到了错误.\resourcedef.h(9):fatalerrorRC1004:unexpectedendoffilefound(resourcedef.h恰好有9行长)。当我在.h的末尾添加换行符时,//lines1-8#defineID_MY

c++ - 使用 GetModuleHandle 获取指向 IMAGE_DOS_HEADER 的指针?

一旦我的进程加载到内存中,我就试图获取它的图像库。据我了解,您可以调用GetModuleHandle来获取图像库。我的问题是,返回的句柄是否实质上指向IMAGE_DOS_HEADER结构,以便您可以执行以下操作:PIMAGE_DOS_HEADERDosHeader;DosHeader=(PIMAGE_DOS_HEADER)GetModuleHandle(NULL);如果这不正确,您还可以使用什么其他方法? 最佳答案 这是正确的,但如果您想要dll的模块句柄,则需要指定其路径。否则,您将获得进程exe的句柄。您还应该首先检查返回的HM

C 试图在 header 中查找\r\n\r\n

我试图找到最后一次出现的\r\n\r\n并删除它之前的所有内容(包括它)。我正在创建一个套接字并下载一个文件,然后该文件将被保存。HTTPheader保存在文件中(并且根据十六进制编辑器\r\n\r\n确实存在)。但我似乎无法使用strstr找到它,根据MSDNrecv返回char所以它应该能够找到它?while((tmpres=recv(sock,buf,BUFSIZ,0))>0){char*p=strstr(buf,"\r\n\r\n");printf("%s",p);exit(1);if(fwrite(buf,1,tmpres,fp)!=tmpres){printf("Error

c++ - 获取kernel32的符号

在C++/Windows中获取kernel32.dll符号的唯一途径是SymbolServer吗?谢谢:) 最佳答案 您也可以下载符号包。起点ishere. 关于c++-获取kernel32的符号,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/4699048/

c++ - 这两种包含相同 header 的方式在编译器中是否发生了不同的事情?

是否:#include#include#include#include#include"FileX.h"编译同一个头文件:#include#include#include#include#include在第一种情况下,windows.h是另一个文件(仍然包含在最后)。这两种包含相同header的方式在编译器中是否发生了不同? 最佳答案 在我的世界里,“FileX.h”定义如下#error"Thisisdifferentfromwindows.h,asitcontainsan#error!"#include所以是的,在这种情况下,“编

c++ - 在使用 NT DDK 构建的用户模式程序中包含 C++ header

所以...我有一个内核模式组件和一个用户模式组件,我正在使用NTDDK7.1.0的交key构建环境放在一起。.内核组件都是.c/.h/.rc文件。用户模式组件是.cpp/.c/.h/.rc文件。起初,对两者都使用build似乎是最简单的,因为我看到您可以修改./sources用户模式组件的文件说这样的话:TARGETNAME=MyUserModeComponentTARGETTYPE=PROGRAMUMTYPE=windowsUMENTRY=winmainUSE_MSVCRT=1这似乎没有引起问题,所以我很高兴,直到我尝试#include(或或其他)找不到那个东西:errorC1083