建议大家用eclipse for c++开发啊~~~ 好用!
至于具体的通信过程,网上一大堆。
不解释,详细解释都在代码注释里了。
客户端代码:
client.cpp
#include <stdio.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <unistd.h>
#include <errno.h>
#include <string.h>
#include <stdlib.h>
#include <sys/ioctl.h>
#include <net/if.h>
#include <arpa/inet.h>
#define DEST_IP "127.0.0.1"
#define SERV_PORT 8000
int main() {
/* socket文件描述符 */
int sock_fd;
/* 建立udp socket */
sock_fd = socket(AF_INET, SOCK_DGRAM, 0);
if (sock_fd < 0) {
perror("socket");
exit(1);
}
/* 定义一个连接的地址结构体 address */
struct sockaddr_in addr_serv;
int len;
memset(&addr_serv, 0, sizeof(struct sockaddr_in));
//************* 设置协议族 即IPV4 ************//
addr_serv.sin_family = AF_INET;
//************* 设置连接的服务器端口 ************//
//端口号和IP地址都是以 网络字节存储的,需要重新排序
addr_serv.sin_port = htons(SERV_PORT); //转换为网络字节序, 小端 -> 大端
//************* 设置连接的服务器地址 ************//
//第0种写法,用INADDR_ANY代表服务器地址
/* INADDR_ANY 表示不管是哪个网卡接收到数据,只要端口号对应,就会被该程序接收 */
//addr_serv.sin_addr.s_addr = htonl(INADDR_ANY );
//第1种地址转换方法(点分10进制,转换为in_addr_t 类型)
addr_serv.sin_addr.s_addr = inet_addr("127.0.0.1"); //出错返回INADDR_NONE
//第2种
//inet_aton("127.0.0.1", &addr_serv.sin_addr);
//************* 设置连接的服务器地址 ************//
len = sizeof(addr_serv);
//************* 获取本机mac地址 可忽略 ************//
struct ifreq ifr;
ifr.ifr_addr.sa_family = AF_INET;
strncpy(ifr.ifr_name, "eth0", IFNAMSIZ - 1);
ioctl(sock_fd, SIOCGIFHWADDR, &ifr);
printf("我是客户端,我的MAC地址:");
printf("%.2x:%.2x:%.2x:%.2x:%.2x:%.2x\n",
(unsigned char) ifr.ifr_hwaddr.sa_data[0],
(unsigned char) ifr.ifr_hwaddr.sa_data[1],
(unsigned char) ifr.ifr_hwaddr.sa_data[2],
(unsigned char) ifr.ifr_hwaddr.sa_data[3],
(unsigned char) ifr.ifr_hwaddr.sa_data[4],
(unsigned char) ifr.ifr_hwaddr.sa_data[5]);
//获取mac地址结束,
int recv_num;
int send_num;
char send_buf[20] = "Hi, I am the client";
char recv_buf[20]; //接收缓存
//**************给服务器发送数据 *************//
//相比TCP,UDP节省了connect函数,即3次握手,可以直接发送数据
//int sendto (int socket, void *buffer. size_t size, int flags, struct sockaddr *addr, socklen_t length)
send_num = sendto(sock_fd, send_buf, strlen(send_buf), 0,
(struct sockaddr *) &addr_serv, len);
printf("客户端说:%s\n", send_buf);
if(send_num < 0){
perror("sendto error");
exit(1);
}
//**************接收服务器数据 *************//
//int recvfrom (int socket, void *buffer, size_t size, int flags, struct sockaddr *addr, socklen_t *length-ptr)
recv_num = recvfrom(sock_fd, recv_buf, sizeof(recv_buf), 0,
(struct sockaddr *)&addr_serv,(socklen_t *)len);
recv_buf[recv_num] = '\0';
printf("客户端收到: %d bytes : %s\n", recv_num, recv_buf);
close(sock_fd);
return 0;
}
服务器端代码:
server.cpp
#include <stdio.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <unistd.h>
#include <errno.h>
#include <string.h>
#include <stdlib.h>
#include <sys/ioctl.h>
#include <net/if.h>
#define SERV_PORT 8000
int main() {
/* socket文件描述符 */
int sock_fd;
/* 建立udp socket */
sock_fd = socket(AF_INET, SOCK_DGRAM, 0);
if (sock_fd < 0) {
perror("socket");
exit(1);
}
/* 设置 address */
struct sockaddr_in addr_serv;
int len;
memset(&addr_serv, 0, sizeof(struct sockaddr_in));
addr_serv.sin_family = AF_INET;
//htons含义:h:host n:network s:short l:long l:long
addr_serv.sin_port = htons(SERV_PORT); //转换为网络字节序, 小端 -> 大端
/* INADDR_ANY 表示不管是哪个网卡接收到数据,只要端口号对应,就会被该程序接收 */
addr_serv.sin_addr.s_addr = htonl(INADDR_ANY );
len = sizeof(addr_serv);
/* 绑定 socket */
// int bind (int socket, struct sockaddr *addr, socklen_t length)
if (bind(sock_fd, (struct sockaddr *) &addr_serv, sizeof(addr_serv)) < 0) {
perror("bind error:");
exit(1);
}
int recv_num;
int send_num;
char send_buf[20] = "i am server!";
char recv_buf[20]; //接收缓存
struct sockaddr_in addr_client;
//获取本机mac地址
struct ifreq ifr;
ifr.ifr_addr.sa_family = AF_INET;
strncpy(ifr.ifr_name, "eth0", IFNAMSIZ - 1);
ioctl(sock_fd, SIOCGIFHWADDR, &ifr);
printf("我是服务器,我的MAC地址:");
printf("%.2x:%.2x:%.2x:%.2x:%.2x:%.2x\n",
(unsigned char) ifr.ifr_hwaddr.sa_data[0],
(unsigned char) ifr.ifr_hwaddr.sa_data[1],
(unsigned char) ifr.ifr_hwaddr.sa_data[2],
(unsigned char) ifr.ifr_hwaddr.sa_data[3],
(unsigned char) ifr.ifr_hwaddr.sa_data[4],
(unsigned char) ifr.ifr_hwaddr.sa_data[5]);
//循环等待
while (1) {
printf("server wait:\n");
/* recvfrom() 从基于UDP的套接口接收数据,包括发送者的IP地址。因为数据包可能来自任何主机
* flag=0, 常规读取,等同read()函数。 flag=MSG_PEEK,读数据但不刷新读缓冲区。MSG——OOB,读带外数据,普通数据被忽略 */
recv_num = recvfrom(sock_fd, recv_buf, sizeof(recv_buf), 0,
(struct sockaddr *) &addr_client, (socklen_t *) &len);
if (recv_num < 0) {
perror("recvfrom error:");
exit(1);
}
recv_buf[recv_num] = '\0';
printf("服务端收到: %d bytes: %s\n", recv_num, recv_buf);
//给客户端发送数据
send_num = sendto(sock_fd, send_buf, recv_num, 0,
(struct sockaddr *) &addr_client, len);
printf("服务器说:%s\n",send_buf);
if (send_num < 0) {
perror("sendto error:");
exit(1);
}
}
close(sock_fd);
return 0;
}
分享到:
相关推荐
14、Linux网络编程14——I/O复用之select详解 15、Linux网络编程15——I/O复用之poll详解 16、Linux网络编程16——I/O复用之epoll详解 17、Linux网络编程17——tcp并发服务器(多进程) 18、Linux网络编程18——tcp...
基于windows下的UDP通信,传输协议,完成互相通信,在控制台实现该功能
Qt网络编程之搭建Udp通信【单播、组播、广播】 内有三种详细的方式对应的代码。还有详细的注释。如果有什么不懂得可以私聊我。 切记路径不能有中文。
linux UDP编程总结和实例
linux 网络通信程序,包括服务器端和客户端,一个完整的TCP,udp 通信程序
总之,Linux网络编程是一项重要的技能,它涉及到网络通信的基本原理以及多路复用技术的使用,对于开发网络应用程序来说是必不可少的技能。Linux网络编程是指在Linux操作系统上开发网络应用程序的过程。它主要涉及到...
内容包含Linux系统概述、Linux编程环境、Linux文件系统简介、Linux下的进程和线程、TCP/IP协议族、应用层网络服务程序、TCP编程、主机信息获取、数据IO复用、UDP编程、高级套接字、套接字选项、原始套接字、服务器...
Visual C# UDP应用实例详解
Linux网络编程示例程序,包含TCP、UDP的server和client
在linux下的udp通信,采用c语言编写,可实现简单的文件下载与上传,适用于初学者
以太网UDP通信实例,包括服务器端和客户端实例代码。
C#套接字编程实例_UDP_TCP通信源码实例 本人收藏了3年的资源 现放出 都是总结了很多系统 软件项目实施过程中的经验的 慢慢积累的
其包含客户端和服务器端代码,实现了linux下的socket编程,是UDP方面很好的例子
除了同一操作系统下的udp通信外,还能进行windows下与linux下的客户端与服务端通信。出现中文乱码的话,那一定是运行此程序的窗口的编码格式不一致,只要改为一致就可以了。如果要将dos窗口的编码方式改为UTF8,可...
C#UDP通信实例 C#UDP通信实例 C#UDP通信实例 C#UDP通信实例 C#UDP通信实例
linux网络编程实现tcp udp通信
UDP通信过程详解 UDP通信过程详解+附Java实现方式
TCP&UDP测试工具
实验验证linux网络编程中的UDP编程,其中UDP服务器从电脑1接收数据,然后转发到电脑2实现了简单的udp收发服务器的设计,其中lisntener为服务器程序,talker为电脑1程序,disp为电脑2程序
Linux网络编程一步一步学-IPv6下网络编程步骤.pdf Linux网络编程一步一步学-select详解.pdf Linux网络编程一步一步学-UDP编程介绍.pdf Linux网络编程一步一步学-UDP方式点对点通讯.pdf Linux网络编程一步一步学-UDP...