网络通信1—TCP程序编写步骤(参照 Ubuntu 16.04 版本)(转载)

本文主要是介绍网络通信1—TCP程序编写步骤(参照 Ubuntu 16.04 版本)(转载),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

转载自:https://blog.csdn.net/wenfei11471/article/details/79478105

网络通信1—TCP程序编写步骤(参照 Ubuntu 16.04 版本)

wenfei11471 2018-03-07 22:38:48

965

收藏 4

分类专栏: Linux C 语言 文章标签: TCP Linux 网络编程

版权

Linux C 语言 专栏收录该内容

31 篇文章 0 订阅

订阅专栏

  • TCP基础模型
  1. 服务器流程
    1. step 1:创建 socke() 套接字接口并判断

listenfd = socket(AF_INET, SOCK_STREAM, 0);

if (listenfd == -1)

{perror("socket failed");return -1;}

  1. step 2:设置 IP 和 Port

memset (&seraddr, 0, sizeof(seraddr));

seraddr.sin_family = AF_INET;

seraddr.sin_port = htons(8888);

seraddr.sin_addr.s_addr = inet_addr("127.0.0.1");

  1. step 3:绑定 IP 和 Port 并判断

ret = bind(listenfd, (struct sockaddr *)&seraddr, sizeof(seraddr));

if (ret == -1)

{perror("bind failed");return -1;}

  1. step 4:监听连接并判断

ret = listen(listenfd, 5);

if (ret == -1)

{perror("listen failed");return -1;}

  1. step 5:接受连接请求并判断

connfd = accept(listenfd, (struct sockaddr *)&cliaddr, &addrlen);

if (connfd == -1)

{perror("accept failed");return -1;}

printf("connect sucessfully: client IP: %s, Port: %d\n", inet_ntoa(cliaddr.sin_addr), ntohs(cliaddr.sin_port));

  1. step 6:接收数据并判断

ret = recv(connfd, buf, sizeof(buf), 0);

if (ret == -1)

{perror("recv failed");return -1;}

printf("recv from client: %s\nrecv %d bytes\n", buf, ret);

  1. step 7:发送数据并判断

ret = send(connfd, buf, sizeof(buf), 0);

if (ret == -1)

{perror("send failed");return -1;}

printf("send successfully!\n");

  1. step 8:关闭连接

close(connfd);

  1. step 9:检查头文件和变量是否定义

客户端流程

  1. step 1:创建 socke() 套接字接口并判断

connfd = socket(AF_INET, SOCK_STREAM, 0);

if (connfd == -1)

{perror("socket failed");return -1;}

  1. step 2:设置服务器 IP 和 Port

memset (&seraddr, 0, sizeof(seraddr));

seraddr.sin_family = AF_INET;

seraddr.sin_port = htons(8888);

seraddr.sin_addr.s_addr = inet_addr("127.0.0.1");

  1. step 3:发送连接请求并判断

ret = connect(connfd, (struct sockaddr *)&seraddr, sizeof(seraddr));

if (ret == -1)

{perror("connect faile");return -1;}

printf("connect sucessfully!\n");

  1. step 4:发送数据并判断

ret = send(connfd, buf, sizeof(buf), 0);

if (ret == -1)

{perror("send faile");return -1;}

printf("send successfully!");

  1. step 5:接收数据

ret = recv(connfd, buf, sizeof(buf), 0);

if (ret == -1)

{perror("recv faile");return -1;}

printf("%s\n", buf);

  1. step 6:关闭连接

close(connfd);

  1. step 7:检查头文件和变量是否定义
  • TCP 循环服务器模型
  1. 服务器流程
    1. step 1:创建 socke() 套接字接口并判断

listenfd = socket(AF_INET, SOCK_STREAM, 0);

if (listenfd == -1)

{perror("socket failed");return -1;}

  1. step 2:设置 IP 和 Port

memset (&seraddr, 0, sizeof(seraddr));

seraddr.sin_family = AF_INET;

seraddr.sin_port = htons(8888);

seraddr.sin_addr.s_addr = inet_addr("127.0.0.1");

  1. step 3:绑定 IP 和 Port 并判断

ret = bind(listenfd, (struct sockaddr *)&seraddr, sizeof(seraddr));

if (ret == -1)

{perror("bind failed");return -1;}

  1. step 4:监听连接并判断

ret = listen(listenfd, 5);

if (ret == -1)

{perror("listen failed");return -1;}

  1. step 5:设置循环连接

while(1)

  1. step 6:接受连接请求并判断

connfd = accept(listenfd, (struct sockaddr *)&cliaddr, &addrlen);

if (connfd == -1)

{perror("accept failed");return -1;}

printf("connect sucessfully: client IP: %s, Port: %d\n", inet_ntoa(cliaddr.sin_addr), ntohs(cliaddr.sin_port));

  1. step 7:循环接收数据,直达条件满足退出

while(1)

  1. step 8:接收数据并判断

ret = recv(connfd, buf, sizeof(buf), 0);

if (ret == -1)

{perror("recv failed");return -1;}

  1. step 9:设置跳出循环的条件

if (!strncmp("quit", buf, 4))

break;

