»áÔ±£º ÃÜÂ룺 ¡¡Ãâ·Ñ×¢²á | Íü¼ÇÃÜÂë | »áÔ±µÇ¼ ÍøÒ³¹¦ÄÜ£º ¼ÓÈëÊÕ²Ø ÉèΪÊ×Ò³ ÍøÕ¾ËÑË÷  
¼¼ÊõÎĵµ > VCÎĵµ > ÍøÂçͨѶ
ÓÃVC++6.0±àдProxy·þÎñÆ÷
·¢±íÈÕÆÚ£º2004-07-04 15:39:01×÷ÕߣºÍ ³ö´¦£º  

ÎÒÃÇÒ»°ã³£ÓõÄInternet´úÀí·þÎñÆ÷ÊÇÓÃ΢ÈíµÄProxy Server 2.0 ¡£µ«ÎÒÃÇ¿ÉÒÔ×Ô¼º¶¯ÊÖ±àдһ¸ö¼òµ¥¡¢Ð¡Ð͵ÄProxy Server ¡£ÏÂÃæ½éÉܾßÌåµÄʵÏÖ·½·¨¡£

---- Ò»£® Ô­Àí

---- ±¾³ÌÐòµÄ½á¹¹Ô­ÀíÈçÏ£º

---- ¶ÔÓÚÿһ¸öÓû§µÄÇëÇó£¨Internet ÇëÇó£¬ÓÉä¯ÀÀÆ÷·¢³ö£©£¬±¾³ÌÐò½«Æô¶¯Á½¸öỊ̈߳¬Ò»¸ö°Ñ±¾µØÓû§µÄÇëÇóÊý¾Ý·¢Ë͵½Ô¶³ÌµÄInternetÖ÷»ú£¬ÁíÒ»¸öḬ̈߳ÑÔ¶³ÌÖ÷»úµÄ»ØÓ¦Êý¾Ý·¢Ë͵½±¾µØÇëÇóÓû§¡£

---- ¶þ£® Ö÷Òªº¯Êý

  1. UserToProxyThread ( void * pParam ) £ºËüÊÇÓÃÀ´°Ñ±¾µØÓû§ÇëÇóÊý¾Ý·¢Ë͵½Ô¶³ÌÖ÷»úµÄ£¬Æð·þÎñÆ÷Ï߳̽ÇÉ«¡£µ±½Óµ½±¾µØ£¨¾ÖÓòÍø£©Óû§µÄÇëÇó£¬Ëü¾ÍÆô¶¯ÁíÒ»¸ö×ÔÉíỊ̈߳¬ÒÔÕìÌý±ðµÄÓû§µÄÇëÇ󣬲¢¶Á³öÒѽÓÊÕµ½µÄÇëÇóÊý¾Ý£¬½Ó×ÅÆô¶¯µÚ¶þ¸öÏß³ÌProxyToServer()£¨Õâ¸öÏß³ÌÓÃÀ´Á¬½ÓÔ¶³ÌÖ÷»ú£©£¬µ±Ô¶³ÌÖ÷»úÁ¬½Ó³É¹¦ºó£¬Ëü°ÑÒѶÁ³öµÄ±¾µØÓû§ÇëÇóÊý¾Ý·¢Ë͵½Ô¶³ÌÖ÷»ú¡£
  2. ProxyToServer ( void * pParam) £¬¿ÉÒÔ±»µ±×÷ÊÇ¿Í»§¶Ë·þÎñ£¬Ëü°ÑÔ¶³ÌÖ÷»ú·¢ËÍÀ´µÄÊý¾Ý·Ö·¢¸ø±¾µØÇëÇóÓû§¡£
---- Èý£® ¿ª·¢ÔËÐл·¾³

---- ±¾³ÌÐòÊÇÔÚVC++6.0»·¾³Ï¿ª·¢µÄ£¬ÔÚWin95 ºÍ WinNT4.0ÏÂÔËÐÐÕý³£¡£

---- ËÄ£® Ïêϸ´úÂë

#include "stdafx.h"
#include "Proxy.h"
#include < winsock2.h >  //WINSOCKET  API 2¡£0
#include < stdlib.h >
#include < stdio.h >
#include < string.h >

#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif

/////////////////////////////////////////////////////////////////////////////


#define HTTP  "http://"
#define FTP   "ftp://"
#define PROXYPORT    5001    //Proxy ¶Ë¿Ú
#define BUFSIZE   10240      //»º³åÇø´óС


CWinApp theApp;

using namespace std;

UINT ProxyToServer(LPVOID pParam);
UINT UserToProxyThread(void *pParam);

