Exemple #1
0
int  CCommunication::CheckHeart4PhoneS1(CBaseSocket  & ttBSocket , SOCKET & sendSocket)
{
	//建立连接
	CString  strShowInfo;

	int nRet = -1;

	nRet = ttBSocket.NoNagleCreateSocket(&sendSocket);
	if(0x00 != nRet)
	{
		nRet = GetLastError();

		strShowInfo.Format(_T("[CCommunication::CheckHeart4PhoneS1] InitializeAndCreateSocket ErrorNo=[%d].\r\n"), nRet);
		XWriteEventLog(strShowInfo);

		m_nExceptionHeart++;
		ttBSocket.CloseSocket( &sendSocket);
		return -2;
	}

	nRet = ttBSocket.ConnectToServer(&sendSocket, CCommunication::m_Port, CCommunication::m_Ip);
	if(0x00 != nRet)
	{	
		Sleep(1000);
		nRet = ttBSocket.ConnectToServer(&sendSocket, CCommunication::m_Port, CCommunication::m_Ip);
		if(nRet != 0x00)
		{
			Sleep(2000);
			nRet = ttBSocket.ConnectToServer(&sendSocket, CCommunication::m_Port, CCommunication::m_Ip);
		}

		if(nRet != 0x00)
		{
			nRet = GetLastError();
			strShowInfo.Format(_T("[CCommunication::CheckHeart4PhoneS1] ConnectToServer IP=[%s] Port =[%d] ErrorNo=[%d].\r\n"), CCommunication::m_Ip,CCommunication::m_Port,nRet);
			XWriteEventLog(strShowInfo);

			m_nExceptionHeart++;
			ttBSocket.CloseSocket( &sendSocket);

			if( 10061 == nRet)
			{
				return -33;
			}
			return -3;
		}
	}
	else
	{
		strShowInfo.Format(_T("[CCommunication::CheckHeart4PhoneS1] ConnectToServer IP=[%s] Port =[%d] Connect OK\r\n"), CCommunication::m_Ip,CCommunication::m_Port);
		XWriteEventLog(strShowInfo);

	}

	//////////////////////////////////////////////////////////////////////
	return  0;

}
Exemple #2
0
int  CCommunication::GetHeart4Phone(CString argRequest, CString& argResponse)
{
	//建立连接
	CString  strShowInfo;
	argResponse.Empty();
	CBaseSocket  OclsBSocket ; 
	CBaseSocket* clsBSocket = &OclsBSocket; 
	//CBaseSocket* clsBSocket = CBaseSocket::GetInstance(); 

	if(NULL == clsBSocket) 
	{
		XWriteEventLog(_T("[CCommunication::GetHeart4Phone] CBaseSocket::GetInstance Failed.\r\n"));
		return -1;
	}

	int nRet = -1;
	SOCKET sendSocket, oldSock;
	nRet = clsBSocket->NoNagleCreateSocket(&sendSocket);
	if(0x00 != nRet)
	{
		nRet = GetLastError();

		strShowInfo.Format(_T("[CCommunication::GetHeart4Phone] InitializeAndCreateSocket ErrorNo=[%d].\r\n"), nRet);
		XWriteEventLog(strShowInfo);

		clsBSocket->CloseSocket( &sendSocket);
		return -2;
	}

	HANDLE hCurProcess = ::GetCurrentProcess();
	BOOL bIsOK = ::DuplicateHandle(
								hCurProcess, (HANDLE)oldSock, 
								hCurProcess, (LPHANDLE)&sendSocket, 
								0x00, FALSE,  ///关闭子进程继承标志
								DUPLICATE_CLOSE_SOURCE);

	if(FALSE == bIsOK)
	{
		sendSocket = oldSock;
		strShowInfo.Format(_T("[CCommunication::GetHeart4Phone] DuplicateHandle Failed\r\n"));
		XWriteEventLog(strShowInfo);
	}

	nRet = clsBSocket->ConnectToServer(&sendSocket, CCommunication::m_Port, CCommunication::m_Ip);
	if(0x00 != nRet)
	{	
		nRet = GetLastError();
		strShowInfo.Format(_T("[CCommunication::GetHeart4Phone] ConnectToServer ErrorNo=[%d].\r\n"), nRet);
		XWriteEventLog(strShowInfo);

		//m_nExceptionHeart++;
		clsBSocket->CloseSocket( &sendSocket);

		if( 10061 == nRet)
		{
			return -33;
		}
		return -3;
	}
	//发送命令
	if( ! argRequest.IsEmpty())
	{
		nRet = clsBSocket->SendMsg(&sendSocket, argRequest);
		if(0x00 != nRet)
		{
			nRet = GetLastError();
			strShowInfo.Format(_T("[CCommunication::GetHeart4Phone] SendMsg ErrorNo=[%d].\r\n"), nRet);
			XWriteEventLog(strShowInfo);

			//m_nExceptionHeart++;
			clsBSocket->CloseSocket( &sendSocket);
			return -4;
		}
	}else
	{
		XWriteEventLog(_T("[CCommunication::GetHeart4Phone] argRequest is Empty.\r\n"));
		return -5;
	}


	//接收返回值
	argResponse = "";
	clsBSocket->RecvMsg( &sendSocket, argResponse);
	//BYTE pRevStrTmp[1024 + 1] = {0};
	//int dword=0, iRevLen = 0;

	//Sleep(200);
	//do
	//{
	//	memset(pRevStrTmp, 0x00, sizeof(pRevStrTmp));
	//	dword = clsBSocket->RecvMsg( &sendSocket, pRevStrTmp, 1024);

	//	if(dword > 0x00 )
	//	{
	//		argResponse += (CHAR*)pRevStrTmp;
	//		iRevLen += dword;
	//		/// 接收完成 GetHeart4Phone
	//		if((-1) != argResponse.Find(_T("</res>"))) dword = 0x00;
	//	}

	//}while( dword != SOCKET_ERROR && dword != 0);

	//if(SOCKET_ERROR != dword)
	//{
	//	m_bPhoneStatus = TRUE;
	//}else
	//{
	//	//m_nExceptionHeart++;
	//	iRevLen = dword;
	//	nRet = GetLastError();
	//	strShowInfo.Format(_T("[CCommunication::GetHeart4Phone]  ErrorNo=[%d].\r\n"), nRet);
	//	XWriteEventLog(strShowInfo);
	//}

	//if(argResponse.IsEmpty())
	//{
	//	strShowInfo.Format(_T("[CCommunication::GetHeart4Phone]  Resp Data is Empty.\r\n"));
	//	XWriteEventLog(strShowInfo);
	//}
	//关闭连接
	clsBSocket->CloseSocket( &sendSocket);
	return  argResponse.GetLength();

}