运行截图

客户端

  • 创建客户端套接字,用于创建UDP通信

     SOCKET socket_client;
  • 创建UDP通信
     socket_client = socket(AF_INET, SOCK_DGRAM, );
  • 创建客户端结构体保存ip地址以及端口号
     SOCKADDR_IN sever;
  • 设置通信模式,通信地址以及通信端口
         //设置通信模式
    sever.sin_family = AF_INET;
    //设置通信地址
    sever.sin_addr.S_un.S_addr = inet_addr("192.168.0.104");
    //开启通信端口
    sever.sin_port = htons();
  • 创建字符串用于发送信息
         //存储获取的字符串
    char strreceive[] = { };
    //获取的字符串长度
    int length;
  • 获取字符串并通过套接字发送到相应的ip地址
     //不断进行数据交换
    while ()
    {
    char str[] = { };
    fgets(str, , stdin);
    //通过套接字发送信息到服务器
    sendto(socket_client, str, strlen(str) + , , &sever, sizeof(SOCKADDR));
    }
  • 套接字检测版本信息
     //UDP版本,2,2版本
    WORD wversion=MAKEWORD(,);
    //当前版本
    WSADATA wsadata;
    //获取版本对比,开始通信
    int error = WSAStartup(wversion, &wsadata); //如果版本与指定的不对则返回
    if (error!=)
    {
    printf("error");
    return;
    } //取出低八位与高八位进行版本对比
    if (LOBYTE(wsadata.wVersion) != || HIBYTE(wsadata.wVersion) != )
    {
    printf(" version error");
    return;
    }
  • 关闭套接字
         //关闭
    closesocket(socket_client);
    //关闭
    WSACleanup();

客户端完整代码

 #define  _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include <stdlib.h>
#include <string.h>
//网络通信
#include<winsock.h>
#pragma comment(lib,"ws2_32.lib") void main()
{
//存储获取的字符串
char strreceive[] = { };
//获取的字符串长度
int length;
//客户端的套接字,用于创建UDP通信
SOCKET socket_client;
//创建客户端结构体保存ip地址以及端口号
SOCKADDR_IN sever;
SOCKADDR_IN severTmp; //UDP版本,2,2版本
WORD wversion=MAKEWORD(,);
//当前版本
WSADATA wsadata;
//获取版本对比,开始通信
int error = WSAStartup(wversion, &wsadata); //如果版本与指定的不对则返回
if (error!=)
{
printf("error");
return;
} //取出低八位与高八位进行版本对比
if (LOBYTE(wsadata.wVersion) != || HIBYTE(wsadata.wVersion) != )
{
printf(" version error");
return;
}
//创建UDP通信
socket_client = socket(AF_INET, SOCK_DGRAM, ); //设置通信模式
sever.sin_family = AF_INET;
//设置通信地址
sever.sin_addr.S_un.S_addr = inet_addr("192.168.0.104");
//开启通信端口
sever.sin_port = htons(); //打开文件
FILE *pfr = fopen("1.txt", "rb");
//不断进行数据交换
while ()
{
char str[] = { };
fgets(str, , stdin);
//通过套接字发送信息到服务器
sendto(socket_client, str, strlen(str) + , , &sever, sizeof(SOCKADDR)); } //关闭
closesocket(socket_client);
//关闭
WSACleanup(); system("pause");
}