struct SocketPair{
	SOCKET  user_proxy;      //socket : ±¾µØ»úÆ÷µ½PROXY ·þÎñ»ú
	SOCKET  proxy_server;    //socket : PROXY ·þÎñ»úµ½Ô¶³ÌÖ÷»ú
	BOOL    IsUser_ProxyClosed; // ±¾µØ»úÆ÷µ½PROXY ·þÎñ»ú״̬
	BOOL    IsProxy_ServerClosed; // PROXY ·þÎñ»úµ½Ô¶³ÌÖ÷»ú״̬
};


struct ProxyParam{
	char Address[256];    // Ô¶³ÌÖ÷»úµØÖ·
	HANDLE User_SvrOK;    // PROXY ·þÎñ»úµ½Ô¶³ÌÖ÷»úµÄÁª½á״̬
	SocketPair *pPair;    // ά»¤Ò»×éSOCKETµÄÖ¸Õë
	int     Port;         // ÓÃÀ´Áª½áÔ¶³ÌÖ÷»úµÄ¶Ë¿Ú
	};                   //Õâ¸ö½á¹¹ÓÃÀ´PROXY SERVERÓëÔ¶³ÌÖ÷»úµÄÐÅÏ¢½»»».

SOCKET    gListen_Socket;   //ÓÃÀ´ÕìÌýµÄSOCKET¡£

int StartServer()  //Æô¶¯·þÎñ
{
     WSADATA wsaData;
	 sockaddr_in local;
	 SOCKET listen_socket;

	if(::WSAStartup(0x202,&wsaData)!=0)
		{printf("\nError in Startup session.\n");WSACleanup();return -1;};

	local.sin_family=AF_INET;
	local.sin_addr.s_addr=INADDR_ANY;
	local.sin_port=htons(PROXYPORT);

	listen_socket=socket(AF_INET,SOCK_STREAM,0);
	if(listen_socket==INVALID_SOCKET)
		{printf("\nError in New a Socket.");WSACleanup();return -2;}

	if(::bind(listen_socket,(sockaddr *)&local,sizeof(local))!=0)
		{printf("\n Error in Binding socket.");	WSACleanup();return -3;	};

	if(::listen(listen_socket,5)!=0)
		{printf("\n Error in Listen."); WSACleanup(); return -4;}
	gListen_Socket=listen_socket; 
	AfxBeginThread(UserToProxyThread,NULL);   //Æô¶¯ÕìÌý
	return 1;
}

int CloseServer()  //¹Ø±Õ·þÎñ
{
	closesocket(gListen_Socket);
	WSACleanup();
	return 1;
}

//·ÖÎö½ÓÊÕµ½µÄ×Ö·û£¬µÃµ½Ô¶³ÌÖ÷»úµØÖ·
int GetAddressAndPort( char * str, char *address, int * port)
{
	char buf[BUFSIZE], command[512], proto[128], *p;
	int j;
	sscanf(str,"%s%s%s",command,buf,proto);
	p=strstr(buf,HTTP);
	//HTTP
	if(p)
	{
		p+=strlen(HTTP);
		for(int i=0;i< strlen(p);i++)
			if( *(p+i)=='/') break;
		*(p+i)=0;
		strcpy(address,p);
		p=strstr(str,HTTP);
		for(int j=0;j< i+strlen(HTTP);j++)
			*(p+j)=' ';  //È¥µôÔ¶³ÌÖ÷»úÃû: 
                                     //GET http://www.njust.edu.cn/ HTTP1.1  == > GET / HTTP1.1
		*port=80;      //ȱʡµÄ http ¶Ë¿Ú 
	}
	else
	{//FTP, ²»Ö§³Ö, ÏÂÃæµÄ´úÂë¿ÉÒÔÊ¡ÂÔ.
	 p=strstr(buf,FTP);
	 if(!p) return 0;
	 	p+=strlen(FTP);
		for(int i=0;i< strlen(p);i++)
			if( *(p+i)=='/') break;      //Get The Remote Host
		*(p+i)=0;
		for(j=0;j< strlen(p);j++)
			if(*(p+j)==':') 
				{*port=atoi(p+j+1);    //Get The Port
			     *(p+j)=0;
				}
			 else *port=21;		 			              

		strcpy(address,p);
		p=strstr(str,FTP);
		for(j=0;j< i+strlen(FTP);j++)
			*(p+j)=' ';		
	}
	return 1; 
}

