Mydll.cpp
上传用户:nbcables
上传日期:2007-01-11
资源大小:1243k
文件大小:10k
源码类别:

钩子与API截获

开发平台:

Visual C++

  1. // ------------------------------------- //
  2. // 您如果要使用本文件,请不要删除本说明  //
  3. // ------------------------------------- //
  4. //             HOOKAPI 开发例子          //
  5. //   Copyright 2002 编程沙龙 Paladin     //
  6. //       www.ProgramSalon.com            //
  7. // ------------------------------------- //
  8. #include "stdafx.h"
  9. #include <winsock2.h>
  10. #include <stdio.h>
  11. #include <stdlib.h>
  12. #include <time.h>
  13. #include <lmcons.h>
  14. #include <lmalert.h>
  15. #include "mydll.h"
  16. #include <nb30.h>
  17. #include "util.h"
  18. #include "filter.h"
  19. char g_szDllPath[128];
  20. HINSTANCE g_hInstance;
  21. CSocketFilter socket_filter;
  22. #ifdef WIN95
  23. #pragma code_seg("_INIT")
  24. #pragma comment(linker,"/SECTION:.bss,RWS /SECTION:.data,RWS /SECTION:.rdata,RWS /SECTION:.text,RWS /SECTION:_INIT,RWS ")
  25. #pragma comment(linker,"/BASE:0xBFF70000")
  26. #endif
  27. BOOL APIENTRY DllMain( HANDLE hModule, 
  28.                        DWORD  ul_reason_for_call, 
  29.                        LPVOID lpReserved
  30.  )
  31. {
  32. if(ul_reason_for_call =DLL_PROCESS_ATTACH)
  33. {
  34. GetProfileString("HookAPI", "dll_path", "", g_szDllPath, sizeof(g_szDllPath));
  35. }
  36. return TRUE;
  37. }
  38. int WINAPI mysocket(int af, int type, int protocol)
  39. {
  40. WriteLog("mysocket, af=%d, type=%d, protocol=%d", af, type, protocol);
  41. return socket(af, type, protocol);
  42. }
  43. struct hostent * WINAPI mygethostbyname (const char * name)
  44. {
  45. // filter IE url
  46. WriteLog("gethostbyname:name:%s", name);
  47. if(socket_filter.FilterDNS((char *)name))
  48. {
  49. WSASetLastError(-1);
  50. return NULL;
  51. }
  52. WriteLog("gethostbyname, do...");
  53. return gethostbyname(name);
  54. }
  55. int WINAPI myaccept(SOCKET s, struct sockaddr *pname, int *pnamelen)
  56. {
  57. int port =GetLocalPortBySocket(s);
  58. WriteLog("myaccept");
  59. int s1 =accept(s, pname, pnamelen);
  60. if(s1 >0)
  61. {
  62. int err=WSAGetLastError();
  63. if(socket_filter.FilterAccept(s))
  64. {
  65. WSASetLastError(-1);
  66. return -1;
  67. }
  68. }
  69. return s1;
  70. }
  71. int WINAPI myconnect(SOCKET s, struct sockaddr *name, int namelen)
  72. {
  73. struct sockaddr_in *paddr =(struct sockaddr_in *)name;
  74. char *ip =inet_ntoa(paddr->sin_addr);
  75. int port =ntohs(paddr->sin_port);
  76. WriteLog("connect: ip=%s, port=%dn", ip, port);
  77. if(socket_filter.FilterConnect(ip, port))
  78. {
  79. WSASetLastError(-1);
  80. return -1;
  81. }
  82. return connect(s, name, namelen);
  83. }
  84. int WINAPI myrecv(SOCKET s, char *buf, int len, int flags)
  85. {
  86. WriteLog("nmyrecv");
  87. int recved_len =recv(s, (char *)buf, len, flags);
  88. int err;
  89. err =WSAGetLastError();
  90. if(recved_len >0)
  91. {
  92. socket_filter.FilterRecv(s, buf, len);
  93. }
  94. WSASetLastError(err);
  95. return recved_len;
  96. }
  97. int WINAPI mysend(SOCKET s, char *buf, int len, int flags)
  98. {
  99. int ret;
  100. WriteLog("nmysend");
  101. socket_filter.FilterSend(s, buf, len);
  102. ret =send(s, (char *)buf, len, flags);
  103. int err =WSAGetLastError();
  104. // do something
  105. WSASetLastError(err);
  106. return ret;
  107. }
  108. int WINAPI mysendto (SOCKET s, char FAR * buf, int len, int flags, struct sockaddr FAR * to, int tolen)
  109. {
  110. WriteLog("mysendto");
  111. char *ip =inet_ntoa(((struct sockaddr_in *)to)->sin_addr);
  112. int port =ntohs(((struct sockaddr_in *)to)->sin_port);
  113. if(socket_filter.FilterConnect(ip, port))
  114. {
  115. WSASetLastError(-1);
  116. return -1;
  117. }
  118. socket_filter.FilterSendTo(ip, port, buf, len);
  119. return sendto(s, buf, len, flags, to, tolen);
  120. }
  121. int WINAPI myrecvfrom (SOCKET s, char FAR * buf, int len, int flags, struct sockaddr FAR * from, int *fromlen)
  122. {
  123. WriteLog("myrecvfrom");
  124. char *ip =inet_ntoa(((struct sockaddr_in *)from)->sin_addr);
  125. int port =ntohs(((struct sockaddr_in *)from)->sin_port);
  126. len = recvfrom(s, buf, len, flags, from, fromlen);
  127. int err=WSAGetLastError();
  128. socket_filter.FilterRecvFrom(ip, port, buf, len);
  129. WSASetLastError(err);
  130. return len;
  131. }
  132. HINSTANCE WINAPI myLoadLibraryA(char *name)
  133. {
  134. char fname[128];
  135. GetModuleFileName(NULL, fname, sizeof(fname));
  136. WriteLog("%s,LoadLibraryA:%s", fname, name);
  137. return LoadLibraryA(name);
  138. }
  139. HINSTANCE WINAPI myLoadLibraryW(LPWSTR name)
  140. {
  141. char fname[128];
  142. GetModuleFileName(NULL, fname, sizeof(fname));
  143. char aname[128];
  144. WideCharToMultiByte( CP_ACP, 0, name, -1, aname, 128,NULL,NULL); 
  145. WriteLog("%s,LoadLibraryW:%s", fname, aname);
  146. return LoadLibraryW(name);
  147. }
  148. FARPROC WINAPI myGetProcAddress(HMODULE hMod, char *name)
  149. {
  150. char fname[128];
  151. GetModuleFileName(NULL, fname, sizeof(fname));
  152. if(strstr(fname, "HookAPI") ==NULL)
  153. WriteLog("%s,GetProcAddress:%s", fname, name);
  154. return GetProcAddress(hMod, name);
  155. }
  156. int WINAPI myNetbios(PNCB pncb)
  157. {
  158. WriteLog("Netbios");
  159. return Netbios(pncb);
  160. }
  161. int WINAPI myNetAlertRaise( LPWSTR event_name, LPVOID buf, DWORD buf_len)
  162. {
  163. WriteLog("myNetAlertRaise...");
  164. return NetAlertRaise(event_name, buf, buf_len);
  165. }
  166. int WINAPI myWSHOpenSocket( int *family, int *type, int *protocol, LPWSTR device_name, LPVOID *context, LPDWORD event)
  167. {
  168. WriteLog("WSHOpenSocket:event=%d", *event);
  169. HMODULE hMod=GetModuleHandle("WSHTcpip.dll");
  170. if(hMod ==NULL) return -1;
  171. WSHOPENSOCKET WSHOpenSocket =(WSHOPENSOCKET)GetProcAddress(hMod, "WSHOpenSocket");
  172. if(WSHOpenSocket ==NULL) return -1;
  173. return WSHOpenSocket(family, type, protocol, device_name, context,event);
  174. }
  175. int WINAPI myWSHOpenSocket2(int *family, int *type, int *protocol, int group, int flags, LPWSTR device_name, LPVOID *context, LPDWORD event)
  176. {
  177. WriteLog("WSHOpenSocket2");
  178. HMODULE hMod=GetModuleHandle("WSHTcpip.dll");
  179. if(hMod ==NULL) return -1;
  180. WSHOPENSOCKET2 WSHOpenSocket2 =(WSHOPENSOCKET2)GetProcAddress(hMod, "WSHOpenSocket2");
  181. if(WSHOpenSocket2 ==NULL) return -1;
  182. return WSHOpenSocket2(family, type, protocol, group, flags, device_name, context,event);
  183. }
  184. int WINAPI myWSHNotify( PVOID context, int sock, HANDLE ao, HANDLE co, DWORD event)
  185. {
  186. HMODULE hMod=GetModuleHandle("WSHTcpip.dll");
  187. if(hMod ==NULL) return -1;
  188. WSHNOTIFY WSHNotify =(WSHNOTIFY)GetProcAddress(hMod, "WSHNotify");
  189. WriteLog("myWSHNotify:event=%d", event);
  190. return WSHNotify(context, sock, ao, co, event);
  191. }
  192. // test hookprocess
  193. int WINAPI myExitProcess(int exit_code)
  194. {
  195. char mod_name[128];
  196. WriteLog("myExitProcess:exit_code=%d", exit_code);
  197. GetModuleFileName(NULL, mod_name, sizeof(mod_name));
  198. if(!strstr(mod_name, "hookprocess"))
  199. {
  200. ExitProcess(exit_code);
  201. }
  202. return 0;
  203. }
  204. DWORD WINAPI myCreateProcessW(
  205. LPCWSTR lpApplicationName,
  206. LPWSTR lpCommandLine, 
  207. LPSECURITY_ATTRIBUTES lpProcessAttributes,
  208. LPSECURITY_ATTRIBUTES lpThreadAttributes,
  209. BOOL bInheritHandles,
  210. DWORD dwCreationFlags,
  211. LPVOID lpEnvironment,
  212. LPCWSTR lpCurrentDirectory,
  213. LPSTARTUPINFOW lpStartupInfo,
  214. LPPROCESS_INFORMATION lpProcessInformation
  215. )
  216. {
  217. char cmd[600];
  218. int len =WideCharToMultiByte( CP_ACP, 0, lpCommandLine, -1, cmd, 128,NULL,NULL); 
  219. cmd[len] =0;
  220. BOOL ifsuccess = CreateProcessW(lpApplicationName,
  221. lpCommandLine, lpProcessAttributes,
  222. lpThreadAttributes, bInheritHandles, dwCreationFlags, lpEnvironment,
  223. lpCurrentDirectory, lpStartupInfo, lpProcessInformation);
  224. DWORD err =GetLastError();
  225. if(ifsuccess)
  226. {
  227. //HWND hWndNotify =FindWindow("HookAPINotify", NULL);
  228. //if(hWndNotify) PostMessage(hWndNotify, WM_APP+100, lpProcessInformation->dwProcessId, 0L);
  229. /*ResumeThread(lpProcessInformation->hThread);
  230. int ret=WaitForInputIdle(lpProcessInformation->hProcess, INFINITE);
  231. ResumeThread(lpProcessInformation->hThread);
  232. HANDLE hProcess=lpProcessInformation->hProcess;
  233. if((int)SuspendThread(lpProcessInformation->hThread) !=-1)
  234. {
  235. //if(is_nt)
  236. {
  237. char szdll[128];
  238. wsprintf(szdll, "%s\mydll.dll", g_szDllPath);
  239. WriteLog("CreateProcessW: InjectLib %s", szdll);
  240. InjectLib(hProcess, szdll, TRUE);
  241. wsprintf(szdll, "%s\HookAPINT.dll", g_szDllPath);
  242. WriteLog("CreateProcessW: InjectLib %s", szdll);
  243. InjectLib(hProcess, szdll, TRUE);
  244. }
  245. ResumeThread(lpProcessInformation->hThread);
  246. }
  247. WriteLog("CreateProcessW:%s, wait ret=%d, processid=%d", cmd, ret,lpProcessInformation->dwProcessId);
  248. */
  249. }
  250. else WriteLog("CreateProcessW failed:%s", cmd);
  251. SetLastError(err);
  252. return (DWORD)ifsuccess;
  253. }
  254. DWORD WINAPI myCreateProcessA(
  255. LPCSTR lpApplicationName,
  256. LPSTR lpCommandLine, 
  257. LPSECURITY_ATTRIBUTES lpProcessAttributes,
  258. LPSECURITY_ATTRIBUTES lpThreadAttributes,
  259. BOOL bInheritHandles,
  260. DWORD dwCreationFlags,
  261. LPVOID lpEnvironment,
  262. LPCSTR lpCurrentDirectory,
  263. LPSTARTUPINFO lpStartupInfo,
  264. LPPROCESS_INFORMATION lpProcessInformation
  265. )
  266. {
  267. WriteLog("myCreateProcessA, cmd=%s", lpCommandLine);
  268. BOOL ifsuccess = CreateProcessA(lpApplicationName, lpCommandLine, lpProcessAttributes,
  269. lpThreadAttributes, bInheritHandles, dwCreationFlags, lpEnvironment,
  270. lpCurrentDirectory, lpStartupInfo, lpProcessInformation);
  271. //WriteLog("CreateProcessA ok! ifsuccess=%d", ifsuccess);
  272. if(ifsuccess)
  273. {
  274. HANDLE hProcess =lpProcessInformation->hProcess;
  275. //if(is_nt)
  276. {
  277. //InjectLib(hProcess, "mydll.dll", TRUE);
  278. //InjectLib(hProcess, "HookAPINT.dll", TRUE);
  279. }
  280. }
  281. else
  282. {
  283. DWORD err;
  284. err =GetLastError();
  285. WriteLog("CreateProcessA failed:err=%d, cmd=%sn", err, lpCommandLine);
  286. SetLastError(err);
  287. }
  288. return (DWORD)ifsuccess;
  289. }
  290. MYAPIINFO myapi_info[] =
  291. {
  292. {"WSOCK32.DLL", "socket(a,b,c)", "mysocket"},
  293. {"WSOCK32.DLL", "accept(a,b,c)", "myaccept"},
  294. {"WSOCK32.DLL", "connect(SOCKET, struct sockaddr *, INT)", "myconnect"},
  295. {"WSOCK32.DLL", "recv(INT, char *, INT, INT)", "myrecv"},
  296. {"WSOCK32.DLL", "send(INT, char *, INT, INT)", "mysend"},
  297. {"WSOCK32.DLL", "sendto(INT, char *, INT, INT, struct sockaddr *, int)", "mysendto"},
  298. {"WSOCK32.DLL", "recvfrom(INT, char *, INT, INT, struct sockaddr *, int)", "myrecvfrom"},
  299. {"WSOCK32.DLL", "gethostbyname(char *)", "mygethostbyname"},
  300. //{"WSHTCPIP.DLL", "WSHOpenSocket(int *, int *, int *, LPWSTR, LPVOID *, LPDWORD)", "myWSHOpenSocket"},
  301. //{"WSHTCPIP.DLL", "WSHOpenSocket2(int *, int *, int *, int, int, LPWSTR, LPVOID *, LPDWORD)", "myWSHOpenSocket2"},
  302. //{"WSHTCPIP.DLL", "WSHNotify(PVOID, int, HANDLE, HANDLE, DWORD)", "myWSHNotify"},
  303. //{"NETAPI32.DLL", "Netbios(PNCB)", "myNetbios"},
  304. //{"KERNEL32.DLL", "LoadLibraryA(char *)", "myLoadLibraryA"},
  305. //{"KERNEL32.DLL", "ExitProcess(int)", "myExitProcess"},
  306. //{"KERNEL32.DLL", "CreateProcessA(1,2,3,4,5,6,7,8,9,10)", "myCreateProcessA"},
  307. //{"KERNEL32.DLL", "CreateProcessW(1,2,3,4,5,6,7,8,9,10)", "myCreateProcessW"},
  308. {NULL,NULL,NULL}
  309. };
  310. MYAPIINFO *GetMyAPIInfo()
  311. {
  312. return &myapi_info[0];
  313. }