Please visit our sponsor
UNKNOWN
//**************************************
// Name: CHTTPSocket - Direct/ViaProxy - Reusable Class
// Description:CHTTPSocket class with full source code,
full qualified, one step, HTTP client. Can fetch pages from web, no problems
if You try virtual host. If You use proxy server, only set some variables and
get it worked also. I also compile sample application which You can download
and test.
// By: ATM
//
//
// Inputs:None
//
// Returns:None
//
//Assumes:None
//
//Side Effects:None
//This code is copyrighted and has limited warranties.
//Please see http://www.Planet-Source-Code.com/xq/ASP/txtCodeId.270/lngWId.3/qx/vb/scripts/ShowCode.htm
//for details.
//**************************************
//Download full source code from:
// http://www.tair.freeservers.com/
#include
#include "httpsocket.h"
/************************************************************************
Sample derived class
************************************************************************/
class CMySock : public CHTTPSocket
{
char szErrMessage[255];
public:
void OnError();
void OnResponse();
};
//error trigger
void CMySock::OnError()
{
wsprintf(szErrMessage,"Error: %d, %d, %s",m_nErrCode,m_nExtErrCode,m_nErrInfo);
MessageBox(NULL,szErrMessage,"Error",MB_OK);
CHTTPSocket::OnError();
};
//response trigger
void CMySock::OnResponse()
{
printf("----m_ulResponseSize=%d\r\n",m_ulResponseSize);
printf("%s\r\n",(char *)m_szResponse);
CHTTPSocket::OnResponse();
};
//-----------------------------------------------------------------------
//call style:
//-----------------------------------------------------------------------
// dts.exe /URL http://www.yahoo.com [/PRX 127.0.0.1] [/PRT 8080]
//-----------------------------------------------------------------------
// where /URL - U see
///PRX - proxy's internet address
///PRT - proxy's port
//-----------------------------------------------------------------------
// You must have KERNEL32.DLL, USER32.DLL and WS2_32.DLL installed.
//-----------------------------------------------------------------------
/************************************************************************
main. entry point for service
************************************************************************/
void main(int argc,char* argv[])
{
CMySock cs;
cs.m_bUseProxy=FALSE;
int i=0;
char* page=NULL;
char* serverHost=NULL;
char* serverPort=NULL;
while(i
//rem next line if no debug dump wanted
#define DEBON
#include
//default send and recieve timeouts in sec
#define HTTPRTIMEOUTDEF 90000
#define HTTPSTIMEOUTDEF 90000
#define MAXHOSTLENGTH65
#define MAXIPLENGTH 16
#define MAXBLOCKSIZE1024
#define MAXURLLENGTH255
#define MAXHEADERLENGTH 269
//primary error codes
#define ERR_OK0
//if this error occurs, extended code is WSA's error code
#define ERR_WSAINTERNAL 1
#define ERR_URLNOTHING2
#define ERR_URLTOOLONG3
#define ERR_HOSTUNKNOWN 4
#define ERR_PROXYUNKNOWN 5
#define ERR_PROTOPARSE6
#define ERR_BADHOST 7
#define ERR_BADPORT 8
class CHTTPSocket
{
static int nInstanceCount;
SOCKET sckHTTPSocket;
struct sockaddr_in sinHTTPSocket;
struct sockaddr_in sinHTTPServer;
// remote server host address, size 64 bytes, 65th set to \0
char m_szServerHost[MAXHOSTLENGTH];
// host
char m_szHost[MAXHOSTLENGTH];
// requested URI/URL
char m_szURL[MAXURLLENGTH];
// remote server IP address, size 15 bytes, 16th set to \0
char m_szServerHostIP[MAXIPLENGTH];
//-- Win32 specific
WSADATAwsaData;
void szcopy(char* dest,const char* src,int nMaxBytes);
void szsent(SOCKET sckDest,const char* szHttp);
public:
// set to TRUE in InitInstance if TIME_WAIT not need ()
BOOL m_bNoTimeWait;
// recieve timeout change in InitInstance
intm_nRecvTimeout;
// send timeout change in InitInstance
intm_nSendTimeout;
// remote server port
int m_nServerPort;
// use proxy flag
BOOL m_bUseProxy;
// error code
int m_nErrCode;
// extended error code;
int m_nExtErrCode;
// error info
char m_nErrInfo[255];
// response content
LPVOID m_szResponse;
// response size
ULONG m_ulResponseSize;
public:
//const/destr
CHTTPSocket();
virtual ~CHTTPSocket();
//utils
// sets proxy or http server's host
void SetServerHost(const char* src);
// sets proxy or http server's ip
//(should be skipped if SetServerHost used)
void SetServerHostIP(const char* src);
//starts request transaction
void Request(const char* url="http://www.tair.freeservers.com");
//used for free memory allocated for page
//(should be skipped if You use CHTTPSocket::OnResponse call in OnResponse)
void memPostup();
//fire your OnError with specific error cdes and message
void ThrowError(int err, int xerr, const char* errdesc);
//overridable
//shoul be used for additional inits
virtual BOOL InitInstance();
//trigger on any transaction error
//(its great if U will call CHTTPSocket::OnError inside,
//to free allocated memory pages)
virtual void OnError();
//trigger on response recieved
//(its great if U will call CHTTPSocket::OnResponse inside,
//to free allocated memory pages)
virtual void OnResponse();
};
#endif