// È¡µ½±¾µØµÄÊý¾Ý£¬·¢ÍùÔ¶³ÌÖ÷»ú
UINT UserToProxyThread(void *pParam)
{
	 char Buffer[BUFSIZE];
	 int  Len;
	 sockaddr_in from;
	 SOCKET msg_socket;
	 int fromlen,retval;
	 SocketPair SPair;
	 ProxyParam ProxyP;
	 CWinThread *pChildThread;
     fromlen=sizeof(from);
	 msg_socket=accept(gListen_Socket,(struct sockaddr*)&from,&fromlen);
 	 AfxBeginThread(UserToProxyThread,pParam); //Æô¶¯ÁíÒ»ÕìÌý.
	 if( msg_socket==INVALID_SOCKET)
		{ printf( "\nError  in accept "); return -5;}
	 
	//¶Á¿Í»§µÄµÚÒ»ÐÐÊý¾Ý

	 SPair.IsUser_ProxyClosed=FALSE;
	 SPair.IsProxy_ServerClosed=TRUE;
	 SPair.user_proxy=msg_socket;

	 retval=recv(SPair.user_proxy,Buffer,sizeof(Buffer),0);
	 
	 if(retval==SOCKET_ERROR)
			{ printf("\nError Recv"); 
		      if(SPair.IsUser_ProxyClosed==FALSE)
				{closesocket(SPair.user_proxy);
				 SPair.IsUser_ProxyClosed=TRUE;
				}
			}
	 if(retval==0)
			{printf("Client Close connection\n");
		     if(SPair.IsUser_ProxyClosed==FALSE)
				{closesocket(SPair.user_proxy);
				 SPair.IsUser_ProxyClosed=TRUE;
				}
			}
	 Len=retval;
#ifdef _DEBUG

	 Buffer[Len]=0;
	 printf("\n Received %d bytes,data[%s]from client\n",retval,Buffer);
#endif
	 //
	 SPair.IsUser_ProxyClosed=FALSE;
	 SPair.IsProxy_ServerClosed=TRUE;
	 SPair.user_proxy=msg_socket;

	 ProxyP.pPair=&SPair;
	 ProxyP.User_SvrOK=CreateEvent(NULL,TRUE,FALSE,NULL);
	 
	 GetAddressAndPort( Buffer,ProxyP.Address,&ProxyP.Port);

	 pChildThread=AfxBeginThread(ProxyToServer,(LPVOID)&ProxyP);
	 ::WaitForSingleObject(ProxyP.User_SvrOK,60000);  //µÈ´ýÁª½á
	 ::CloseHandle(ProxyP.User_SvrOK);

  while(SPair.IsProxy_ServerClosed ==FALSE && SPair.IsUser_ProxyClosed==FALSE)
	 {	
	   retval=send(SPair.proxy_server,Buffer,Len,0);
	   if(retval==SOCKET_ERROR)
		{ printf("\n send() failed:error%d\n",WSAGetLastError());
	     if(SPair.IsProxy_ServerClosed==FALSE)
			{
				closesocket(SPair.proxy_server);
				SPair.IsProxy_ServerClosed=TRUE;
			}
		  continue;
		}
	    retval=recv(SPair.user_proxy,Buffer,sizeof(Buffer),0);
	 
		if(retval==SOCKET_ERROR)
			{ printf("\nError Recv"); 
		      if(SPair.IsUser_ProxyClosed==FALSE)
				{closesocket(SPair.user_proxy);
				 SPair.IsUser_ProxyClosed=TRUE;
				}
		      continue;
			}
		if(retval==0)
			{printf("Client Close connection\n");
		     if(SPair.IsUser_ProxyClosed==FALSE)
				{closesocket(SPair.user_proxy);
				 SPair.IsUser_ProxyClosed=TRUE;
				}
			 break;
			}
		Len=retval;
#ifdef _DEBUG
		Buffer[Len]=0;
	 printf("\n Received %d bytes,data[%s]from client\n",retval,Buffer);
#endif
	
  } //End While

     if(SPair.IsProxy_ServerClosed==FALSE)
			{
				closesocket(SPair.proxy_server);
				SPair.IsProxy_ServerClosed=TRUE;
			}
	 if(SPair.IsUser_ProxyClosed==FALSE)
				{closesocket(SPair.user_proxy);
				 SPair.IsUser_ProxyClosed=TRUE;
				}
	::WaitForSingleObject(pChildThread- >m_hThread,20000);  //Should check the return value
	return 0;
}

