Linux网络编程之TCP协议

简介:

server.c:


#include <stdlib.h> 

#include <stdio.h> 
#include <errno.h> 
#include <string.h> 
#include <netdb.h> 
#include <sys/types.h> 
#include <netinet/in.h> 
#include <sys/socket.h> 


#define portnumber 8888


int main(int argc, char *argv[]) 

int sockfd,new_fd; 
//设置一个socket地址结构server_addr,代表服务器internet地址, 端口
struct sockaddr_in server_addr; 
struct sockaddr_in client_addr; 
int sin_size; 
char hello[]="Hello! Are You Fine?\n"; 
char buff[1024];
int nbytes;



/* 服务器端开始建立sockfd描述符 */ 
if((sockfd=socket(AF_INET,SOCK_STREAM,0))==-1) // AF_INET:IPV4;SOCK_STREAM:TCP 创建用于internet的流协议(TCP)socket,用server_socket代表服务器socket
fprintf(stderr,"Socket error:%s\n\a",strerror(errno)); 
exit(1); 



/* 服务器端填充 sockaddr结构 */ 
bzero(&server_addr,sizeof(struct sockaddr_in)); // 初始化,置0 把一段内存区的内容全部设置为0
server_addr.sin_family=AF_INET;                 // Internet
server_addr.sin_addr.s_addr=htonl(INADDR_ANY);  // (将本机器上的long数据转化为网络上的long数据)和任何主机通信  //INADDR_ANY 表示可以接收任意IP地址的数据,即绑定到所有的IP
//server_addr.sin_addr.s_addr=inet_addr("210.41.141.155");  //用于绑定到一个固定IP,inet_addr用于把数字加格式的ip转化为整形ip
server_addr.sin_port=htons(portnumber);         // (将本机器上的short数据转化为网络上的short数据)端口号

/* 捆绑sockfd描述符到IP地址 把socket和socket地址结构联系起来*/ 
if(bind(sockfd,(struct sockaddr *)(&server_addr),sizeof(struct sockaddr))==-1) 

fprintf(stderr,"Bind error:%s\n\a",strerror(errno)); 
exit(1); 



/* 设置允许连接的最大客户端数 server_socket用于监听*/ 
if(listen(sockfd,5)==-1) 

fprintf(stderr,"Listen error:%s\n\a",strerror(errno)); 
exit(1); 



while(1) 

/* 服务器阻塞,直到客户程序建立连接 */ 
sin_size=sizeof(struct sockaddr_in); 
//接受一个到server_socket代表的socket的一个连接
        //如果没有连接请求,就等待到有连接请求--这是accept函数的特性
        //accept函数返回一个新的socket,这个socket(new_server_socket)用于同连接到的客户的通信
        //new_server_socket代表了服务器和客户端之间的一个通信通道
        //accept函数把连接到的客户端信息填写到客户端的socket地址结构client_addr中
if((new_fd=accept(sockfd,(struct sockaddr *)(&client_addr),&sin_size))==-1) 

fprintf(stderr,"Accept error:%s\n\a",strerror(errno)); 
exit(1); 

fprintf(stderr,"Server get connection from %s\n",inet_ntoa(client_addr.sin_addr)); // 将网络地址转换成.字符串

if((nbytes=read(new_fd,buff,1024))==-1) 

fprintf(stderr,"Write Error:%s\n",strerror(errno)); 
exit(1); 

/* 这个通讯已经结束 */ 
printf("Server received %s\n",buff);
close(new_fd); 
/* 循环下一个 */ 



/* 结束通讯 */ 
close(sockfd); 
exit(0); 


client.c:

#include <stdlib.h> 
#include <stdio.h> 
#include <errno.h> 
#include <string.h> 
#include <netdb.h> 
#include <sys/types.h> 
#include <netinet/in.h> 
#include <sys/socket.h> 


#define portnumber 8888


int main(int argc, char *argv[]) 

int sockfd; 
char buffer[1024]; 
struct sockaddr_in server_addr; //设置一个socket地址结构client_addr,代表客户机internet地址, 端口
struct hostent *host; 
int nbytes; 
char buff[1024];


        /* 使用hostname查询host 名字 */
if(argc!=2) 

fprintf(stderr,"Usage:%s hostname \a\n",argv[0]); 
exit(1); 



if((host=gethostbyname(argv[1]))==NULL) 

fprintf(stderr,"Gethostname error\n"); 
exit(1); 



/* 客户程序开始建立 sockfd描述符 */ 
if((sockfd=socket(AF_INET,SOCK_STREAM,0))==-1) // AF_INET:Internet;SOCK_STREAM:TCP