服务器端

  • 创建服务器端套接字,用于创建UDP通信

     //服务器套接字,创建UDP通信
    SOCKET socket_send;
  • 创建UDP通信
     socket_send = socket(AF_INET, SOCK_DGRAM, );
  • 创建服务器端结构体保存ip地址以及端口号
     SOCKADDR_IN server;
  • 设置通信模式,通信地址以及通信端口
     //设置通信方式
    server.sin_family = AF_INET;
    //获取本地ip信息
    server.sin_addr.S_un.S_addr = htonl(INADDR_ANY);
    server.sin_port = htons();//端口
  • 把服务器的ip信息和端口信息与服务器套接字绑定,接收该地址收到的内容
     bind(socket_send, &server, sizeof(SOCKADDR));
  • 保存是谁发来的信息的ip
     SOCKADDR_IN client;
  • 创建字符串用于接收
     //存储获取的字符串
    char strreceive[] = { };
    //存储获取的长度
    int length;
  • 通过套接字获取
     //获取长度
    length = sizeof(SOCKADDR);
    while ()
    {
    //通过服务器套接字接受信息
    recvfrom(socket_send, strreceive, , , &client, &length);
    if (strlen(strreceive) > )
    {
    printf("收到%s\n", strreceive);
    printf("%d\n", client.sin_addr.S_un.S_addr);
    memset(strreceive, , );
    }
    }
  • 版本检测
     //版本,2,2版本
    WORD wversion = MAKEWORD(, );
    //当前版本
    WSADATA wsadata;
    //获取版本对比,开始通信
    int error = WSAStartup(wversion, &wsadata); //如果版本与指定的不对则返回
    if (error != )
    {
    printf("error");
    return;
    } //取出低八位,高八位,对比版本
    if (LOBYTE(wsadata.wVersion) != || HIBYTE(wsadata.wVersion) != )
    {
    printf(" version error");
    return;
    }
  • 关闭
     closesocket(socket_send);//关闭
    WSACleanup();

完整代码

 #define  _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include <stdlib.h>
#include <string.h>
//网络通信
#include<winsock.h>
#pragma comment(lib,"ws2_32.lib") void main()
{
//存储获取的字符串
char strreceive[] = { };
//存储获取的长度
int length;
//服务器套接字,创建UDP通信
SOCKET socket_send;
//创建服务器端结构体保存ip地址以及端口号
SOCKADDR_IN server;
//保存是谁发来的信息的ip
SOCKADDR_IN client; //版本,2,2版本
WORD wversion = MAKEWORD(, );
//当前版本
WSADATA wsadata;
//获取版本对比,开始通信
int error = WSAStartup(wversion, &wsadata); //如果版本与指定的不对则返回
if (error != )
{
printf("error");
return;
} //取出低八位,高八位,对比版本
if (LOBYTE(wsadata.wVersion) != || HIBYTE(wsadata.wVersion) != )
{
printf(" version error");
return;
} //创建UDP通信
socket_send = socket(AF_INET, SOCK_DGRAM, ); //设置通信方式
server.sin_family = AF_INET;
//获取本地ip信息
server.sin_addr.S_un.S_addr = htonl(INADDR_ANY);
server.sin_port = htons();//端口 //把服务器的ip信息和端口信息与服务器套接字绑定
bind(socket_send, &server, sizeof(SOCKADDR));
//获取长度
length = sizeof(SOCKADDR);
while ()
{
//通过服务器套接字接受信息
recvfrom(socket_send, strreceive, , , &client, &length);
if (strlen(strreceive) > )
{
printf("收到%s\n", strreceive);
printf("%d\n", client.sin_addr.S_un.S_addr);
memset(strreceive, , );
}
} closesocket(socket_send);//关闭
WSACleanup(); system("pause"); }

96.udp通信的更多相关文章

  1. vector(可变数组) 用于UDP通信

    头文件: #include<vector.h> 然后,声明并初始化vctor数组. vector<char>  str(len); 其中len可以是变量或者常量.(其实用常量就 ...

  2. 高性能 TCP & UDP 通信框架 HP-Socket v3.5.3

    HP-Socket 是一套通用的高性能 TCP/UDP 通信框架,包含服务端组件.客户端组件和 Agent 组件,广泛适用于各种不同应用场景的 TCP/UDP 通信系统,提供 C/C++.C#.Del ...

  3. 高性能 TCP & UDP 通信框架 HP-Socket v3.5.2

    HP-Socket 是一套通用的高性能 TCP/UDP 通信框架,包含服务端组件.客户端组件和 Agent 组件,广泛适用于各种不同应用场景的 TCP/UDP 通信系统,提供 C/C++.C#.Del ...

  4. 高性能 TCP & UDP 通信框架 HP-Socket v3.5.1

    HP-Socket 是一套通用的高性能 TCP/UDP 通信框架,包含服务端组件.客户端组件和 Agent 组件,广泛适用于各种不同应用场景的 TCP/UDP 通信系统,提供 C/C++.C#.Del ...

  5. 高性能 TCP & UDP 通信框架 HP-Socket v3.4.1

    HP-Socket 是一套通用的高性能 TCP/UDP 通信框架,包含服务端组件.客户端组件和 Agent 组件,广泛适用于各种不同应用场景的 TCP/UDP 通信系统,提供 C/C++.C#.Del ...

  6. 高性能 TCP & UDP 通信框架 HP-Socket v3.3.1

    HP-Socket 是一套通用的高性能 TCP/UDP 通信框架,包含服务端组件.客户端组件和 Agent 组件,广泛适用于各种不同应用场景的 TCP/UDP 通信系统,提供 C/C++.C#.Del ...

  7. HP-SOCKET TCP/UDP通信框架库解析

    项目概述: HP-SOCKET是一套通用TCP/UDP通信框架,包括服务器.客户端.Agent组件:其目标是提供高性能.通用性.简易性.可扩展.可定制: 鉴于此,其仅实现基本的通用框架通信.数据收发功 ...

  8. .Net开发笔记(十四) 基于“泵”的UDP通信(接上篇)

    上一篇中说到了“泵”在编程中的作用以及一些具体用处,但没有实际demo,可能不好理解,这篇文章我分享一个UDP通信的demo,大概实现了类似“飞鸽传书”在局域网中文本消息和文件传输的功能.功能不全也不 ...

  9. 高性能 TCP & UDP 通信框架 HP-Socket v3.2.3

    HP-Socket 是一套通用的高性能 TCP/UDP 通信框架,包含服务端组件.客户端组件和 Agent 组件,广泛适用于各种不同应用场景的 TCP/UDP 通信系统,提供 C/C++.C#.Del ...

随机推荐

  1. Aizu - 2555 Everlasting Zero 模拟

    Aizu - 2555 Everlasting Zero 题意:学习技能,每个技能有不同的要求,问能否学习全部特殊技能 思路:枚举每两个技能,得到他们的先后学习关系,如果两个都不能先学的话就是No了, ...

  2. Android真机调试访问本地服务器(localhost)的解决方案

    Android系统把它自己作为了localhost!当连接localhost都是他自己啊.. 囧,在这里晕了好久才发现.. 网上介绍的都是模拟器连接本地服务器的,我试着把链接改为http://10.0 ...

  3. java带package的编译

    ProcessBuilder pb = new ProcessBuilder("cmd", "/c", "java -cp d:\\TEST com/ ...

  4. 内联函数(Inline Functions)

    影响性能的一个重要因素是内联技巧.内联函数也可称为内嵌函数. 在C++中,函数调用需要建立栈环境,进行参数复制,保护调用现场,返回时,还要进行返回值复制,恢复调用现场.这些工作都是与完成特定任务的操作 ...

  5. visual studio 添加库文件

    我在visual studio中使用OpenGL时需要添加额外的库 一 首先下载库文件,里面将会有一些.h文件和.lib文件,打开visual studio安装目录下打开: D:\program\VS ...

  6. SSH—指定登录的IP

    设置ssh安全--指定的IP登陆 为了服务器更加具有安全性,我们可以设置ssh安全只允许用户从固定的IP进行登陆, 首先获取要登录服务器的电脑的IP地址 登录http://www.ip138.com/ ...

  7. 讲的好,php后端模式,php-fpm以及php-cgi, fast-cgi,以及与nginx的关系

    关于cgi是什么,fast-cgi是什么,php-cgi是什么,fast-cgi是什么,下面这篇讲的很清楚: https://segmentfault.com/q/1010000000256516 另 ...

  8. 编译安装 gcc 4.9并验证使用

    编译安装 gcc 4.9并验证使用 1. 准备环境(GCC 编译器) centOS 6.3 cat /proc/version Linux version 2.6.32-279.el6.x86_64 ...

  9. Floyd-Warshall 算法-- 最短路径(适合节点密集的图)

     由于此算法时间复杂度为O(V³).大多数情况下不如迪杰斯特拉算法的.迪杰斯特拉算法适合于节点疏散的图.  演示样例图例如以下:     Step 1 创建节点与边的最短路径结果表(直接可达关系).数 ...

  10. [ Javascript ] JavaScript中的定时器(Timer) 是怎样工作的!

    作为入门者来说.了解JavaScript中timer的工作方式是非常重要的.通常它们的表现行为并非那么地直观,而这是由于它们都处在一个单一线程中.让我们先来看一看三个用来创建以及操作timer的函数. ...