linux下一个简单的基于IPv6(UDP)的回显服务器程序

简介:

 话不多说,直接上源码。

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
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
/** 
  *@author walker 
  *@date 2012.9 
  */ 
  
#include <unistd.h> 
#include <arpa/inet.h> 
#include <stdio.h> 
#include <stdlib.h> 
#include <string.h> 
  
#define UDP_PORT 6000   //预定义的端口号 
#define MAXSIZE 8192 
  
//实际使用端口号 
int  g_udp_port = UDP_PORT; 
  
//用于回显的函数 
void  echo_fn( int  sockfd); 
  
int  main( int  argc,  char  *argv[]) 
     //获取用户输入的端口号 
     if  (argc > 1) 
    
         g_udp_port =  atoi (argv[1]); 
    
     if  (g_udp_port <= 0 || g_udp_port > 65535) 
    
         perror ( "Invalid port.\n" ); 
         return  -1; 
    
  
     int  sockfd;      //套接字描述符 
     struct  sockaddr_in6 addr;    //用于UDP的IPv6地址结构 
  
     if ((sockfd = socket(AF_INET6, SOCK_DGRAM,0)) == -1) 
    
         printf ( "Error in socket\n" ); 
         return  -1; 
    
  
     bzero(&addr,  sizeof (addr)); 
     addr.sin6_family = AF_INET6; 
     addr.sin6_port = htons(g_udp_port); 
     addr.sin6_addr = in6addr_any; 
  
     if (bind(sockfd, ( struct  sockaddr *)&addr,  sizeof ( struct  sockaddr_in6)) == -1) 
    
         printf ( "Error in binding\n" ); 
         return  -1; 
    
  
     echo_fn(sockfd);     //调用回显函数 
  
     close(sockfd);       //关闭套接字 
  
     return  -1; 
  
//用于回显的函数 
void  echo_fn( int  sockfd) 
     char  data[MAXSIZE]; 
     int  n = 0; 
     socklen_t len =  sizeof ( struct  sockaddr_in6); 
     struct  sockaddr_in6 addr; 
  
     while (1) 
    
         printf ( "Waiting for data...\n" ); 
  
         //接受从客户端发来的数据 
         if ((n = recvfrom(sockfd, data, MAXSIZE, 0, ( struct  sockaddr *)&addr, &len)) == -1) 
        
             printf ( "Error in receiving\n" ); 
             exit (-1); 
        
         data[n] =  '\0'
  
         printf ( "Received data: %s\n" , data); 
         //将收到的数据再发送回去 
         sendto(sockfd, data, n, 0, ( struct  sockaddr *)&addr, len); 
  
         //存储用"冒号十六进制记法"表示的IPv6地址 
         char  buf_addr[40]; 
         //将IPv6地址转为"冒号十六进制记法"(colon hexadecimal notation)表示 
         inet_ntop(AF_INET6, &addr.sin6_addr, buf_addr, 64); 
  
         printf ( "Client ip: %s\n" , buf_addr); 
         printf ( "Client port: %d\n" , ntohs(addr.sin6_port)); 
         printf ( "\n" ); 
    
}


*** walker ***

本文转自walker snapshot博客51CTO博客,原文链接http://blog.51cto.com/walkerqt/1006583如需转载请自行联系原作者

RQSLT
相关文章
|
6月前
|
安全 Linux iOS开发
Nessus Professional 10.10 Auto Installer for RHEL 10, AlmaLinux 10, Rocky Linux 10 - Nessus 自动化安装程序
Nessus Professional 10.10 Auto Installer for RHEL 10, AlmaLinux 10, Rocky Linux 10 - Nessus 自动化安装程序
412 6
Nessus Professional 10.10 Auto Installer for RHEL 10, AlmaLinux 10, Rocky Linux 10 - Nessus 自动化安装程序
|
网络协议 Java API
【JavaEE】——Udp翻译器的实现(回显服务器)
网络编程,DatagramSocket 和 DatagramPacket类,回显服务器,服务器实现,客户端实现,
|
运维 Java Linux
【运维基础知识】Linux服务器下手写启停Java程序脚本start.sh stop.sh及详细说明
### 启动Java程序脚本 `start.sh` 此脚本用于启动一个Java程序,设置JVM字符集为GBK,最大堆内存为3000M,并将程序的日志输出到`output.log`文件中,同时在后台运行。 ### 停止Java程序脚本 `stop.sh` 此脚本用于停止指定名称的服务(如`QuoteServer`),通过查找并终止该服务的Java进程,输出操作结果以确认是否成功。
1134 1
|
存储 网络协议 Java
【网络】UDP回显服务器和客户端的构造,以及连接流程
【网络】UDP回显服务器和客户端的构造,以及连接流程
340 3
|
存储 网络协议 Java
【网络】UDP和TCP之间的差别和回显服务器
【网络】UDP和TCP之间的差别和回显服务器
229 1
|
网络协议 Linux 网络性能优化
Linux C/C++之TCP / UDP通信
这篇文章详细介绍了Linux下C/C++语言实现TCP和UDP通信的方法,包括网络基础、通信模型、编程示例以及TCP和UDP的优缺点比较。
797 0
Linux C/C++之TCP / UDP通信
|
网络协议 Linux 网络性能优化
Linux基础-socket详解、TCP/UDP
综上所述,Linux下的Socket编程是网络通信的重要组成部分,通过灵活运用TCP和UDP协议,开发者能够构建出满足不同需求的网络应用程序。掌握这些基础知识,是进行更复杂网络编程任务的基石。
599 1
|
6月前
|
弹性计算 运维 安全
阿里云轻量应用服务器与云服务器ECS啥区别?新手帮助教程
阿里云轻量应用服务器适合个人开发者搭建博客、测试环境等低流量场景,操作简单、成本低;ECS适用于企业级高负载业务,功能强大、灵活可扩展。二者在性能、网络、镜像及运维管理上差异显著,用户应根据实际需求选择。
476 10
|
6月前
|
运维 安全 Ubuntu
阿里云渠道商:服务器操作系统怎么选?
阿里云提供丰富操作系统镜像,涵盖Windows与主流Linux发行版。选型需综合技术兼容性、运维成本、安全稳定等因素。推荐Alibaba Cloud Linux、Ubuntu等用于Web与容器场景,Windows Server支撑.NET应用。建议优先选用LTS版本并进行测试验证,通过标准化镜像管理提升部署效率与一致性。