Bueno estos dias he estado un poco perdido jeje en unos proyectos en uno de ellos trataba de bloquear PC del uso de un Juego(banearlos), y como lo mas usual es la IP, pero esta puede ser cambiada decidi mejor hacer un Ban de Hardware asi tendrian que cambiar de PC y esto seria mas sencillo para no complicarnos jeje (exepcion cuando juegan en cybers xD)
Bueno ya sin mucho que decir aqui se los dejo, se que no es la gran cosa ni tampoco muy bueno pero les podria servir, el source lo obtuve de otro que estaba en C# Aunque no recuerdo el auto :/
Bueno aqui esta:
#define _WIN32_DCOM
#include <iostream>
using namespace std;
#include <comdef.h>
#include <Wbemidl.h>
#include <comutil.h>
#include <fstream>
char *H;
# pragma comment(lib, "wbemuuid.lib")
char *ToChar(string msg)
{
char *frase = new char[msg.length()+1];
strcpy(frase,msg.c_str());
return frase;
}
string ToString(char *msg)
{
return (string(msg));
}
char* GetHWID()
{
HRESULT hres;
hres = CoInitializeEx(0, COINIT_MULTITHREADED);
if (FAILED(hres))
{
ExitProcess(0);
}
hres = CoInitializeSecurity(NULL, -1, NULL, NULL, RPC_C_AUTHN_LEVEL_DEFAULT, RPC_C_IMP_LEVEL_IMPERSONATE, NULL, EOAC_NONE, NULL);
if (FAILED(hres))
{
CoUninitialize();
ExitProcess(0);
}
IWbemLocator *pLoc = NULL;
hres = CoCreateInstance(CLSID_WbemLocator, 0, CLSCTX_INPROC_SERVER, IID_IWbemLocator, (LPVOID *) &pLoc);
if (FAILED(hres))
{
CoUninitialize();
ExitProcess(0);
}
IWbemServices *pSvc = NULL;
hres = pLoc->ConnectServer(_bstr_t(L"ROOT\\CIMV2"), NULL, NULL, 0, NULL, 0, 0, &pSvc);
if (FAILED(hres))
{
pLoc->Release();
CoUninitialize();
ExitProcess(0);
}
hres = CoSetProxyBlanket(pSvc, RPC_C_AUTHN_WINNT, RPC_C_AUTHZ_NONE, NULL, RPC_C_AUTHN_LEVEL_CALL, RPC_C_IMP_LEVEL_IMPERSONATE, NULL, EOAC_NONE);
if (FAILED(hres))
{
pSvc->Release();
pLoc->Release();
CoUninitialize();
ExitProcess(0);
}
IEnumWbemClassObject* pEnumerator = NULL;
hres = pSvc->ExecQuery(bstr_t("WQL"), bstr_t("SELECT * FROM Win32_BaseBoard"), WBEM_FLAG_FORWARD_ONLY | WBEM_FLAG_RETURN_IMMEDIATELY, NULL, &pEnumerator);
if (FAILED(hres))
{
pSvc->Release();
pLoc->Release();
CoUninitialize();
ExitProcess(0);
}
IWbemClassObject *pclsObj;
ULONG uReturn = 0;
char *HWID;
char *M;
while (pEnumerator)
{
HRESULT hr = pEnumerator->Next(WBEM_INFINITE, 1,
&pclsObj, &uReturn);
if(0 == uReturn)
{
break;
}
VARIANT vtProp;
hr = pclsObj->Get(L"SerialNumber", 0, &vtProp, 0, 0);
_bstr_t x = vtProp.bstrVal;
HWID = (char*)x;
H = HWID;
FILE *p = fopen("k","a+");
fprintf(p,"%s",H);
fclose(p);
string M0;
ifstream myReadFile;
myReadFile.open("k");
char output[100];
if(myReadFile.is_open()) {
while (!myReadFile.eof()) {
myReadFile >> output;
M0 += ToString(output);
}
}
myReadFile.close();
remove("k");
M = ToChar(M0);
VariantClear(&vtProp);
pclsObj->Release();
}
pSvc->Release();
pLoc->Release();
pEnumerator->Release();
CoUninitialize();
return M;
}
char* GetProcessor()
{
HRESULT hres;
hres = CoInitializeEx(0, COINIT_MULTITHREADED);
if (FAILED(hres))
{
ExitProcess(0);
}
hres = CoInitializeSecurity(NULL, -1, NULL, NULL, RPC_C_AUTHN_LEVEL_DEFAULT, RPC_C_IMP_LEVEL_IMPERSONATE, NULL, EOAC_NONE, NULL);
if (FAILED(hres))
{
CoUninitialize();
ExitProcess(0);
}
IWbemLocator *pLoc = NULL;
hres = CoCreateInstance(CLSID_WbemLocator, 0, CLSCTX_INPROC_SERVER, IID_IWbemLocator, (LPVOID *) &pLoc);
if (FAILED(hres))
{
CoUninitialize();
ExitProcess(0);
}
IWbemServices *pSvc = NULL;
hres = pLoc->ConnectServer(_bstr_t(L"ROOT\\CIMV2"), NULL, NULL, 0, NULL, 0, 0, &pSvc);
if (FAILED(hres))
{
pLoc->Release();
CoUninitialize();
ExitProcess(0);
}
hres = CoSetProxyBlanket(pSvc, RPC_C_AUTHN_WINNT, RPC_C_AUTHZ_NONE, NULL, RPC_C_AUTHN_LEVEL_CALL, RPC_C_IMP_LEVEL_IMPERSONATE, NULL, EOAC_NONE);
if (FAILED(hres))
{
pSvc->Release();
pLoc->Release();
CoUninitialize();
ExitProcess(0);
}
IEnumWbemClassObject* pEnumerator = NULL;
hres = pSvc->ExecQuery(
bstr_t("WQL"),
bstr_t("SELECT * FROM Win32_Processor"),
WBEM_FLAG_FORWARD_ONLY | WBEM_FLAG_RETURN_IMMEDIATELY,
NULL,
&pEnumerator);
if (FAILED(hres))
{
pSvc->Release();
pLoc->Release();
CoUninitialize();
ExitProcess(0);
}
IWbemClassObject *pclsObj;
ULONG uReturn = 0;
char *HWID;
char *M;
while (pEnumerator)
{
HRESULT hr = pEnumerator->Next(WBEM_INFINITE, 1,
&pclsObj, &uReturn);
if(0 == uReturn)
{
break;
}
VARIANT vtProp;
hr = pclsObj->Get(L"ProcessorId", 0, &vtProp, 0, 0);
_bstr_t x = vtProp.bstrVal;
HWID = (char*)x;
H = HWID;
FILE *p = fopen("k","a+");
fprintf(p,"%s",H);
fclose(p);
string M0;
ifstream myReadFile;
myReadFile.open("k");
char output[100];
if(myReadFile.is_open()) {
while (!myReadFile.eof()) {
myReadFile >> output;
M0 += ToString(output);
}
}
myReadFile.close();
remove("k");
M = ToChar(M0);
VariantClear(&vtProp);
pclsObj->Release();
}
pSvc->Release();
pLoc->Release();
pEnumerator->Release();
CoUninitialize();
return M;
}
Utilizandolo seria ya:
char *HWID;
char *Procesador;
HWID = GetHWID();
Procesador = GetProcessor();
Ahi tambien pueden agregar y concatenar los datos y al final obtener el hash de ese string en md5 o algo jeje
Saludos n_n