基本信息
源码名称:监听webbrowser所有请求
源码大小:0.71M
文件格式:.zip
开发语言:C/C++
更新时间:2015-05-02
友情提示:(无需注册或充值,赞助后即可获取资源下载链接)
嘿,亲!知识可是无价之宝呢,但咱这精心整理的资料也耗费了不少心血呀。小小地破费一下,绝对物超所值哦!如有下载和支付问题,请联系我们QQ(微信同号):813200300
本次赞助数额为: 4 元×
微信扫码支付:4 元
×
请留下您的邮箱,我们将在2小时内将文件发到您的邮箱
源码介绍
Retrieve HttpOnly Session Cookie in WebBrowser
// Process those modules loaded dynamically, NTSTATUS WINAPI CWininetHook::_LdrLoadDll (IN PWCHAR PathToFile OPTIONAL, IN ULONG Flags OPTIONAL, IN PUNICODE_STRING ModuleFileName, OUT PHANDLE ModuleHandle) { NTSTATUS ntStatus = s_pfnLdrLoadDll ( PathToFile, Flags, ModuleFileName, ModuleHandle); if( ntStatus == STATUS_SUCCESS && (Flags & LOAD_LIBRARY_AS_DATAFILE) == 0 ) { #ifdef _DEBUG if( ModuleFileName->Length > 0 ) { WCHAR wszPath[MAX_PATH] = {0}; memcpy_s( wszPath, MAX_PATH*sizeof(WCHAR), ModuleFileName->Buffer, MAX_PATH*sizeof(WCHAR)); TRACE( L"LdrLoadDll %s\n", wszPath); } #endif HANDLE hDll = *ModuleHandle; ReplaceIATEntryInImageImportTable( hDll, "NTDLL.DLL", s_pfnLdrLoadDll, &CWininetHook::_LdrLoadDll); //...... } return ntStatus; } // Return the user-provided function address instead of the read one NTSTATUS WINAPI CWininetHook::_LdrGetProcedureAddress (IN HMODULE ModuleHandle, IN PANSI_STRING FunctionName OPTIONAL, IN WORD Oridinal OPTIONAL, OUT PVOID *FunctionAddress ) { NTSTATUS ntStatus = s_pfnLdrGetProcedureAddress ( ModuleHandle, FunctionName, Oridinal, FunctionAddress); if( ntStatus == STATUS_SUCCESS ) { TCHAR tszPath[MAX_PATH] = {0}; if( GetModuleFileName( ModuleHandle, tszPath, MAX_PATH) ) { CString strFile(tszPath); int nFind = strFile.ReverseFind('\\'); if( nFind > 0 ) strFile = strFile.Mid(nFind 1); if( strFile.CompareNoCase(_T("WININET.dll")) == 0 ) { CHAR szFunName[1024] = {0}; memcpy( szFunName, FunctionName->Buffer, FunctionName->Length ); #ifdef _DEBUG USES_CONVERSION; TRACE( _T("LdrGetProcedureAddress %s\n"), A2T(szFunName)); #endif TRY_GET_ADDRESS( "HttpSendRequestA", s_pfnHttpSendRequestA, _HttpSendRequestA, PFN_HttpSendRequestA); // ...... } } } return ntStatus; }