一、枚舉系統(tǒng)中可用的
無(wú)線網(wǎng)絡(luò)設(shè)備
下面的函數(shù)可以枚舉出系統(tǒng)中所有可用的
無(wú)線網(wǎng)卡設(shè)備的guid,為了簡(jiǎn)化,我選擇第一塊可用的無(wú)線網(wǎng)卡來(lái)操作
bool getfirstwirelesscard(ptchar pcard)
{
if (!pcard)
{
return false;
}
intfs_key_table intfstable;
intfstable.dwnumintfs = 0;
intfstable.pintfs = null;
_tcscpy(pcard, text(""));
// 枚舉系統(tǒng)中可用的無(wú)線網(wǎng)卡
dword dwstatus = wzcenuminterfaces(null, &intfstable);
if (dwstatus != error_success)
{
retailmsg(dbg_msg, (text("wzcenuminterfaces() error 0x%08x\n"),dwstatus));
return false;
}
// 判斷無(wú)線網(wǎng)卡的數(shù)量,可以根據(jù)無(wú)線網(wǎng)卡數(shù)量來(lái)枚舉出所有可用的無(wú)線網(wǎng)卡
if (!intfstable.dwnumintfs)
{
retailmsg(dbg_msg, (text("system has no wireless card.\n")));
return false;
}
_tcscpy(pcard, intfstable.pintfs[0].wszguid);
localfree(intfstable.pintfs);
return true;
}
二、獲取無(wú)線網(wǎng)絡(luò)信息
獲取到了系統(tǒng)可用的無(wú)線網(wǎng)卡后,我們就可以利用它的 guid 號(hào)來(lái)進(jìn)行進(jìn)一步的操作了,首先要做的事情就是得到該無(wú)線網(wǎng)卡的信息以及該無(wú)線網(wǎng)卡掃描到的
wifi 網(wǎng)關(guān)信息。
以下函數(shù)可以獲取到該無(wú)線網(wǎng)卡及掃描的到的無(wú)線 ap 信息
//////////////////////////////////////////////////////////////////////////
// pcard: 無(wú)線網(wǎng)卡 guid
// pintf: 無(wú)線網(wǎng)卡配置信息結(jié)果體
// poutflags: 網(wǎng)卡配置信息掩碼標(biāo)志
//////////////////////////////////////////////////////////////////////////
bool getwirelesscardinfo(ptchar pcard, pintf_entry_ex pintf, pdword poutflags)
{
tchar *szwificard = null;
// 參數(shù)校驗(yàn)
if (!pcard || !pintf || !poutflags)
{
retailmsg(dbg_msg, (text("param error.\n")));
return false;
}
szwificard = pcard;
*poutflags = 0;
// 初始化無(wú)線網(wǎng)卡信息
zeromemory(pintf, sizeof(intf_entry_ex));
// 設(shè)置 guid 號(hào)
pintf->wszguid = szwificard;
// 查詢無(wú)線網(wǎng)卡信息
dword dwstatus = wzcqueryinterfaceex(null, intf_all, pintf, poutflags);
if (dwstatus != error_success)
{
retailmsg(dbg_msg, (text("wzcqueryinterfaceex() error 0x%08x\n"), dwstatus));
return false;
}
return true;
}
三、判斷連接狀態(tài)
我們可以通過(guò)無(wú)線網(wǎng)卡的狀態(tài)來(lái)判斷當(dāng)前無(wú)線網(wǎng)卡是否已經(jīng)和無(wú)線ap建立了連接
bool isassociated(const intf_entry_ex intf, const dword dwoutflags)
{
if (dwoutflags & intf_bssid)
{
praw_data prdmac = (praw_data)(&intf.rdbssid);
// 判斷 bssid 的 mac 地址是否有效來(lái)判斷是否和無(wú)線ap建立了連接
if (prdmac == null || prdmac->dwdatalen == 0 ||
(!prdmac->pdata[0] && !prdmac->pdata[1] && !prdmac->pdata[2] &
!prdmac->pdata[3] && !prdmac->pdata[4] && !prdmac->pdata[5]))
{
retailmsg(dbg_msg, (text("(this wifi card is not associated to any)\n")));
return false;
}
else
{
retailmsg(dbg_msg, (text("(this wifi card is associated state)\n")));
return true;
}
}
else
{
return false;
}
}
四、獲取無(wú)線ap信息
獲取了無(wú)線網(wǎng)卡的信息后,可以通過(guò)無(wú)線網(wǎng)卡枚舉出當(dāng)前所有可用的無(wú)線ap的ssid名稱以及加密模式等等所有可用信息,一下函數(shù)可以實(shí)現(xiàn)該功能
void getwirelseelistssid(const praw_data prdbssidlist, hwnd hlistctlwnd)
{
if (prdbssidlist == null || prdbssidlist->dwdatalen == 0)
{
retailmsg(dbg_msg, (text("<null> entry.\n")));
}
else
{
pwzc_802_11_config_list pconfiglist = (pwzc_802_11_config_list)prdbssidlist->pdata;
//retailmsg(dbg_msg, (text("[%d] entries.\n"), pconfiglist->numberofitems));
uint i;
// 枚舉所有無(wú)線ap
for (i = 0; i < pconfiglist->numberofitems; i++)
{
pwzc_wlan_config pconfig = &(pconfiglist->config[i]);
raw_data rdbuffer;
rdbuffer.dwdatalen = pconfig->ssid.ssidlength;
rdbuffer.pdata = pconfig->ssid.ssid;
tchar tssid[max_path];
// 將 ssid 的 ascii 碼轉(zhuǎn)化成字符串
printssid(&rdbuffer, tssid);
if (hlistctlwnd)
{
if (listbox_findstring(hlistctlwnd, 0, tssid) == lb_err)
{
listbox_addstring(hlistctlwnd, tssid);
}
}
//retailmsg(dbg_msg, (text("\n")));
}
}
}
五、連接到指定的無(wú)線ap
//////////////////////////////////////////////////////////////////////////
// pcard: 無(wú)線網(wǎng)卡 guid
// pssid: 無(wú)線ap ssid號(hào)
// badhoc: 是否點(diǎn)對(duì)點(diǎn)的 wifi 連接
// ulprivacy: 加密模式(wep/wpa....)
// ndismode: 認(rèn)證模式(open/share)
// ikeyindex: 密鑰索引(1-4)
// pkey: 密碼
// ieaptype: 802.11 認(rèn)證模式
//////////////////////////////////////////////////////////////////////////
bool wirelessconnect(ptchar pcard, ptchar pssid, bool badhoc, ulong ulprivacy, ndis_802_11_authentication_mode ndismode, int ikeyindex, ptchar pkey, int ieaptype)
{
bool bret = false;
if (!pssid)
{
retailmsg(dbg_msg, (text("param error.\n")));
return false;
}
else
{
wzc_wlan_config wzcconfig;
zeromemory(&wzcconfig, sizeof(wzc_wlan_config));
wzcconfig.length = sizeof(wzc_wlan_config);
wzcconfig.dwctlflags = 0;
wzcconfig.ssid.ssidlength = _tcslen(pssid);
for (uint i = 0; i < wzcconfig.ssid.ssidlength; i++)
{
wzcconfig.ssid.ssid[i] = (char)pssid[i];
}
if (badhoc)
{
wzcconfig.infrastructuremode = ndis802_11ibss;
}
else
{
wzcconfig.infrastructuremode = ndis802_11infrastructure;
}
wzcconfig.authenticationmode = ndismode;
wzcconfig.privacy = ulprivacy;
if (pkey == null || _tcslen(pkey) == 0)
{
// 對(duì)密鑰進(jìn)行轉(zhuǎn)換
bret = interpretencryptionkeyvalue(wzcconfig, 0, null, true);
wzcconfig.eapolparams.dweaptype = ieaptype;
wzcconfig.eapolparams.dweapflags = eapol_enabled;
wzcconfig.eapolparams.benable8021x = true;
wzcconfig.eapolparams.dwauthdatalen = 0;
wzcconfig.eapolparams.pbauthdata = 0;
}
else
{
retailmsg(dbg_msg, (text("wirelessconnect ikeyindex = %d.\n"), ikeyindex));
bret = interpretencryptionkeyvalue(wzcconfig, ikeyindex, pkey, false);
}
// 連接到指定的無(wú)線ap,并將該ap添加到首先無(wú)線ap中
addtopreferrednetworklist(pcard, wzcconfig, pssid);
}
return bret;
}
六、密鑰轉(zhuǎn)換
輸入的密鑰需要通過(guò)加密方式進(jìn)行一定的轉(zhuǎn)化,以下函數(shù)可以完成改功能
static void encryptwepkmaterial(in out wzc_wlan_config* pwzcconfig)
{
byte chfakekeymaterial[] = { 0x56, 0x09, 0x08, 0x98, 0x4d, 0x08, 0x11, 0x66, 0x42, 0x03, 0x01, 0x67, 0x66 };
for (int i = 0; i < wzcctl_max_wepk_material; i++)