青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

doing5552

記錄每日點滴,不枉人生一世

  C++博客 :: 首頁 :: 聯系 :: 聚合  :: 管理
  73 Posts :: 0 Stories :: 94 Comments :: 0 Trackbacks

公告

常用鏈接

留言簿(24)

我參與的團隊

最新隨筆

搜索

  •  

積分與排名

  • 積分 - 455899
  • 排名 - 49

最新隨筆

最新評論

閱讀排行榜

評論排行榜

Here, I present the source code for a socket class that faciliates using Sockets in Windows Programming. I also want to say thanks Fabien Le Lez, www.infflux.com and Tamas Kaskoto who have improved this source.
This socket class is being used for BROADCAST chat client.
These are actually four classes: Socket (the base class) from which SocketServer and SocketClient are derived. Also, there is SocketSelect which can be used to do a Select call on more than one Socket. The constructors of Socket are protected; this should be a taken as a hint not to use Socket, but either SocketServer or SocketClient.
When you compile this files, make sure you link them against Ws2_32.lib.
Jump to the header file, the implementation file, the test programm and the Echo Server. Here's also a Proxy and a Web Server.
You can also download the files.
A small description of the socket class: Every program that uses Windows Sockets needs to call WSAStartup. This call is wrapped into Socket::Start, which in turn is called by the Socket's constructor. I pass 2.0 as version here as I expect that version to be installed.
The Socket's constructor also calls socket() (note the small s) which actually creates the socket. It passes the SOCK_STREAM parameter, indicating TCP. If UDP were wished, you'd have to pass SOCK_DGRAM.
SocketClient: SocketClient is inherited from Socket.
The constructor of SocketClient takes a host as parameter, which is the name of the server that this client wishes to communicate to. This name is resolved into an IP Address by gethostbyname().
SocketServer: SocketServer is inherited from Socket.
The constructor of the SocketServer class listens on the port indicated in its parameter. This is made by calling bind().
As SOCK_STREAM type sockets have the ability to queue incoming connection requests, we need to know the maximum number of connections to be queued which can be stated by the connections parameter (and which is passed to listen()).
SocketServer::Accept(): simply waits for an incoming connection request (or removes one from the queue) by calling accept (note the small a).
socket.h
/*
Socket.h
Copyright (C) 2002-2004 René Nyffenegger
This source code is provided 'as-is', without any express or implied
warranty. In no event will the author be held liable for any damages
arising from the use of this software.
Permission is granted to anyone to use this software for any purpose,
including commercial applications, and to alter it and redistribute it
freely, subject to the following restrictions:
1. The origin of this source code must not be misrepresented; you must not
claim that you wrote the original source code. If you use this source code
in a product, an acknowledgment in the product documentation would be
appreciated but is not required.
2. Altered source versions must be plainly marked as such, and must not be
misrepresented as being the original source code.
3. This notice may not be removed or altered from any source distribution.
René Nyffenegger rene.nyffenegger@adp-gmbh.ch
*/
#ifndef SOCKET_H
#define SOCKET_H
#include <WinSock2.h>
#include <string>
enum TypeSocket {BlockingSocket, NonBlockingSocket};
class Socket {
public:
virtual ~Socket();
Socket(const Socket&);
Socket& operator=(Socket&);
std::string ReceiveLine();
std::string ReceiveBytes();
void   Close();
// The parameter of SendLine is not a const reference
// because SendLine modifes the std::string passed.
void   SendLine (std::string);
// The parameter of SendBytes is a const reference
// because SendBytes does not modify the std::string passed
// (in contrast to SendLine).
void   SendBytes(const std::string&);
protected:
friend class SocketServer;
friend class SocketSelect;
Socket(SOCKET s);
Socket();
SOCKET s_;
int* refCounter_;
private:
static void Start();
static void End();
static int  nofSockets_;
};
class SocketClient : public Socket {
public:
SocketClient(const std::string& host, int port);
};
class SocketServer : public Socket {
public:
SocketServer(int port, int connections, TypeSocket type=BlockingSocket);
Socket* Accept();
};
// http://msdn.microsoft.com/library/default.asp?url=/library/en-us/winsock/wsapiref_2tiq.asp
class SocketSelect {
public:
SocketSelect(Socket const * const s1, Socket const * const s2=NULL, TypeSocket type=BlockingSocket);
bool Readable(Socket const * const s);
private:
fd_set fds_;
};
#endif

