//客户端
#include <iostream>
#include <stdio.h>
#include <windows.h>
#include <string.h>
using namespace std;
#pragma comment(lib, "WS2_32.lib")
class CInitSock
{
public:
CInitSock(int version01 = 2, int versiont02 = 2)
{
WORD sockVersion = MAKEWORD(2, 2);
WSADATA wsaData = {0};
if (WSAStartup(sockVersion, &wsaData) != 0)
{
cout << "initlization failed!" << endl;
exit(0);
}
}
~CInitSock()
{
WSACleanup();
}
};
CInitSock mysock;
int const MAX_SIZE = 1024;
int main()
{
char buffer[MAX_SIZE] = "\0";
sockaddr_in addr = {0};
int nLen = sizeof(sockaddr_in);
SOCKET s;
addr.sin_addr.S_un.S_addr = inet_addr("127.0.0.1");
addr.sin_family = AF_INET;
addr.sin_port = htons(4567);
s = socket(AF_INET, SOCK_DGRAM, IPPROTO_UDP);
while (true)
{
cout << "Please input send data: " << endl;
cin >> buffer;
if ((strcmp(buffer, "quit") == 0) || (strcmp(buffer, "exit")) == 0)
{
cout << "process exit...." << endl;
break;
}
sendto(s, buffer, strlen(buffer), 0, (sockaddr*)&addr, sizeof(addr));
}
}
//服务器端
#include <iostream>
#include <stdio.h>
#include <windows.h>
using namespace std;
#pragma comment(lib, "WS2_32.lib")
class CInitSock
{
public:
CInitSock(int version01 = 2, int versiont02 = 2)
{
WORD sockVersion = MAKEWORD(2, 2);
WSADATA wsaData = {0};
if (WSAStartup(sockVersion, &wsaData) != 0)
{
cout << "initlization failed!" << endl;
exit(0);
}
}
~CInitSock()
{
WSACleanup();
}
};
CInitSock mysock;
int main()
{
SOCKET s = 0;
sockaddr_in sin = {0};
sin.sin_family = AF_INET;
sin.sin_port = htons(4567);
sin.sin_addr.S_un.S_addr = INADDR_ANY;
s = socket(AF_INET, SOCK_DGRAM, IPPROTO_UDP);
if (bind(s, (LPSOCKADDR)&sin, sizeof(sin)) == SOCKET_ERROR)
{
cout << "bind failed!" << endl;
return 0;
}
char buffer[1024] = "\0";
sockaddr_in addr = {0};
int nLen = 0;
nLen = sizeof(sockaddr_in);
cout << "------- now service start -------------" << endl;
while (true)
{
int nRecv = 0;
cout << "wait to receive data............" << endl;
nRecv = recvfrom(s, buffer, 1024, 0, (sockaddr*)&addr, &nLen);
if (nRecv > 0)
{
buffer[nRecv] = '\0';
cout << "receve buffer: " << buffer << endl;
}
}
closesocket(s);
}
分享到:
相关推荐
工具包括服务器端和客户端; 具备用户注册、登录、找回密码功能(基于TCP协议); 两个用户如果同时在线,采用点到点通信方式进行聊天,信息不需要通过服务器中转,服务器也不保存(基于TCP协议); 支持离线消息...
TCP和UDP的通信源码,该源码采用异步通信方式同时解决了TCP传递消息的无边界问题。form1为UDP程序,form2为TCP程序,最后实现程序整合。(该源码通过个人测试没问题,运行时请将服务器端和客户端配合运行)
Android Studio 下写的UDP客户端通信demo ,Gradle打包方式
资源名:VB实现UDP通信程序源码 包含客户端和服务器端 资源类型:程序源代码 源码说明: 用VB实现UDP通讯,有客户端和服务器端。 并且对接收到的数据进行简单处理,为了便于和上位机通讯,并在VB界面上显示处理后的...
可接接受15000多个客户端并发连接 异步TCP服务器、TCP客户端 UDP服务器端和客户端源代码
用C#开发的即时聊天工具。项目包括服务器端和客户端。
c#编写的UDP客户端和服务器端,很好的资源。
实现测试代码:使用Socket编程接口,编写客户端和服务器端的测试代码。这些代码应包含测试用例中涉及的所有操作。 运行测试:启动客户端和服务器端程序,进行实际测试。可以通过手动或自动化方式发送测试数据,并...
socket编程源代码TCPUDP socket编程源代码-包含客户端服务器端,TCP和UDP协议.rar
服务器端,客户端源代码,基于UDP数据发送
本资源分为服务器端和客户端程序及其源代码,服务器端程序后台运行,客户端程序用于查询服务器的IP,使用情景是本地连接了很多诸如嵌入式设备,需要通过telnet之类的方式连接调试,但是又不知道具体IP,就可以使用此...
异步scoket 通讯包含C#服务端 和客户端源码)
MyICQ是一套公开源代码的即时通讯软件,包括服务器端和客户端,可以用于互联网或局域网中。可以运行在Windows或Linux(KDE/Qt)操作系统上,这是Windows版。目前客户端程序的界面完全模仿腾讯的QQ。 基本功能特点 ----...
TCP/UDP网络通讯助手,封装UDP/TCP通信类,服务器端与客户端连接服务及监听/接收/回复(字符/十六进制)。包含源代码(VisualStudio 2010或更高版本编译运行)。(TCP_server/TCP_client/UDP_server/UDP_client/UDP_...
基于socket的UDP通信源代码,用套接字SOCK_DGRAM类型来实现对UDP无连接的通信操作,srv为服务器端,client为客户端。
使用UDP进行局域网通信,使用多台计算机作为抢答终端和题目显示终端,服务器端可判别抢答方、可统计分数、管理题目。同时服务器端模拟了WEB服务器,通过HTTP方式向客户端提供抢答试题。客户端使用浏览器方式显示抢答...
本设计实现了基于UDP协议的客户端和服务器端的一个简单聊天程序设计。包含客户端和服务器端的源代码及相关截图。
摘要:Java源码,网络相关,UDP 基于JAVA的UDP服务器模型源代码,内含UDP服务器端模型和UDP客户端模型两个小程序,向JAVA初学者演示UDP C/S结构的原理。
封装类源代码,其中TCP服务器多线程监听功能、客户端支持断线重连、多线程串口读写、命名管道监听已经实现。UDP、并口等参考后也较容易实现。特别数据包头解析部分,已经支持多种类型:包头(含数据长度)、特殊类型...
通过使用Socket类,开发人员可以创建客户端和服务器端应用程序,并实现它们之间的双向通信。 使用Socket类进行网络编程的基本模式是: 创建一个Socket对象,并指定要使用的协议类型(如TCP或UDP)。 使用Socket...