Impl get db names with sql
This commit is contained in:
parent
99b42a2bb1
commit
1f5eae96de
13
App/App.cpp
13
App/App.cpp
@ -20,6 +20,14 @@ void printContacts(ContactMap_t contacts)
|
||||
}
|
||||
}
|
||||
|
||||
void printDbNames(vector<wstring> vDbs)
|
||||
{
|
||||
wprintf(L"db numbers: %ld\n", vDbs.size());
|
||||
for (auto it = vDbs.begin(); it != vDbs.end(); ++it) {
|
||||
wprintf(L"%s\n", (*it).c_str());
|
||||
}
|
||||
}
|
||||
|
||||
int onTextMsg(WxMessage_t msg)
|
||||
{
|
||||
wprintf(L"%s msgType: %d, msgSource: %d, isSelf: %d\n", msg.id.c_str(), msg.type, msg.source, msg.self);
|
||||
@ -71,6 +79,11 @@ int main()
|
||||
// 测试获取联系人
|
||||
auto mContact = WxGetContacts();
|
||||
printContacts(mContact);
|
||||
Sleep(1000); // 等待1秒
|
||||
|
||||
// 测试获取数据库名
|
||||
auto vDbNames = WxGetDbNames();
|
||||
printDbNames(vDbNames);
|
||||
|
||||
while (1) {
|
||||
Sleep(10000); // 休眠,释放CPU
|
||||
|
19
Rpc/rpc.idl
19
Rpc/rpc.idl
@ -19,6 +19,7 @@ interface ISpy
|
||||
BSTR content; // 消息内容,MAC版最大:16384,即16KB
|
||||
} RpcMessage_t;
|
||||
|
||||
// 模拟 map<int, wstring>
|
||||
typedef struct RpcIntBstrPair {
|
||||
int key;
|
||||
BSTR value;
|
||||
@ -27,22 +28,24 @@ interface ISpy
|
||||
typedef RpcIntBstrPair_t **PPRpcIntBstrPair;
|
||||
|
||||
typedef struct RpcContact {
|
||||
BSTR wxId;
|
||||
BSTR wxCode;
|
||||
BSTR wxName;
|
||||
BSTR wxCountry;
|
||||
BSTR wxProvince;
|
||||
BSTR wxCity;
|
||||
BSTR wxGender;
|
||||
BSTR wxId; // 微信ID
|
||||
BSTR wxCode; // 微信号
|
||||
BSTR wxName; // 微信昵称
|
||||
BSTR wxCountry; // 国家
|
||||
BSTR wxProvince; // 省/州
|
||||
BSTR wxCity; // 城市
|
||||
BSTR wxGender; // 性别
|
||||
} RpcContact_t;
|
||||
typedef RpcContact_t *PRpcContact;
|
||||
typedef RpcContact_t **PPRpcContact;
|
||||
|
||||
int IsLogin();
|
||||
int SendTextMsg([ in, string ] const wchar_t *wxid, [ in, string ] const wchar_t *at_wxid, [ in, string ] const wchar_t *msg);
|
||||
int SendTextMsg([ in, string ] const wchar_t *wxid, [ in, string ] const wchar_t *at_wxid,
|
||||
[ in, string ] const wchar_t *msg);
|
||||
int SendImageMsg([ in, string ] const wchar_t *wxid, [ in, string ] const wchar_t *path);
|
||||
int GetMsgTypes([out] int *pNum, [ out, size_is(, *pNum) ] PPRpcIntBstrPair *msgTypes);
|
||||
int GetContacts([out] int *pNum, [ out, size_is(, *pNum) ] PPRpcContact *contacts);
|
||||
int GetDbNames([out] int *pNum, [ out, size_is(, *pNum) ] BSTR **dbs);
|
||||
|
||||
void EnableReceiveMsg();
|
||||
[callback] int ReceiveMsg([in] RpcMessage_t rpcMsg);
|
||||
|
@ -153,6 +153,27 @@ PPRpcContact RpcGetContacts(int *pNum)
|
||||
return ppRpcContacts;
|
||||
}
|
||||
|
||||
BSTR *RpcGetDbNames(int *pNum)
|
||||
{
|
||||
int ret = 0;
|
||||
unsigned long ulCode = 0;
|
||||
BSTR *pBstr = NULL;
|
||||
|
||||
RpcTryExcept { ret = client_GetDbNames(pNum, &pBstr); }
|
||||
RpcExcept(1)
|
||||
{
|
||||
ulCode = RpcExceptionCode();
|
||||
printf("RpcGetDbNames exception 0x%lx = %ld\n", ulCode, ulCode);
|
||||
}
|
||||
RpcEndExcept;
|
||||
if (ret != 0) {
|
||||
printf("RpcGetDbNames Failed: %d\n", ret);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
return pBstr;
|
||||
}
|
||||
|
||||
int server_ReceiveMsg(RpcMessage_t rpcMsg)
|
||||
{
|
||||
WxMessage_t msg;
|
||||
|
@ -1,4 +1,4 @@
|
||||
#pragma once
|
||||
#pragma once
|
||||
|
||||
#include "rpc_h.h"
|
||||
|
||||
@ -11,3 +11,4 @@ int RpcSendTextMsg(const wchar_t *wxid, const wchar_t *at_wxid, const wchar_t *m
|
||||
int RpcSendImageMsg(const wchar_t *wxid, const wchar_t *path);
|
||||
PPRpcIntBstrPair RpcGetMsgTypes(int *pNum);
|
||||
PPRpcContact RpcGetContacts(int *pNum);
|
||||
BSTR *RpcGetDbNames(int *pNum);
|
||||
|
16
SDK/sdk.cpp
16
SDK/sdk.cpp
@ -171,3 +171,19 @@ ContactMap_t WxGetContacts()
|
||||
|
||||
return mContact;
|
||||
}
|
||||
|
||||
std::vector<std::wstring> WxGetDbNames()
|
||||
{
|
||||
std::vector<std::wstring> vDbs;
|
||||
int size = 0;
|
||||
BSTR *pBstr = RpcGetDbNames(&size);
|
||||
for (int i = 0; i < size; i++) {
|
||||
vDbs.push_back(GetWstringFromBstr(pBstr[i]));
|
||||
}
|
||||
|
||||
if (pBstr) {
|
||||
midl_user_free(pBstr);
|
||||
}
|
||||
|
||||
return vDbs;
|
||||
}
|
||||
|
@ -1,7 +1,8 @@
|
||||
EXPORTS
|
||||
EXPORTS
|
||||
WxInitSDK
|
||||
WxSetTextMsgCb
|
||||
WxSendTextMsg
|
||||
WxGetMsgTypes
|
||||
WxSendImageMsg
|
||||
WxGetContacts
|
||||
WxGetDbNames
|
||||
|
16
SDK/sdk.h
16
SDK/sdk.h
@ -3,6 +3,7 @@
|
||||
#include <functional>
|
||||
#include <map>
|
||||
#include <string>
|
||||
#include <vector>
|
||||
|
||||
using namespace std;
|
||||
|
||||
@ -18,13 +19,13 @@ typedef struct WxMessage {
|
||||
} WxMessage_t;
|
||||
|
||||
typedef struct WxContact {
|
||||
wstring wxId;
|
||||
wstring wxCode;
|
||||
wstring wxName;
|
||||
wstring wxCountry;
|
||||
wstring wxProvince;
|
||||
wstring wxCity;
|
||||
wstring wxGender;
|
||||
wstring wxId; // 微信ID
|
||||
wstring wxCode; // 微信号
|
||||
wstring wxName; // 微信昵称
|
||||
wstring wxCountry; // 国家
|
||||
wstring wxProvince; // 省/州
|
||||
wstring wxCity; // 城市
|
||||
wstring wxGender; // 性别
|
||||
} WxContact_t;
|
||||
|
||||
typedef map<int, wstring> MsgTypesMap_t;
|
||||
@ -36,3 +37,4 @@ int WxSendTextMsg(wstring wxid, wstring at_wxid, wstring msg);
|
||||
int WxSendImageMsg(wstring wxid, wstring path);
|
||||
ContactMap_t WxGetContacts();
|
||||
MsgTypesMap_t WxGetMsgTypes();
|
||||
vector<wstring> WxGetDbNames();
|
||||
|
@ -187,6 +187,14 @@ wstring GetWstringFromBstr(BSTR p)
|
||||
return ws;
|
||||
}
|
||||
|
||||
BSTR GetBstrFromWstring(wstring ws)
|
||||
{
|
||||
if (!ws.empty()) {
|
||||
return SysAllocStringLen(ws.data(), ws.size());
|
||||
}
|
||||
return NULL;
|
||||
}
|
||||
|
||||
void GetRpcMessage(WxMessage_t *wxMsg, RpcMessage_t rpcMsg)
|
||||
{
|
||||
wxMsg->self = rpcMsg.self;
|
||||
|
@ -1,9 +1,9 @@
|
||||
#pragma once
|
||||
#pragma once
|
||||
|
||||
#include <string>
|
||||
|
||||
#include "sdk.h"
|
||||
#include "rpc_h.h"
|
||||
#include "sdk.h"
|
||||
|
||||
#define WECHAREXE L"WeChat.exe"
|
||||
#define WECHATWINDLL L"WeChatWin.dll"
|
||||
@ -24,4 +24,5 @@ BSTR GetBstrByAddress(DWORD address);
|
||||
void GetRpcMessage(WxMessage_t *wxMsg, RpcMessage_t rpcMsg);
|
||||
DWORD GetMemoryIntByAddress(HANDLE hProcess, DWORD address);
|
||||
std::wstring GetWstringFromBstr(BSTR p);
|
||||
BSTR GetBstrFromWstring(std::wstring ws);
|
||||
std::wstring GetUnicodeInfoByAddress(HANDLE hProcess, DWORD address);
|
||||
|
@ -166,6 +166,7 @@
|
||||
<ItemGroup>
|
||||
<ClInclude Include="..\Rpc\rpc_h.h" />
|
||||
<ClInclude Include="..\SDK\util.h" />
|
||||
<ClInclude Include="exec_sql.h" />
|
||||
<ClInclude Include="framework.h" />
|
||||
<ClInclude Include="get_contacts.h" />
|
||||
<ClInclude Include="load_calls.h" />
|
||||
@ -180,6 +181,7 @@
|
||||
<ClCompile Include="..\Rpc\rpc_s.c" />
|
||||
<ClCompile Include="..\SDK\util.cpp" />
|
||||
<ClCompile Include="dllmain.cpp" />
|
||||
<ClCompile Include="exec_sql.cpp" />
|
||||
<ClCompile Include="get_contacts.cpp" />
|
||||
<ClCompile Include="load_calls.cpp" />
|
||||
<ClCompile Include="monitor.cpp" />
|
||||
|
@ -48,6 +48,9 @@
|
||||
<ClInclude Include="get_contacts.h">
|
||||
<Filter>头文件</Filter>
|
||||
</ClInclude>
|
||||
<ClInclude Include="exec_sql.h">
|
||||
<Filter>头文件</Filter>
|
||||
</ClInclude>
|
||||
</ItemGroup>
|
||||
<ItemGroup>
|
||||
<ClCompile Include="dllmain.cpp">
|
||||
@ -80,6 +83,9 @@
|
||||
<ClCompile Include="get_contacts.cpp">
|
||||
<Filter>源文件</Filter>
|
||||
</ClCompile>
|
||||
<ClCompile Include="exec_sql.cpp">
|
||||
<Filter>源文件</Filter>
|
||||
</ClCompile>
|
||||
</ItemGroup>
|
||||
<ItemGroup>
|
||||
<Midl Include="..\Rpc\rpc.idl">
|
||||
|
33
Spy/exec_sql.cpp
Normal file
33
Spy/exec_sql.cpp
Normal file
@ -0,0 +1,33 @@
|
||||
#include <map>
|
||||
#include <string>
|
||||
|
||||
#include "exec_sql.h"
|
||||
#include "load_calls.h"
|
||||
|
||||
using namespace std;
|
||||
|
||||
extern WxCalls_t g_WxCalls;
|
||||
extern DWORD g_WeChatWinDllAddr;
|
||||
|
||||
typedef map<wstring, DWORD> dbMap_t;
|
||||
static dbMap_t dbMap;
|
||||
|
||||
vector<wstring> GetDbNames()
|
||||
{
|
||||
vector<wstring> vDbs;
|
||||
if (dbMap.empty()) {
|
||||
DWORD sqlHandleBaseAddr = *(DWORD *)(g_WeChatWinDllAddr + g_WxCalls.sql.base);
|
||||
DWORD sqlHandleBeginAddr = *(DWORD *)(sqlHandleBaseAddr + g_WxCalls.sql.start);
|
||||
DWORD sqlHandleEndAddr = *(DWORD *)(sqlHandleBaseAddr + g_WxCalls.sql.end);
|
||||
while (sqlHandleBeginAddr < sqlHandleEndAddr) {
|
||||
DWORD dwHandle = *(DWORD *)sqlHandleBeginAddr;
|
||||
dbMap[wstring((wchar_t *)(*(DWORD *)(dwHandle + g_WxCalls.sql.name)))]
|
||||
= *(DWORD *)(dwHandle + g_WxCalls.sql.slot);
|
||||
sqlHandleBeginAddr += 0x04;
|
||||
}
|
||||
}
|
||||
for (auto it = dbMap.begin(); it != dbMap.end(); it++) {
|
||||
vDbs.push_back(it->first);
|
||||
}
|
||||
return vDbs;
|
||||
}
|
8
Spy/exec_sql.h
Normal file
8
Spy/exec_sql.h
Normal file
@ -0,0 +1,8 @@
|
||||
#pragma once
|
||||
|
||||
#include <string>
|
||||
#include <vector>
|
||||
|
||||
#include "rpc_h.h"
|
||||
|
||||
std::vector<std::wstring> GetDbNames();
|
@ -1,4 +1,4 @@
|
||||
#include <iostream>
|
||||
#include <iostream>
|
||||
#include <map>
|
||||
|
||||
#include "load_calls.h"
|
||||
@ -13,7 +13,10 @@ WxCalls_t wxCalls = { 0x23631D0, // Login Status
|
||||
{ 0xBD780, 0x770120, 0x521640 }, // Send Image Message
|
||||
/* Get Contacts:
|
||||
Base, head, wxId, Code, Name, Gender, Country, Province, City*/
|
||||
{ 0x23638F4, 0x4C, 0x30, 0x44, 0x8C, 0x184, 0x1D0, 0x1E4, 0x1F8 } };
|
||||
{ 0x23638F4, 0x4C, 0x30, 0x44, 0x8C, 0x184, 0x1D0, 0x1E4, 0x1F8 },
|
||||
/* Exec Sql:
|
||||
Exec, base, start, end, slot, name*/
|
||||
{ 0x141A4D0, 0x2363934, 0x1428, 0x142C, 0x3C, 0x50 } };
|
||||
|
||||
int LoadCalls(const wchar_t *version, WxCalls_t *calls)
|
||||
{
|
||||
|
@ -1,6 +1,7 @@
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
|
||||
#include "exec_sql.h"
|
||||
#include "get_contacts.h"
|
||||
#include "monitor.h"
|
||||
#include "rpc_h.h"
|
||||
@ -8,6 +9,9 @@
|
||||
#include "sdk.h"
|
||||
#include "send_msg.h"
|
||||
#include "spy_types.h"
|
||||
#include "util.h"
|
||||
|
||||
using namespace std;
|
||||
|
||||
extern HANDLE g_hEvent;
|
||||
extern MsgQueue_t g_MsgQueue;
|
||||
@ -82,7 +86,7 @@ int server_GetMsgTypes(int *pNum, PPRpcIntBstrPair *msgTypes)
|
||||
|
||||
int server_GetContacts(int *pNum, PPRpcContact *contacts)
|
||||
{
|
||||
std::vector<RpcContact_t> vContacts = GetContacts();
|
||||
vector<RpcContact_t> vContacts = GetContacts();
|
||||
|
||||
*pNum = vContacts.size();
|
||||
PPRpcContact pp = (PPRpcContact)midl_user_allocate(*pNum * sizeof(RpcContact_t));
|
||||
@ -115,6 +119,26 @@ int server_GetContacts(int *pNum, PPRpcContact *contacts)
|
||||
return 0;
|
||||
}
|
||||
|
||||
int server_GetDbNames(int *pNum, BSTR **dbs)
|
||||
{
|
||||
vector<wstring> vDbs = GetDbNames();
|
||||
*pNum = vDbs.size();
|
||||
BSTR *pp = (BSTR *)midl_user_allocate(*pNum * sizeof(BSTR));
|
||||
if (pp == NULL) {
|
||||
printf("server_GetMsgTypes midl_user_allocate Failed for pp\n");
|
||||
return -2;
|
||||
}
|
||||
|
||||
int index = 0;
|
||||
for (auto it = vDbs.begin(); it != vDbs.end(); it++) {
|
||||
pp[index++] = GetBstrFromWstring(*it);
|
||||
}
|
||||
|
||||
*dbs = pp;
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
RPC_STATUS CALLBACK SecurityCallback(RPC_IF_HANDLE /*hInterface*/, void * /*pBindingHandle*/)
|
||||
{
|
||||
return RPC_S_OK; // Always allow anyone.
|
||||
|
@ -1,4 +1,4 @@
|
||||
#pragma once
|
||||
#pragma once
|
||||
|
||||
#include "framework.h"
|
||||
#include <queue>
|
||||
@ -41,6 +41,15 @@ typedef struct Contact {
|
||||
DWORD wxCity;
|
||||
} Contact_t;
|
||||
|
||||
typedef struct Sql {
|
||||
DWORD exec;
|
||||
DWORD base;
|
||||
DWORD start;
|
||||
DWORD end;
|
||||
DWORD slot;
|
||||
DWORD name;
|
||||
} Sql_t;
|
||||
|
||||
typedef struct WxCalls {
|
||||
DWORD login; // 登录状态
|
||||
UserInfoCall_t ui; // 用户信息
|
||||
@ -48,6 +57,7 @@ typedef struct WxCalls {
|
||||
RecvMsg_t recvMsg; // 接收消息
|
||||
SendImg_t sendImg; // 发送图片
|
||||
Contact_t contact; // 获取联系人
|
||||
Sql_t sql; // 执行 SQL
|
||||
} WxCalls_t;
|
||||
|
||||
typedef struct TextStruct {
|
||||
|
Loading…
Reference in New Issue
Block a user