printf("recv from client: %s\nrecv %d bytes\n", buf, ret);

  1. step 10:发送数据并判断

ret = send(connfd, buf, sizeof(buf), 0);

if (ret == -1)

{perror("send failed");return -1;}

printf("send successfully!\n");

  1. step 11:关闭连接

close(connfd);

  1. step 12:检查头文件和变量是否定义

客户端流程

  1. step 1:创建 socke() 套接字接口并判断

connfd = socket(AF_INET, SOCK_STREAM, 0);

if (connfd == -1)

{perror("socket failed");return -1;}

  1. step 2:设置服务器 IP 和 Port

memset (&seraddr, 0, sizeof(seraddr));

seraddr.sin_family = AF_INET;

seraddr.sin_port = htons(8888);

seraddr.sin_addr.s_addr = inet_addr("127.0.0.1");

  1. step 3:发送连接请求并判断

ret = connect(connfd, (struct sockaddr *)&seraddr, sizeof(seraddr));

if (ret == -1)

{perror("connect faile");return -1;}

printf("connect sucessfully!\n");

  1. step 4:设置数据循环,并获取标准输入的数据

while (1)

{fgets(buf, sizeof(buf), stdin);

buf[strlen(buf)-1] = '\0';

...}

  1. step 5:发送数据并判断

ret = send(connfd, buf, sizeof(buf), 0);

if (ret == -1)

{perror("send faile");return -1;}

printf("send successfully!");

  1. step 6:设置退出条件

if (!strncmp("quit", buf, 4))

break;

  1. step 7:接收数据

ret = recv(connfd, buf, sizeof(buf), 0);

if (ret == -1)

{perror("recv faile");return -1;}

printf("%s\n", buf);

  1. step 8:关闭连接

close(connfd);

  1. step 9:检查头文件和变量是否定义
  • TCP 并发服务器模型
  1. 服务器流程
    1. step 1:创建 socke() 套接字接口并判断

listenfd = socket(AF_INET, SOCK_STREAM, 0);

if (listenfd == -1)

{perror("socket failed");return -1;}

  1. step 2:设置 IP 和 Port

memset (&seraddr, 0, sizeof(seraddr));

seraddr.sin_family = AF_INET;

seraddr.sin_port = htons(8888);

seraddr.sin_addr.s_addr = inet_addr("127.0.0.1");

  1. step 3:绑定 IP 和 Port 并判断

ret = bind(listenfd, (struct sockaddr *)&seraddr, sizeof(seraddr));

if (ret == -1)

{perror("bind failed");return -1;}

  1. step 4:监听连接并判断

ret = listen(listenfd, 5);

if (ret == -1)

{perror("listen failed");return -1;}

  1. step 5:设置信号处理防止僵尸进程

signal(SIGCHLD, SIG_IGN);

  1. step 6:设置循环建立连接

while(1)

  1. step 7:接受连接请求并判断

connfd = accept(listenfd, (struct sockaddr *)&cliaddr, &addrlen);

if (connfd == -1)

{perror("accept failed");return -1;}

printf("connect sucessfully: client IP: %s, Port: %d\n", inet_ntoa(cliaddr.sin_addr), ntohs(cliaddr.sin_port));

  1. step 8:创建子进程并判断

pid = fork();

if (pid == -1)

{perror("fork create");return -1}

  1. step 9:设置父进程关闭连接并重新建立链接

if (pid > 0)

{close(connfd);continue;}

  1. step 10:子进程关闭监听,并循环接收数据

close(listenfd);

while(1)

  1. step 11:接收数据并判断

ret = recv(connfd, buf, sizeof(buf), 0);

if (ret == -1)

{perror("recv failed");return -1;}

  1. step 12:设置跳出循环的条件

if (!strncmp("quit", buf, 4))

break;

printf("recv from client: %s\nrecv %d bytes\n", buf, ret);

  1. step 10:发送数据并判断

ret = send(connfd, buf, sizeof(buf), 0);

if (ret == -1)

{perror("send failed");return -1;}

printf("send successfully!\n");

  1. step 11:关闭连接同时退出进程

close(connfd);

exit(0);

  1. step 12:检查头文件和变量是否定义

客户端流程

  1. step 1:创建 socke() 套接字接口并判断

connfd = socket(AF_INET, SOCK_STREAM, 0);

if (connfd == -1)

{perror("socket failed");return -1;}

  1. step 2:设置服务器 IP 和 Port

memset (&seraddr, 0, sizeof(seraddr));

seraddr.sin_family = AF_INET;

seraddr.sin_port = htons(8888);

seraddr.sin_addr.s_addr = inet_addr("127.0.0.1");

  1. step 3:发送连接请求并判断

ret = connect(connfd, (struct sockaddr *)&seraddr, sizeof(seraddr));

if (ret == -1)

{perror("connect faile");return -1;}

printf("connect sucessfully!\n");

  1. step 4:设置数据循环,并获取标准输入的数据

while (1)

{fgets(buf, sizeof(buf), stdin);

buf[strlen(buf)-1] = '\0';

...}

  1. step 5:发送数据并判断

ret = send(connfd, buf, sizeof(buf), 0);

if (ret == -1)

{perror("send faile");return -1;}

printf("send successfully!");

  1. step 6:设置退出条件

if (!strncmp("quit", buf, 4))

break;

  1. step 7:接收数据

ret = recv(connfd, buf, sizeof(buf), 0);

if (ret == -1)

{perror("recv faile");return -1;}

printf("%s\n", buf);

  1. step 8:关闭连接

close(connfd);

  1. step 9:检查头文件和变量是否定义

这篇关于网络通信1—TCP程序编写步骤(参照 Ubuntu 16.04 版本)(转载)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/506915

相关文章

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟 开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚 第一站:海量资源,应有尽有 走进“智听

Android实现任意版本设置默认的锁屏壁纸和桌面壁纸(两张壁纸可不一致)

客户有些需求需要设置默认壁纸和锁屏壁纸  在默认情况下 这两个壁纸是相同的  如果需要默认的锁屏壁纸和桌面壁纸不一样 需要额外修改 Android13实现 替换默认桌面壁纸: 将图片文件替换frameworks/base/core/res/res/drawable-nodpi/default_wallpaper.*  (注意不能是bmp格式) 替换默认锁屏壁纸: 将图片资源放入vendo

K8S(Kubernetes)开源的容器编排平台安装步骤详解

K8S(Kubernetes)是一个开源的容器编排平台,用于自动化部署、扩展和管理容器化应用程序。以下是K8S容器编排平台的安装步骤、使用方式及特点的概述: 安装步骤: 安装Docker:K8S需要基于Docker来运行容器化应用程序。首先要在所有节点上安装Docker引擎。 安装Kubernetes Master:在集群中选择一台主机作为Master节点,安装K8S的控制平面组件,如AP

pico2 开发环境搭建-基于ubuntu

pico2 开发环境搭建-基于ubuntu 安装编译工具链下载sdk 和example编译example 安装编译工具链 sudo apt install cmake gcc-arm-none-eabi libnewlib-arm-none-eabi libstdc++-arm-none-eabi-newlib 注意cmake的版本,需要在3.17 以上 下载sdk 和ex

EMLOG程序单页友链和标签增加美化

单页友联效果图: 标签页面效果图: 源码介绍 EMLOG单页友情链接和TAG标签,友链单页文件代码main{width: 58%;是设置宽度 自己把设置成与您的网站宽度一样,如果自适应就填写100%,TAG文件不用修改 安装方法:把Links.php和tag.php上传到网站根目录即可,访问 域名/Links.php、域名/tag.php 所有模板适用,代码就不粘贴出来,已经打

跨系统环境下LabVIEW程序稳定运行

在LabVIEW开发中,不同电脑的配置和操作系统(如Win11与Win7)可能对程序的稳定运行产生影响。为了确保程序在不同平台上都能正常且稳定运行,需要从兼容性、驱动、以及性能优化等多个方面入手。本文将详细介绍如何在不同系统环境下,使LabVIEW开发的程序保持稳定运行的有效策略。 LabVIEW版本兼容性 LabVIEW各版本对不同操作系统的支持存在差异。因此,在开发程序时,尽量使用

如何编写Linux PCIe设备驱动器 之二

如何编写Linux PCIe设备驱动器 之二 功能(capability)集功能(capability)APIs通过pci_bus_read_config完成功能存取功能APIs参数pos常量值PCI功能结构 PCI功能IDMSI功能电源功率管理功能 功能(capability)集 功能(capability)APIs int pcie_capability_read_wo

CSP 2023 提高级第一轮 CSP-S 2023初试题 完善程序第二题解析 未完

一、题目阅读 (最大值之和)给定整数序列 a0,⋯,an−1,求该序列所有非空连续子序列的最大值之和。上述参数满足 1≤n≤105 和 1≤ai≤108。 一个序列的非空连续子序列可以用两个下标 ll 和 rr(其中0≤l≤r<n0≤l≤r<n)表示,对应的序列为 al,al+1,⋯,ar​。两个非空连续子序列不同,当且仅当下标不同。 例如,当原序列为 [1,2,1,2] 时,要计算子序列 [

arduino ide安装详细步骤

​ 大家好,我是程序员小羊! 前言: Arduino IDE 是一个专为编程 Arduino 微控制器设计的集成开发环境,使用起来非常方便。下面将介绍如何在不同平台上安装 Arduino IDE 的详细步骤,包括 Windows、Mac 和 Linux 系统。 一、在 Windows 上安装 Arduino IDE 1. 下载 Arduino IDE 打开 Arduino 官网

这些心智程序你安装了吗?

原文题目:《为什么聪明人也会做蠢事(四)》 心智程序 大脑有两个特征导致人类不够理性,一个是处理信息方面的缺陷,一个是心智程序出了问题。前者可以称为“认知吝啬鬼”,前几篇文章已经讨论了。本期主要讲心智程序这个方面。 心智程序这一概念由哈佛大学认知科学家大卫•帕金斯提出,指个体可以从记忆中提取出的规则、知识、程序和策略,以辅助我们决策判断和解决问题。如果把人脑比喻成计算机,那心智程序就是人脑的