The implementation file

socket.cpp
/*
Socket.cpp
Copyright (C) 2002-2004 René Nyffenegger
This source code is provided 'as-is', without any express or implied
warranty. In no event will the author be held liable for any damages
arising from the use of this software.
Permission is granted to anyone to use this software for any purpose,
including commercial applications, and to alter it and redistribute it
freely, subject to the following restrictions:
1. The origin of this source code must not be misrepresented; you must not
claim that you wrote the original source code. If you use this source code
in a product, an acknowledgment in the product documentation would be
appreciated but is not required.
2. Altered source versions must be plainly marked as such, and must not be
misrepresented as being the original source code.
3. This notice may not be removed or altered from any source distribution.
René Nyffenegger rene.nyffenegger@adp-gmbh.ch
*/
#include "Socket.h"
#include <iostream>
using namespace std;
int Socket::nofSockets_= 0;
void Socket::Start() {
if (!nofSockets_) {
WSADATA info;
if (WSAStartup(MAKEWORD(2,0), &info)) {
throw "Could not start WSA";
}
}
++nofSockets_;
}
void Socket::End() {
WSACleanup();
}
Socket::Socket() : s_(0) {
Start();
// UDP: use SOCK_DGRAM instead of SOCK_STREAM
s_ = socket(AF_INET,SOCK_STREAM,0);
if (s_ == INVALID_SOCKET) {
throw "INVALID_SOCKET";
}
refCounter_ = new int(1);
}
Socket::Socket(SOCKET s) : s_(s) {
Start();
refCounter_ = new int(1);
};
Socket::~Socket() {
if (! --(*refCounter_)) {
Close();
delete refCounter_;
}
--nofSockets_;
if (!nofSockets_) End();
}
Socket::Socket(const Socket& o) {
refCounter_=o.refCounter_;
(*refCounter_)++;
s_         =o.s_;
nofSockets_++;
}
Socket& Socket::operator=(Socket& o) {
(*o.refCounter_)++;
refCounter_=o.refCounter_;
s_         =o.s_;
nofSockets_++;
return *this;
}
void Socket::Close() {
closesocket(s_);
}
std::string Socket::ReceiveBytes() {
std::string ret;
char buf[1024];
while (1) {
u_long arg = 0;
if (ioctlsocket(s_, FIONREAD, &arg) != 0)
break;
if (arg == 0)
break;
if (arg > 1024) arg = 1024;
int rv = recv (s_, buf, arg, 0);
if (rv <= 0) break;
std::string t;
t.assign (buf, rv);
ret += t;
}
return ret;
}
std::string Socket::ReceiveLine() {
std::string ret;
while (1) {
char r;
switch(recv(s_, &r, 1, 0)) {
case 0: // not connected anymore;
// ... but last line sent
// might not end in \n,
// so return ret anyway.
return ret;
case -1:
return "";
//      if (errno == EAGAIN) {
//        return ret;
//      } else {
//      // not connected anymore
//      return "";
//      }
}
ret += r;
if (r == '\n')  return ret;
}
}
void Socket::SendLine(std::string s) {
s += '\n';
send(s_,s.c_str(),s.length(),0);
}
void Socket::SendBytes(const std::string& s) {
send(s_,s.c_str(),s.length(),0);
}
SocketServer::SocketServer(int port, int connections, TypeSocket type) {
sockaddr_in sa;
memset(&sa, 0, sizeof(sa));
sa.sin_family = PF_INET;
sa.sin_port = htons(port);
s_ = socket(AF_INET, SOCK_STREAM, 0);
if (s_ == INVALID_SOCKET) {
throw "INVALID_SOCKET";
}
if(type==NonBlockingSocket) {
u_long arg = 1;
ioctlsocket(s_, FIONBIO, &arg);
}
/* bind the socket to the internet address */
if (bind(s_, (sockaddr *)&sa, sizeof(sockaddr_in)) == SOCKET_ERROR) {
closesocket(s_);
throw "INVALID_SOCKET";
}
listen(s_, connections);
}
Socket* SocketServer::Accept() {
SOCKET new_sock = accept(s_, 0, 0);
if (new_sock == INVALID_SOCKET) {
int rc = WSAGetLastError();
if(rc==WSAEWOULDBLOCK) {
return 0; // non-blocking call, no request pending
}
else {
throw "Invalid Socket";
}
}
Socket* r = new Socket(new_sock);
return r;
}
SocketClient::SocketClient(const std::string& host, int port) : Socket() {
std::string error;
hostent *he;
if ((he = gethostbyname(host.c_str())) == 0) {
error = strerror(errno);
throw error;
}
sockaddr_in addr;
addr.sin_family = AF_INET;
addr.sin_port = htons(port);
addr.sin_addr = *((in_addr *)he->h_addr);
memset(&(addr.sin_zero), 0, 8);
if (::connect(s_, (sockaddr *) &addr, sizeof(sockaddr))) {
error = strerror(WSAGetLastError());
throw error;
}
}
SocketSelect::SocketSelect(Socket const * const s1, Socket const * const s2, TypeSocket type) {
FD_ZERO(&fds_);
FD_SET(const_cast<Socket*>(s1)->s_,&fds_);
if(s2) {
FD_SET(const_cast<Socket*>(s2)->s_,&fds_);
}
TIMEVAL tval;
tval.tv_sec  = 0;
tval.tv_usec = 1;
TIMEVAL *ptval;
if(type==NonBlockingSocket) {
ptval = &tval;
}
else {
ptval = 0;
}
if (select (0, &fds_, (fd_set*) 0, (fd_set*) 0, ptval) == SOCKET_ERROR)
throw "Error in select";
}
bool SocketSelect::Readable(Socket const* const s) {
if (FD_ISSET(s->s_,&fds_)) return true;
return false;
}

A simple Client

The following simple client connects to www.google.ch and get its front-website.
#include "Socket.h"
#include <iostream>
using namespace std;
int main() {
try {
SocketClient s("www.google.com", 80);
s.SendLine("GET / HTTP/1.0");
s.SendLine("Host: www.google.com");
s.SendLine("");
while (1) {
string l = s.ReceiveLine();
if (l.empty()) break;
cout << l;
cout.flush();
}
}
catch (const char* s) {
cerr << s << endl;
}
catch (std::string s) {
cerr << s << endl;
}
catch (...) {
cerr << "unhandled exception\n";
}
return 0;
}

A simple echo Server

The following simple Server opens a port on 2000 and waits for incoming connections. Each connection is answered with the same line as was written (echoed).
If you want to test the server, use telnet localhost 2000
/*
EchoServer.cpp
Copyright (C) 2002-2004 René Nyffenegger
This source code is provided 'as-is', without any express or implied
warranty. In no event will the author be held liable for any damages
arising from the use of this software.
Permission is granted to anyone to use this software for any purpose,
including commercial applications, and to alter it and redistribute it
freely, subject to the following restrictions:
1. The origin of this source code must not be misrepresented; you must not
claim that you wrote the original source code. If you use this source code
in a product, an acknowledgment in the product documentation would be
appreciated but is not required.
2. Altered source versions must be plainly marked as such, and must not be
misrepresented as being the original source code.
3. This notice may not be removed or altered from any source distribution.
René Nyffenegger rene.nyffenegger@adp-gmbh.ch
*/
#include "Socket.h"
#include <process.h>
#include <string>
unsigned __stdcall Answer(void* a) {
Socket* s = (Socket*) a;
while (1) {
std::string r = s->ReceiveLine();
if (r.empty()) break;
s->SendLine(r);
}
delete s;
return 0;
}
int main(int argc, char* argv[]) {
SocketServer in(2000,5);
while (1) {
Socket* s=in.Accept();
unsigned ret;
_beginthreadex(0,0,Answer,(void*) s,0,&ret);
}
return 0;
}

A Proxy that uses the Socket class

You need the Chameleon class to compile this proxy.
Usage: proxy <port proxy> <addr server> <port server>.
This proxy will then listen on <port proxy> and whenever it receives a connection, relays the traffic to the <port server> of <addr server>. This makes it ideal to see what an SMTP Client exchanges with a SMTP Server, or equally what a NNTP client exchanges with an NNTP Server.
Proxy.cpp
/*
Proxy.cpp
Copyright (C) 2002-2004 René Nyffenegger
This source code is provided 'as-is', without any express or implied
warranty. In no event will the author be held liable for any damages
arising from the use of this software.
Permission is granted to anyone to use this software for any purpose,
including commercial applications, and to alter it and redistribute it
freely, subject to the following restrictions:
1. The origin of this source code must not be misrepresented; you must not
claim that you wrote the original source code. If you use this source code
in a product, an acknowledgment in the product documentation would be
appreciated but is not required.
2. Altered source versions must be plainly marked as such, and must not be
misrepresented as being the original source code.
3. This notice may not be removed or altered from any source distribution.
René Nyffenegger rene.nyffenegger@adp-gmbh.ch
*/
#include "Socket.h"
#include <iostream>
#include <process.h>
#include <sstream>
int         portProxy;
std::string addrServer;
int         portServer;
unsigned __stdcall RunProxyThread (void* a) {
Socket*      s = (Socket*) a;
SocketClient c(addrServer, portServer);
while (1) {
SocketSelect sel(s, &c);
bool still_connected = true;
if (sel.Readable(s)) {
std::string bytes = s->ReceiveBytes();
c.SendBytes(bytes);
std::cout << "Server: " << bytes << std::endl;
if (bytes.empty()) still_connected=false;
}
if (sel.Readable(&c)) {
std::string bytes = c.ReceiveBytes();
s->SendBytes(bytes);
std::cout << "Client: " << bytes << std::endl;
if (bytes.empty()) still_connected=false;
}
if (! still_connected) {
break;
}
}
delete s;
return 0;
}
int main(int argc, char* argv[]) {
if (argc < 4) {
std::cout << "Usage:" << std::endl;
std::cout << "  proxy <port proxy> <addr server> <port server>" << std::endl;
std::cout << std::endl;
std::cout << "  This proxy will then listen on <port proxy> and whenever it receives" << std::endl;
std::cout << "  a connection, relays the traffic to the <port server> of <addr server>." << std::endl;
std::cout << "  This makes it ideal to see what an SMTP Client exchanges with a SMTP Server," << std::endl;
std::cout << "  or equally what a NNTP client exchanges with an NNTP Server." << std::endl << std::endl;
return -1;
}
std::stringstream s;
s<<argv[1]; s>>portProxy; s.clear();
addrServer=argv[2];
s<<argv[3]; s>>portServer;
SocketServer in(portProxy,5);
while (1) {
Socket* s=in.Accept();
unsigned ret;
_beginthreadex(0, 0, RunProxyThread,(void*) s,0,&ret);
}
return 0;
}
See also: Fiddler: a HTTP Debugging Proxy which logs all HTTP traffic between your computer and the Internet. Fiddler allows you to watch HTTP Traffic, set breakpoints, and "fiddle" with incoming or outgoing data. Fiddler is designed to be much simpler than using NetMon or Achilles.

Message Distributor

Message Distributor is a server that listens on port 2000. Any number of clients can connect to that server. When a client sends a message to the server, the server will broadcast this message to all other clients, but not to the one that sent the message.
MsgDistributor.cpp
/*
MsgDistributor.cpp
Copyright (C) 2002-2004 René Nyffenegger
This source code is provided 'as-is', without any express or implied
warranty. In no event will the author be held liable for any damages
arising from the use of this software.
Permission is granted to anyone to use this software for any purpose,
including commercial applications, and to alter it and redistribute it
freely, subject to the following restrictions:
1. The origin of this source code must not be misrepresented; you must not
claim that you wrote the original source code. If you use this source code
in a product, an acknowledgment in the product documentation would be
appreciated but is not required.
2. Altered source versions must be plainly marked as such, and must not be
misrepresented as being the original source code.
3. This notice may not be removed or altered from any source distribution.
René Nyffenegger rene.nyffenegger@adp-gmbh.ch
*/
#include "Socket.h"
#include <process.h>
#include <string>
#include <list>
typedef std::list<Socket*> socket_list;
socket_list g_connections;
unsigned __stdcall Connection(void* a) {
Socket* s = (Socket*) a;
g_connections.push_back(s);
s->SendLine("Welcome to the Message Distributor");
while (1) {
std::string r = s->ReceiveLine();
if (r.empty()) break;
for (socket_list::iterator os =g_connections.begin();
os!=g_connections.end();
os++) {
if (*os != s) (*os)->SendLine(r);
}
}
g_connections.remove(s);
delete s;
return 0;
}
int main() {
SocketServer in(2000,5);
while (1) {
Socket* s=in.Accept();
unsigned ret;
_beginthreadex(0,0,Connection,(void*) s,0,&ret);
}
return 0;
}

Download the files

You can download the source code and the exefiles as a zip file consisting of
  • socket.h
  • Chameleon.h
  • Chameleon.cpp
  • EchoServer.cpp
  • MsgDistributor.cpp
  • Proxy.cpp
  • Socket.cpp
  • EchoServer.exe
  • Proxy.exe
  • makefile
I was able to compile the sources with mingw using the supplied makefile.

Thanks

Thanks to Eugene Wee and Nathan Vander Wilt who helped me improve the socket class.

 

posted on 2010-01-12 20:36 doing5552 閱讀(970) 評論(0)  編輯 收藏 引用
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            日韩视频免费| 激情一区二区| 久热re这里精品视频在线6| 国产视频在线观看一区二区三区| 一本一本a久久| 嫩草国产精品入口| 亚洲午夜91| 亚洲欧洲精品一区二区三区| 亚洲欧美国产不卡| 亚洲最新合集| 亚洲国产精品电影在线观看| 国产亚洲精品资源在线26u| 欧美午夜精品理论片a级按摩| 蜜臀a∨国产成人精品| 欧美一区二区三区另类| 亚洲精品婷婷| 亚洲精品中文字幕女同| 亚洲人成77777在线观看网| 韩日视频一区| 国内精品久久久久久久97牛牛| 欧美精品一区三区| 久热爱精品视频线路一| 欧美在线视频导航| 性欧美大战久久久久久久久| 欧美一区2区三区4区公司二百| 亚洲欧美日韩国产一区二区| 亚洲欧美在线另类| 欧美在线国产精品| 蜜桃av一区二区| 欧美二区不卡| 欧美日韩福利| 国产精品久久久久天堂| 国产一区视频在线观看免费| 国产婷婷成人久久av免费高清| 国产偷国产偷精品高清尤物| 国产一区二区三区最好精华液| 亚洲精品久久久久久久久久久| 亚洲视频综合| 欧美国产视频在线| 亚洲欧美视频一区二区三区| 亚洲一区二区3| 欧美黄色免费| 亚洲国产高清自拍| 久久高清国产| 9色porny自拍视频一区二区| 午夜久久美女| 国产欧美日韩视频| 日韩视频免费看| 美女黄色成人网| 久久精品夜色噜噜亚洲a∨| 国产精品免费看久久久香蕉| 亚洲激精日韩激精欧美精品| 欧美福利视频在线观看| 欧美亚洲在线播放| 国产精品一区二区黑丝| 亚洲在线第一页| 亚洲日韩视频| 亚洲已满18点击进入久久| 亚洲欧美激情四射在线日 | 亚洲人成网站在线观看播放| 99国产精品久久久久久久久久| 午夜一级久久| 一本一本久久a久久精品综合妖精 一本一本久久a久久精品综合麻豆 | 亚洲精品久久久久| 母乳一区在线观看| 在线欧美日韩国产| 免费观看成人| 免播放器亚洲一区| 极品中文字幕一区| 欧美二区在线观看| 欧美一区二区日韩一区二区| 亚洲欧洲在线观看| 国产午夜亚洲精品不卡| 久久一区二区三区av| 老鸭窝毛片一区二区三区| 亚洲黄色一区| 欧美一区二区免费| 99这里只有精品| 亚洲国产专区校园欧美| 国产专区精品视频| 亚洲午夜电影网| 亚洲福利国产精品| 一区二区欧美日韩| 亚洲美女在线观看| 亚洲一区三区在线观看| 欧美二区在线看| 久热精品视频在线| 欧美日韩国产成人高清视频| 欧美人与性动交α欧美精品济南到| 欧美一级专区免费大片| 欧美日韩在线免费视频| 亚洲国产综合91精品麻豆| 精品成人一区二区| 久久综合久久久久88| 久久综合九色综合欧美就去吻 | 久久蜜桃香蕉精品一区二区三区| 国产精品一区二区久久久久| 久久成人羞羞网站| 欧美在线观看视频一区二区| 性感少妇一区| 久久久国产精品一区二区中文 | 久久综合色播五月| 亚洲精品影院| 亚洲丰满在线| 欧美国产丝袜视频| 一区二区毛片| 亚洲经典视频在线观看| 香蕉久久国产| 亚洲国产美女| 性亚洲最疯狂xxxx高清| 亚洲图片欧美午夜| 国产精品亚发布| 久久久免费观看视频| 久久精品男女| 99国内精品久久| 一区二区毛片| 国产一区二区三区视频在线观看| 久久免费国产精品1| 久久久久免费视频| aa日韩免费精品视频一| 亚洲一区中文| 亚洲国产91精品在线观看| 亚洲美女少妇无套啪啪呻吟| 国产精品一级| 免费欧美电影| 国产精品久久久久久久电影| 久久精品免费电影| 午夜视频一区| 国内成人精品2018免费看| 久久免费视频在线| 美腿丝袜亚洲色图| 亚洲欧美色婷婷| 暖暖成人免费视频| 欧美在线视屏 | 亚洲桃花岛网站| 在线成人av网站| 亚洲一区区二区| 99re6热在线精品视频播放速度| 亚洲一区日韩| 99在线|亚洲一区二区| 欧美一区2区三区4区公司二百| 99国产精品99久久久久久| 欧美一级日韩一级| 亚洲一区二区高清| 欧美成人综合网站| 久久久蜜臀国产一区二区| 欧美日韩亚洲系列| 欧美中文在线观看国产| 欧美午夜一区二区福利视频| 国产精品一卡二| 在线视频亚洲一区| 99精品视频免费全部在线| 久久一区二区三区超碰国产精品| 亚洲精品美女| 亚洲伊人第一页| 亚洲一区亚洲二区| 欧美福利一区| 欧美激情导航| 亚洲第一黄网| 美女日韩欧美| 亚洲第一视频网站| 亚洲成人影音| 久久综合九色99| 午夜精品久久久久影视 | 亚洲欧洲日本国产| 亚洲人成在线播放| 亚洲欧美欧美一区二区三区| 国内外成人免费视频| 欧美激情乱人伦| 国产欧美韩国高清| 午夜久久99| 在线播放中文一区| 亚洲一区激情| 亚洲蜜桃精久久久久久久| 亚洲男同1069视频| 亚洲免费av观看| 久久免费黄色| 欧美在线播放| 欧美在线三区| 99综合在线| 亚洲国产欧美一区二区三区久久| 亚洲人成网站在线播| 欧美一区视频在线| 欧美亚洲综合另类| 欧美日韩亚洲一区二区三区在线观看 | 欧美成人一区二区在线| 午夜国产欧美理论在线播放 | 午夜精品国产| 99综合在线| 久久天天综合| 欧美一级视频一区二区| 欧美伦理a级免费电影| 欧美jizz19hd性欧美| 国产欧美一区二区白浆黑人| 一区二区三区www| 欧美激情综合在线| 正在播放欧美视频| 亚洲男人天堂2024| 欧美黄污视频| 亚洲久久成人|