📄 xinstall.cpp
字号:
//——————————————————————————————————————
/*
文件: XInstall.cpp
说明:
——————————————————————————
用来安装过滤性质的自定义基础服务提供者。
——————————————————————————
工程: Xfilter 个人防火墙
作者: 朱雁辉,朱雁冰
创建日期: 2001/08/28
网址: http://www.xfilt.com
电子邮件: xstudio@xfilt.com
版权所有 (c) 2001-2002 X 工作室
警告:
——————————————————————————
本电脑程序受著作权法的保护。未经授权,不能使用
和修改本软件全部或部分源代码。凡擅自复制、盗用或散
布此程序或部分程序或者有其它任何越权行为,将遭到民
事赔偿及刑事的处罚,并将依法以最高刑罚进行追诉。
凡通过合法途径购买本软件源代码的用户被默认授权
可以在自己的程序中使用本软件的部分代码,但作者不对
代码产生的任何后果负责。
使用了本软件代码的程序只能以可执行文件形式发布,
未经特别许可,不能将含有本软件源代码的源程序以任何
形式发布。
——————————————————————————
*/
//——————————————————————————————————————
#include "stdafx.h"
#include "XInstall.h"
BOOL CXInstall::IsWinsock2()
{
WORD wVersionRequested = MAKEWORD(2, 0);
WSADATA wsaData;
if(WSAStartup(wVersionRequested, &wsaData) != 0)
return FALSE;
if (LOBYTE(wsaData.wVersion) != 2)
{
WSACleanup();
return FALSE;
}
return TRUE;
}
BOOL CXInstall::IsInstalled(TCHAR *sPathName)
{
TCHAR tsPathName[MAX_PATH];
if( ReadReg(REG_INSTALL_PATH_ITEM,
(BYTE*)tsPathName,
MAX_PATH,
HKEY_LOCAL_MACHINE,
REG_INSTALL_KEY, REG_SZ
)
)
{
if(sPathName != NULL)
_tcscpy(sPathName, tsPathName);
return TRUE;
}
return FALSE;
}
int CXInstall::InstallProvider(TCHAR *sPathName)
{
if(IsInstalled())
return XERR_PROVIDER_ALREADY_INSTALL;
_tcscpy(m_sPathName, sPathName);
int iRet;
if((iRet = EnumHookKey(FALSE)) != XERR_SUCCESS)
return iRet;
if(!SaveReg(REG_INSTALL_PATH_ITEM, (BYTE*)sPathName, _tcslen(sPathName),
HKEY_LOCAL_MACHINE, REG_INSTALL_KEY, REG_SZ))
return XERR_PROVIDER_SAVE_PATH_FAILED;
return XERR_SUCCESS;
}
BOOL CXInstall::RemoveProvider()
{
int iRet = XERR_SUCCESS;
if(!IsInstalled())
return XERR_PROVIDER_NOT_INSTALL;
if(iRet = EnumHookKey(TRUE) != XERR_SUCCESS)
return iRet;
if(!DeleteReg())
return XERR_PROVIDER_REG_DELETE_FAILED;
return XERR_SUCCESS;
}
//****************************************************************************
// 私有安装函数
//****************************************************************************
int CXInstall::EnumHookKey(BOOL IsRemove)
{
HKEY hkey = NULL;
if(RegOpenKeyEx(HKEY_LOCAL_MACHINE
, REG_PROTOCOL_CATALOG_KEY, 0, KEY_READ, &hkey) != ERROR_SUCCESS)
return XERR_PROVIDER_OPEN_REG_FAILED;
__try
{
TCHAR sSubKey[MAX_PATH];
DWORD dwIndex = 0;
int iRet = 0;
while(RegEnumKey(hkey, dwIndex, sSubKey, MAX_PATH) == ERROR_SUCCESS)
{
if((iRet = SaveHookKey(hkey, sSubKey, IsRemove)) != XERR_SUCCESS)
return iRet;
dwIndex ++;
}
}
__finally
{
RegCloseKey(hkey);
}
return XERR_SUCCESS;
}
int CXInstall::SaveHookKey(HKEY hkey, LPCTSTR sSubKey, BOOL IsRemove)
{
HKEY hSubKey = NULL;
BYTE ItemValue [MAX_PROTOCOL_CATALOG_LENTH];
DWORD ItemSize = MAX_PROTOCOL_CATALOG_LENTH;
if(RegOpenKeyEx(hkey
, sSubKey, 0, KEY_ALL_ACCESS, &hSubKey) != ERROR_SUCCESS)
return XERR_PROVIDER_OPEN_REG_FAILED;
__try
{
if(RegQueryValueEx(hSubKey, REG_PROTOCOL_CATALOG_ITEM
, 0, NULL, ItemValue, &ItemSize) != ERROR_SUCCESS
|| (ItemSize != MAX_PROTOCOL_CATALOG_LENTH))
return XERR_PROVIDER_READ_VALUE_FAILED;
WSAPROTOCOL_INFOW *mProtocolInfo
= (WSAPROTOCOL_INFOW*)(ItemValue + MAX_PATH);
if(mProtocolInfo->ProtocolChain.ChainLen == 1
&& mProtocolInfo->iAddressFamily == AF_INET)
{
TCHAR sItem[21];
_stprintf(sItem, _T("%u"), mProtocolInfo->dwCatalogEntryId);
if(!IsRemove)
{
if(!SaveReg(sItem, ItemValue, _tcslen((TCHAR*)ItemValue),
HKEY_LOCAL_MACHINE, REG_INSTALL_KEY, REG_SZ))
return XERR_PROVIDER_CREATE_ITEM_FAILED;
_tcscpy((TCHAR*)ItemValue, m_sPathName);
if(RegSetValueEx(hSubKey, REG_PROTOCOL_CATALOG_ITEM
, 0, REG_BINARY, ItemValue, ItemSize) != ERROR_SUCCESS)
return XERR_PROVIDER_SET_VALUE_FAILED;
}
else
{
TCHAR sProvider[MAX_PATH];
if(!ReadReg(sItem, (BYTE*)sProvider, MAX_PATH,
HKEY_LOCAL_MACHINE, REG_INSTALL_KEY, REG_SZ))
return XERR_PROVIDER_READ_VALUE_FAILED;
_tcscpy((TCHAR*)ItemValue, sProvider);
if(RegSetValueEx(hSubKey, REG_PROTOCOL_CATALOG_ITEM
, 0, REG_BINARY, ItemValue, ItemSize) != ERROR_SUCCESS)
return XERR_PROVIDER_SET_VALUE_FAILED;
}
}
}
__finally
{
RegCloseKey(hSubKey);
}
return XERR_SUCCESS;
}
//****************************************************************************
// 注册表操作函数
//****************************************************************************
BOOL CXInstall::ReadReg(
TCHAR *sKey,
BYTE *pBuffer,
DWORD dwBufSize,
HKEY hkey,
TCHAR *sSubKey,
DWORD ulType
)
{
HKEY hSubkey;
if(RegOpenKeyEx(hkey
, sSubKey, 0, KEY_ALL_ACCESS, &hSubkey) != ERROR_SUCCESS)
return FALSE;
__try
{
DWORD dwType;
if (RegQueryValueEx(hSubkey, sKey
, 0, &dwType, pBuffer, &dwBufSize) == ERROR_SUCCESS
&& dwType == ulType)
return TRUE;
}
__finally
{
RegCloseKey(hSubkey);
}
return FALSE;
}
BOOL CXInstall::SaveReg(
TCHAR *sKey,
BYTE *pBuffer,
DWORD dwBufSize,
HKEY hkey,
TCHAR *sSubKey,
DWORD ulType
)
{
HKEY hSubkey;
DWORD dwDisposition;
if (RegCreateKeyEx(hkey, sSubKey, 0, NULL
, REG_OPTION_NON_VOLATILE, KEY_ALL_ACCESS, NULL
, &hSubkey, &dwDisposition) != ERROR_SUCCESS)
return FALSE;
if (RegSetValueEx(hSubkey
, sKey, 0, ulType, pBuffer, dwBufSize) != ERROR_SUCCESS)
{
RegCloseKey(hSubkey);
return FALSE;
}
RegCloseKey(hSubkey);
return TRUE;
}
BOOL CXInstall::DeleteReg(
HKEY hkey,
TCHAR *sSubKey,
TCHAR *sItem
)
{
if(hkey == NULL || sSubKey == NULL)
return FALSE;
if(sItem == NULL)
{
if(RegDeleteKey(hkey,sSubKey) == ERROR_SUCCESS)
return TRUE;
else
return FALSE;
}
HKEY hSubKey;
if(RegOpenKeyEx(hkey, sSubKey
, 0, KEY_ALL_ACCESS, &hSubKey) != ERROR_SUCCESS)
return FALSE;
__try
{
if(RegDeleteValue(hSubKey, sItem) == ERROR_SUCCESS)
return TRUE;
}
__finally
{
RegCloseKey(hSubKey);
}
return FALSE;
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -