POCO C++ SOCKET

  1. // client program  
  2. #include "Poco/Net/DatagramSocket.h"  
  3. #include "Poco/Net/SocketAddress.h"  
  4. #include "Poco/Timestamp.h"  
  5. #include "Poco/DateTimeFormatter.h"  
  6.   
  7. int testUdpClient(){  
  8.     const char* ipaddr = "192.168.81.140"; //"192.168.81.140"  
  9.     Poco::Net::SocketAddress sa(ipaddr, 5004);  
  10.     Poco::Net::DatagramSocket dgs(Poco::Net::IPAddress::IPv4);  
  11.     dgs.connect(sa);  
  12.     //dgs.bind(sa);  
  13.     std::string syslogMsg;  
  14.     Poco::Timestamp now;  
  15.     syslogMsg = Poco::DateTimeFormatter::format(now, "<14>%w %f %H:%M:%S Hello,world!");  
  16.     dgs.sendBytes(syslogMsg.data(), syslogMsg.size());  
  17.   
  18.     return 0;  
  19. }  
  20.   
  21. /// server program  
  22. #include "Servers.h"  
  23. #include "Poco/Net/DatagramSocket.h"  
  24. #include "Poco/Net/SocketAddress.h"  
  25. #include "Poco/Timestamp.h"  
  26. #include "Poco/DateTimeFormatter.h"  
  27. int testDatagramSocket(){  
  28.     Poco::Net::SocketAddress sa(Poco::Net::IPAddress(), 5004);  
  29.     Poco::Net::DatagramSocket dgs(sa);  
  30.     char buffer[1024]; // 1K byte  
  31.       
  32.     while(1){  
  33.         Poco::Net::SocketAddress sender;  
  34.         int n = dgs.receiveFrom(buffer, sizeof(buffer)-1, sender);  
  35.         buffer[n] = '\0';  
  36.         std::cout << sender.toString() << ":" << buffer << std::endl;  
  37.     }  
  38.   
  39.     return 0;  
  40. }  

tcp

  1. // client program  
  2. #include "Poco/Net/SocketAddress.h"  
  3. #include "Poco/Net/StreamSocket.h"  
  4. #include "Poco/Net/SocketStream.h"  
  5. #include "Poco/StreamCopier.h"  
  6. #include <iostream>  
  7.   
  8. int main(int argc, char** argv){  
  9.     const char* ipaddr = "192.168.81.140"; // the server address.  
  10.     Poco::Net::SocketAddress sa(ipaddr, 5004); // the server port.  
  11.     Poco::Net::StreamSocket socket(sa);  
  12.     Poco::Net::SocketStream str(socket);  
  13.   
  14.     // Writes all bytes readable from str into std::cout, using an internal buffer.  
  15.     Poco::StreamCopier::copyStream(str, std::cout);  
  16.   
  17.     return 0;  
  18. }  
  19.   
  20. // server program  
  21. #include "Poco/Net/ServerSocket.h"  
  22. #include "Poco/Net/StreamSocket.h"  
  23. #include "Poco/Net/SocketStream.h"  
  24. #include "Poco/Net/SocketAddress.h"  
  25.   
  26. int main(int argc, char** argv){  
  27.     Poco::Net::ServerSocket srv(5004); // does bind + listen  
  28.     for(;;){  
  29.         Poco::Net::StreamSocket ss = srv.acceptConnection();  
  30.         Poco::Net::SocketStream str(ss);  
  31.   
  32.         // flush() make sure the file stream is updated with the data.  
  33.         // endl() puts a newline and then uses flush().  
  34.         str << "HTTP/1.0 200 OK\r\n"  
  35.             "Content-Type: text/html\r\n"  
  36.             "\r\n"  
  37.             "<html><head><title>My 1st Web Server</title></head>"  
  38.             "<body><h1>Hello,Wordl!</h1></body></html>"  
  39.             "\r\n"  
  40.             << std::flush;  
  41.     }  
  42.     return 0;  
  43. }  

 

时间: 2024-10-31 01:14:42

POCO C++ SOCKET的相关文章

POCO库中文编程参考指南(3)Poco::Net::Socket

POCO库中文编程参考指南(3)Poco::Net::Socket 作者:柳大·Poechant 博客:Blog.CSDN.net/Poechant 邮箱:zhongchao.ustc#gmail.com (# -> @) 日期:April 14th, 2012 1 SelectMode enum SelectMode /// The mode argument to poll() and select(). { SELECT_READ = 1, SELECT_WRITE = 2, SELECT

C++ POCO库中文编程参考指南(3) Poco::Net::Socket

1 SelectMode enum SelectMode /// The mode argument to poll() and select(). { SELECT_READ = 1, SELECT_WRITE = 2, SELECT_ERROR = 4 }; 2 SocketList typedef std::vector<Socket> SocketList; 3 构造函数 未初始化的 socket: Socket (); 拷贝构造函数 Socket(const Socket&

C++ POCO库中文编程参考指南(8) 丰富的Socket编程

1 POCO 中的 Socket POCO 中有 丰富的 Socket 封装.其继承关系如下: 本文暂且只介绍 StreamSocket.ServerSocket.DatagramSocket 2 Poco::Net::ServerSocket ServerSocket 是一个封装层次比较低(low level)的 Socket,其使用的是 TCP 连接.在实际的 Server 中推荐使用 TCPServer 或 Reactor 框架.下面是例程: #include "Poco/Net/Serv

c++ poco StreamSocket tcpclient测试用例

1.代码 #include <iostream> #include "Poco/Net/Socket.h" #include "Poco/Net/StreamSocket.h" #include "Poco/Net/ServerSocket.h" #include "Poco/Net/SocketAddress.h" #include "Poco/Net/NetException.h" #inc

POCO库中文编程参考指南(8)丰富的Socket编程

POCO库中文编程参考指南(8)丰富的Socket编程 作者:柳大·Poechant 博客:Blog.CSDN.net/Poechant 邮箱:zhongchao.ustc#gmail.com (# -> @) 日期:April 16th, 2012 1 POCO 中的 Socket POCO 中有 丰富的 Socket 封装.其继承关系如下: 本文暂且只介绍 StreamSocket.ServerSocket.DatagramSocket 2 Poco::Net::ServerSocket S

C++ POCO库中文编程参考指南(11) 如何使用Reactor框架?

1 Reactor 框架概述 POCO 中的 Reactor 框架是基于 Reactor 设计模式进行设计的.其中由 Handler 将某 Socket 产生的事件,发送到指定的对象的方法上,作为回调. 2 光说不练假把式 PoechantReactorServer 类,基本与 PoechantTCPServer: class PoechantReactorServer: public ServerApplication { public: PoechantServer() {} //: _he

C++ POCO库中文编程参考指南(10) 如何使用TCPServer框架?

1 TCPServer 框架概述 POCO 库提供TCPServer框架,用以搭建自定义的 TCP 服务器.TCPServer维护一个连接队列.一个连接线程池.连接线程用于处理连接,连接线程只要一空闲就不断地从连接队列中取连接并进行处理.一旦连接线程从连接队列中取到一个连接,就会创建一个TCPServerConnection连接对象,并且调用该对象的start()方法,直到start()方法返回,这个连接对象就被删除了. 连接线程的数量是动态的,其取决于连接队列中排队的连接数.当然,你使用的时候

C++ POCO库中文编程参考指南(5) Poco::Net::SocketAddress

1 枚举 最大地址长度,这个与Poco::Net::IPAddress中的定义可以类 比,不过这里指的是`struct sockaddr_in6 enum { MAX_ADDRESS_LENGTH = #if defined(POCO_HAVE_IPv6) sizeof(struct sockaddr_in6) #else sizeof(struct sockaddr_in) #endif /// Maximum length in bytes of a socket address. }; 2

C++ POCO库中文编程参考指南(4) Poco::Net::IPAddress

1 Poco::Net::IPAddress 地址最大长度,IPv4 是 in_addr 的长度, IPv6 是 in6_addr 的长度 enum { MAX_ADDRESS_LENGTH = #if defined(POCO_HAVE_IPv6) sizeof(struct in6_addr) #else sizeof(struct in_addr) #endif /// Maximum length in bytes of a socket address. }; 1.1 IPv4 or