⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 pcdmutils.cpp

📁 是一本关于
💻 CPP
字号:
// PCDMUtils.cpp : Implementation of CPCDMUtils
#include "stdafx.h"
#include "PCDMDLL.h"
#include "PCDMUtils.h"

/////////////////////////////////////////////////////////////////////////////
// CPCDMUtils
#include "PCDMAccessDB.h"

STDMETHODIMP CPCDMUtils::AnalyzeURL(BSTR bstrURL)
{
int i=0,idx=0;
long CmdClass=0;
BSTR strURL,strCMD;
HRESULT hr;

	while (GetURL(idx,bstrURL,&strURL)==S_OK)
	{
		hr=GetClass(strURL,&CmdClass);
		if (hr==S_OK && CmdClass==PCDMCLASS_ACCESSDB)
		{
			if (GetCommand(strURL,&strCMD)==S_OK)
				ExecuteADBCmd(strCMD);
		}
		idx++;
	}
	return S_OK;
}

STDMETHODIMP CPCDMUtils::GetURL(LONG Index, BSTR InURL, BSTR *OutURL)
{
int pos,oldPos,j;

	pos=0;
	for (j=0;j<Index+1;j++)
	{
		oldPos=pos;
		pos=InstrPos(InURL,pos,TEXT(";"));
		if (pos<0)	break;
	}
	if (pos>0)
		MidStr(InURL,oldPos,pos,OutURL);
	else
		return S_FALSE;
	return S_OK;
}

STDMETHODIMP CPCDMUtils::GetClass(BSTR InURL, LONG *ClassID)
{
BSTR *ClassStr=NULL;
long pos=-1,startpos=-1,endpos=-1;

	pos=InstrPos(InURL,0,TEXT("://"));
	if (pos>=0)
		startpos=InstrPos(InURL,pos,TEXT("/"));
	if (startpos>=0)
		endpos=InstrPos(InURL,startpos,TEXT("?"));
	if (endpos-2>0)
	{
		*ClassID=0L;
		MidStr(InURL,startpos,endpos-2,ClassStr);
		if (CompareString(LOCALE_USER_DEFAULT,NORM_IGNORECASE,*ClassStr,-1,TEXT("PCDMAccessDB"), -1)-2)
			*ClassID=PCDMCLASS_ACCESSDB;
		else if (CompareString(LOCALE_USER_DEFAULT,NORM_IGNORECASE,*ClassStr,-1,TEXT("PCDMAccessReg"), -1)-2)
			*ClassID=PCDMCLASS_ACCESSREG;
		else if (CompareString(LOCALE_USER_DEFAULT,NORM_IGNORECASE,*ClassStr,-1,TEXT("PCDMUtils"), -1)-2)
			*ClassID=PCDMCLASS_UTILS;
		else if (CompareString(LOCALE_USER_DEFAULT,NORM_IGNORECASE,*ClassStr,-1,TEXT("PCDMInput"), -1)-2)
			*ClassID=PCDMCLASS_INPUT;
		else if (CompareString(LOCALE_USER_DEFAULT,NORM_IGNORECASE,*ClassStr,-1,TEXT("PCDMTransfer"), -1)-2)
			*ClassID=PCDMCLASS_TRANSFER;
	}
	return S_OK;
}

STDMETHODIMP CPCDMUtils::GetCommand(BSTR InURL, BSTR *Command)
{
int pos=-1;
	pos=InstrPos(InURL,0,TEXT("?"));
	if (pos>=0)
		MidStr(InURL,pos,lstrlen(InURL),Command);
	else
		return S_FALSE;
	return S_OK;
}

STDMETHODIMP CPCDMUtils::ExecuteADBCmd(BSTR Command)
{
BSTR *Cmd=NULL,*Table=NULL,*Value=NULL;
VARIANT	tValue,tlValue;
TCHAR tStr[20];

	VariantInit(&tValue);
	VariantInit(&tlValue);
	HRESULT hr=GetTagValue(Command,TEXT("Command"),Cmd);
	if (hr==S_OK)
	{
		tValue.vt=VT_BSTR;
		tValue.bstrVal=SysAllocString(*Cmd);
		VariantChangeType(&tlValue,&tValue,0,VT_I4);
		switch (tlValue.lVal)
		{
			case ADBCMD_INSERT:
				{
					int i=0;
					long DBHandle;
					hr=GetTagValue(Command,TEXT("Table"),Table);
					if (hr==S_OK)
					{
						CComObject<CPCDMAccessDB>* comDB = new CComObject<CPCDMAccessDB>();
						HRESULT hr = comDB->FinalConstruct();
						hr=comDB->OpenTable(TEXT("\\My Documents\\PCDM.cdb"),*Table,_variant_t(0L),&DBHandle);
						if (FAILED(hr)) break;
						hr=comDB->AddNewRecord(DBHandle);
						if (FAILED(hr)) break;
						do
						{
							wsprintf(tStr,TEXT("Fld%d"),i);
							hr=GetTagValue(Command,tStr,Value);
							hr=comDB->SetValue(_variant_t((LONG)i),_variant_t(*Value));
							i++;
						} while (hr==S_OK);
						hr=comDB->WriteRecord(DBHandle);
						comDB->CloseTable(DBHandle);
					}

				}
				break;
			default:	// Add more commands here...
				break;
		}
	}

	return S_OK;
}

long CPCDMUtils::InstrPos(TCHAR *InSTR, LONG Start, TCHAR *tChar)
{
unsigned int i;

	if (Start>(long)lstrlen(InSTR)) return -1;
	i=Start;
	while (i<=(lstrlen(InSTR)-lstrlen(tChar)) && CompareString(LOCALE_USER_DEFAULT,NORM_IGNORECASE,&InSTR[i],lstrlen(tChar),tChar, lstrlen(tChar))-2) 
		i++;
	i+=lstrlen(tChar);
	if (i>lstrlen(InSTR)) i=-1;
	return (long)i;
}

BOOL CPCDMUtils::MidStr(TCHAR *InSTR, long StartPos, long EndPos, BSTR *OutSTR)
{
TCHAR tmpStr[500];
long j=0;

	for (int i=StartPos;i++;i<EndPos && i<(long)lstrlen(InSTR))
	{
		tmpStr[j]=InSTR[i];
		j++;
	}
	*OutSTR=SysAllocString(tmpStr);	
	return TRUE;
}

STDMETHODIMP CPCDMUtils::GetTagValue(BSTR InCMD, BSTR TagName, BSTR *TagValue)
{
int pos=0,endpos=-1;
TCHAR tTagName[255];

	wsprintf(tTagName,TEXT("%s="),TagValue);
	pos=InstrPos(InCMD,0,tTagName);
	if (pos>=0)
		endpos=InstrPos(InCMD,pos,TEXT("&"));
	if (endpos-2>0)
		MidStr(InCMD,pos+1,endpos-2,TagValue);
	else
		return S_FALSE;
	return S_OK;
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -