专栏首页Eureka伽罗的技术时光轴基于UDP(面向无连接)的socket编程

基于UDP(面向无连接)的socket编程

说明:

本程序是基于windows socket的套接字库实现网络编程; 当WSAStartup函数调用成功后,在程序的最后都需要相应的调用WSACleanup函数 以便释放为该应用程序分配的资源,终止对WinSock动态库的使用。

基于UDP的服务器端流程

创建套接字(socket) 将套接字和IP地址、端口号绑定在一起(bind) 等待客户端发起数据通信(recvfrom/recvto) 关闭套接字

基于UDP的客户端流程

创建套接字(socket) 向服务器发起通信(recvfrom/recvto) 关闭套接字

基于UDP的socket编程流程图

基于UDP的socket编程不需要设置监听和发起/接收请求,可以直接相互通信,流程如下: 这里写图片描述

服务器端代码:

#include "stdafx.h" #include <Winsock2.h>

int _tmain(int argc, _TCHAR* argv[]) { WORD dwVersionReq = MAKEWORD(1,1); WSAData wsData = {0}; //加载套接字库 if (0 != WSAStartup(dwVersionReq,&wsData)) { WSACleanup(); return 0; } //socket版本确认 if (LOBYTE(wsData.wVersion) != 1 || HIBYTE(wsData.wVersion != 1)) { WSACleanup(); return 0; }

//创建服务套接字 SOCKET socketSrv = socket(AF_INET,SOCK_DGRAM,0/*自动选择协议*/);

//对socket绑定端口号和IP地址 SOCKADDR_IN addrServer; addrServer.sin_family = AF_INET; addrServer.sin_port = htons(6000); addrServer.sin_addr.S_un.S_addr = htonl(ADDR_ANY); bind(socketSrv,(SOCKADDR*)&addrServer,sizeof(addrServer));

//保存client端socket信息 SOCKADDR_IN addClient; int len = sizeof(SOCKADDR_IN);

while (1) { //等待并接收数据 char szBuffer[100] = {0}; recvfrom(socketSrv,szBuffer,100,0,(SOCKADDR*)&addClient,&len); printf("client->server:%s\n",szBuffer); //发送数据 char szSendBuf[100] = "this is server"; sendto(socketSrv, szSendBuf, 100,0,(SOCKADDR*)&addClient,len); }

//关闭套接字 closesocket(socketSrv);

//关闭winsocket库 WSACleanup();

system("pause");

return 0; }

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58

客户端代码:

#include "stdafx.h" #include <Winsock2.h>

int _tmain(int argc, _TCHAR* argv[]) { //指定wind socket版本 WORD dwVersionReq = MAKEWORD(1,1); WSAData wsData = {0};

//加载套接字库dll if (0 != WSAStartup(dwVersionReq,&wsData)) { WSACleanup(); return 0; }

//版本判断 if (LOBYTE(wsData.wVersion) != 1 || HIBYTE(wsData.wVersion != 1)) { WSACleanup(); return 0; }

//创建套接字 SOCKET socketClient = socket(AF_INET,SOCK_DGRAM,0);

//填充服务器socket信息 SOCKADDR_IN addrServer; int nLength = sizeof(addrServer); addrServer.sin_family = AF_INET; //服务器的应用程序端口 addrServer.sin_port = htons(6000); //服务器的IP地址,同一台电脑就是本地IP addrServer.sin_addr.S_un.S_addr = inet_addr("127.0.0.1");

//发送数据 char szClientBuf[100]= "this is client"; sendto(socketClient,szClientBuf,100,0,(SOCKADDR*)&addrServer,nLength);

//介绍数据 char szRecvBuf[100] = {0}; recvfrom(socketClient,szRecvBuf,100,0,(SOCKADDR*)&addrServer,&nLength); printf("server->client:%s\n", szRecvBuf);

//关闭套接字 closesocket(socketClient);

//关闭winsocket库 WSACleanup();

system("pause"); return 0; }

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • OD消息断点的设置方法

    使用方法(如): 在当前行按[Shift+F2]键->条件断点(这个不太好用,因为程序BUG偶尔失效)。 在当前行按[Shift+F4]键->条件记录断点(...

    战神伽罗
  • 0x000000fc (ATTEMPTED EXECUTE OF NOEXECUTE MEMORY)

    //断点相关 bp + 地址 设置断点 bl 显示已经设定的断点 bu + 地址 设置断点,但是这种类型断点再下一次启动时被记录 bc 清除断点 ...

    战神伽罗
  • 在gcc中使用intel风格的内联汇编

    很简单,内联汇编使用asm(“.intel_syntax noprefix/n”)声明一下,以后的内联汇编就可以用intel风格了,构建可执行文件时给gcc加上...

    战神伽罗
  • PhantomJS: 一次程序运行无反应的排查过程

    最近刚接触PhantomJS, 听说这工具是一个基于WebKit的服务器端JavaScript API,可以实现绝大部分浏览器的操作, 迫不及待就想练练手.于是...

    Lin_R
  • Android Support Library 的新增功能 | 中文教学视频

    Android 开发者
  • 复习正则

    正则这个东西,说常用也不常用,用到的时候百度一波也够了。早之前对正则还算熟悉,到了后来几乎忘光了。今天重新学一下简单的正则。

    wade
  • ES6中的解构赋值

    ES6解构:es6允许按照一定模式,从数组和对象中提取值,对变量进行赋值,这被称之为解构。

    刘亦枫
  • 【ES6基础】解构赋值(destructuring assignment)

    我们经常可以在其他编程语言(如GO语言)中看到多返回值这种特性,因为在很多实际场景中,函数的返回值中,函数的返回值并不只有一个单一的值。ES6之前,并没有可以直...

    前端达人
  • ES6指北【6】——详谈解构赋值【附赠练习题】

    从定义中,我们可以发现: 解构赋值的作用是对变量进行赋值 主要通过两个方面实现这个作用

    前端博客 : alili.tech
  • ES6(三):变量的解构赋值

    解构赋值语法是一个Javascript表达式,这使得可以将值从数组或属性从对象提取到不同的变量中,文中主要讲数组的解构赋值、对象的解构赋值、字符串的解构赋值、数...

    从入门到进错门

扫码关注云+社区

领取腾讯云代金券