fprintf(stderr,"Socket Error:%s\a\n",strerror(errno)); 
exit(1); 



/* 客户程序填充服务端的资料 */ 
bzero(&server_addr,sizeof(server_addr)); // 初始化,置0
server_addr.sin_family=AF_INET;          //  //internet协议族
server_addr.sin_port=htons(portnumber);  // (将本机器上的short数据转化为网络上的short数据)端口号
server_addr.sin_addr=*((struct in_addr *)host->h_addr); // IP地址

/* 客户程序发起连接请求 */ 
if(connect(sockfd,(struct sockaddr *)(&server_addr),sizeof(struct sockaddr))==-1) 

fprintf(stderr,"Connect Error:%s\a\n",strerror(errno)); 
exit(1); 



/* 连接成功了 */ 
#if 0
if((nbytes=read(sockfd,buffer,1024))==-1) 

fprintf(stderr,"Read Error:%s\n",strerror(errno)); 
exit(1); 

#endif

//buffer[nbytes]='\0'; 
//printf("I have received:%s\n",buffer); 
  printf("please input  char :\n ");
fgets(buff,1024,stdin);
write(sockfd,buff,strlen(buff));
/* 结束通讯 */ 
close(sockfd); 
exit(0); 

目录
相关文章
|
15天前
|
安全 Linux 虚拟化
网络名称空间在Linux虚拟化技术中的位置
网络名称空间(Network Namespaces)是Linux内核特性之一,提供了隔离网络环境的能力,使得每个网络名称空间都拥有独立的网络设备、IP地址、路由表、端口号范围以及iptables规则等。这一特性在Linux虚拟化技术中占据了核心位置🌟,它不仅为构建轻量级虚拟化解决方案(如容器📦)提供了基础支持,也在传统的虚拟机技术中发挥作用,实现资源隔离和网络虚拟化。
网络名称空间在Linux虚拟化技术中的位置
|
13天前
|
存储 算法 Linux
【实战项目】网络编程:在Linux环境下基于opencv和socket的人脸识别系统--C++实现
【实战项目】网络编程:在Linux环境下基于opencv和socket的人脸识别系统--C++实现
38 6
|
4天前
|
机器学习/深度学习 缓存 监控
linux查看CPU、内存、网络、磁盘IO命令
`Linux`系统中,使用`top`命令查看CPU状态,要查看CPU详细信息,可利用`cat /proc/cpuinfo`相关命令。`free`命令用于查看内存使用情况。网络相关命令包括`ifconfig`(查看网卡状态)、`ifdown/ifup`(禁用/启用网卡)、`netstat`(列出网络连接,如`-tuln`组合)以及`nslookup`、`ping`、`telnet`、`traceroute`等。磁盘IO方面,`iostat`(如`-k -p ALL`)显示磁盘IO统计,`iotop`(如`-o -d 1`)则用于查看磁盘IO瓶颈。
|
1天前
|
存储 网络协议 关系型数据库
Python从入门到精通:2.3.2数据库操作与网络编程——学习socket编程,实现简单的TCP/UDP通信
Python从入门到精通:2.3.2数据库操作与网络编程——学习socket编程,实现简单的TCP/UDP通信
|
1天前
|
网络协议 Linux Shell
【linux网络(一)】初识网络, 理解四层网络模型
【linux网络(一)】初识网络, 理解四层网络模型
|
1天前
|
安全 Ubuntu Linux
Linux 网络操作命令Telnet
Linux 网络操作命令Telnet
13 0
Linux 网络操作命令Telnet
|
2天前
|
Ubuntu Linux
Linux(22) Linux设置网络优先级顺序
Linux(22) Linux设置网络优先级顺序
3 0
|
3天前
|
Ubuntu 网络协议 Linux
Linux(20) Ubuntu 20.04 网络接口自动切换路由配置
Linux(20) Ubuntu 20.04 网络接口自动切换路由配置
26 0
|
8天前
|
网络协议 Java API
深度剖析:Java网络编程中的TCP/IP与HTTP协议实践
【4月更文挑战第17天】Java网络编程重在TCP/IP和HTTP协议的应用。TCP提供可靠数据传输,通过Socket和ServerSocket实现;HTTP用于Web服务,常借助HttpURLConnection或Apache HttpClient。两者结合,构成网络服务基础。Java有多种高级API和框架(如Netty、Spring Boot)简化开发,助力高效、高并发的网络通信。
|
9天前
|
网络协议 Ubuntu Unix
Linux 下使用 socket 实现 TCP 客户端
Linux 下使用 socket 实现 TCP 客户端