// ¶ÁÈ¡Ô¶³ÌÖ÷»úÊý¾Ý£¬²¢·¢Íù±¾µØ¿Í»§»ú
UINT ProxyToServer(LPVOID pParam){
    ProxyParam * pPar=(ProxyParam*)pParam;
	char Buffer[BUFSIZE];
	char *server_name= "localhost";
	unsigned short port ;
	int retval,Len;
	unsigned int addr;
	int socket_type ;
	struct sockaddr_in server;
	struct hostent *hp;
	SOCKET  conn_socket;

	socket_type = SOCK_STREAM;
	server_name = pPar- >Address;
	port = pPar- >Port;

	if (isalpha(server_name[0])) {   /* server address is a name */
		hp = gethostbyname(server_name);
	}
	else  { /* Convert nnn.nnn address to a usable one */
		addr = inet_addr(server_name);
		hp = gethostbyaddr((char *)&addr,4,AF_INET);
	}
	if (hp == NULL ) {
		fprintf(stderr,"Client: Cannot resolve address [%s]: Error %d\n",
			server_name,WSAGetLastError());
		::SetEvent(pPar- >User_SvrOK);	
		return 0;
	}

	//
	// Copy the resolved information into the sockaddr_in structure
	//
	memset(&server,0,sizeof(server));
	memcpy(&(server.sin_addr),hp- >h_addr,hp- >h_length);
	server.sin_family = hp- >h_addrtype;
	server.sin_port = htons(port);

	conn_socket = socket(AF_INET,socket_type,0); /* ´ò¿ªÒ»¸ö socket */
	if (conn_socket < 0 ) {
		fprintf(stderr,"Client: Error Opening socket: Error %d\n",
			WSAGetLastError());
		pPar- >pPair- >IsProxy_ServerClosed=TRUE;
		::SetEvent(pPar- >User_SvrOK);	
		return -1;
	}


#ifdef _DEBUG
	printf("Client connecting to: %s\n",hp- >h_name);
#endif
	if (connect(conn_socket,(struct sockaddr*)&server,sizeof(server))
		== SOCKET_ERROR) {
		fprintf(stderr,"connect() failed: %d\n",WSAGetLastError());
		pPar- >pPair- >IsProxy_ServerClosed=TRUE;	
		::SetEvent(pPar- >User_SvrOK);	
		return -1;
	}
	pPar- >pPair- >proxy_server=conn_socket;
	pPar- >pPair- >IsProxy_ServerClosed=FALSE;
    ::SetEvent(pPar- >User_SvrOK);
	// cook up a string to send
	while(!pPar- >pPair- >IsProxy_ServerClosed &&!pPar- >pPair- >IsUser_ProxyClosed)
	{
		retval = recv(conn_socket,Buffer,sizeof (Buffer),0 );
		if (retval == SOCKET_ERROR ) {
			fprintf(stderr,"recv() failed: error %d\n",WSAGetLastError());
			closesocket(conn_socket);
			pPar- >pPair- >IsProxy_ServerClosed=TRUE;
			break;
		}
		Len=retval;
		if (retval == 0) {
			printf("Server closed connection\n");
			closesocket(conn_socket);
			pPar- >pPair- >IsProxy_ServerClosed=TRUE;
			break;
			}

		retval = send(pPar- >pPair- >user_proxy,Buffer,Len,0);
		if (retval == SOCKET_ERROR) {
			fprintf(stderr,"send() failed: error %d\n",WSAGetLastError());
			closesocket(pPar- >pPair- >user_proxy);
			pPar- >pPair- >IsUser_ProxyClosed=TRUE;
			break;						
		}
#ifdef _DEBUG	
		Buffer[Len]=0;		
		printf("Received %d bytes, data [%s] from server\n",retval,Buffer);
#endif
	}
	if(pPar- >pPair- >IsProxy_ServerClosed==FALSE)
			{
				closesocket(pPar- >pPair- >proxy_server);
				pPar- >pPair- >IsProxy_ServerClosed=TRUE;
			}
	 if(pPar- >pPair- >IsUser_ProxyClosed==FALSE)
				{closesocket(pPar- >pPair- >user_proxy);
				 pPar- >pPair- >IsUser_ProxyClosed=TRUE;
				}
	 return 1;
}



int _tmain(int argc, TCHAR* argv[], TCHAR* envp[])
{
	int nRetCode = 0;

	// ³õʼ»¯SOCKET
	if (!AfxWinInit(::GetModuleHandle(NULL), NULL, ::GetCommandLine(), 0))
	{
		// ´íÎó´¦Àí
		cerr < <  _T("Fatal Error: MFC initialization failed") < <  endl;
		nRetCode = 1;
	}
	else
	{
		// Ö÷³ÌÐò¿ªÊ¼.
		StartServer();	
		while(1)	
			if(getchar()=='q') break;
		CloseServer();
	}

	return nRetCode;
}

תÔØÓÚ£º¼ÆËã»úÊÀ½çÈÕ±¨

¡¾·µ»Ø¶¥²¿¡¿ ¡¾´òÓ¡±¾Ò³¡¿ ¡¾¹Ø±Õ´°¿Ú¡¿

¹ØÓÚÎÒÃÇ / ¸øÎÒÁôÑÔ / °æȨ¾Ù±¨ / Òâ¼û½¨Òé / ÍøÕ¾±à³ÌQQȺ   
Copyright ©2003- 2025 Lihuasoft.net webmaster(at)lihuasoft.net ¼ÓÔØʱ¼ä 0.0035