c++ Socket客户端和服务端示例版本二
客户端
#include <stdio.h>
#include <stdlib.h>
#include <errno.h>
#include <sys/socket.h>
#include <sys/types.h>
#include <netinet/in.h>
#include <string.h>
#include<arpa/inet.h>
#include <error.h>
#include <unistd.h>
#include <arpa/inet.h>
#include <netinet/in.h>
//执行 ./ClientLinux.out 127.0.0.1 8080
int main(int arg, char* args[])
{
for (int i = ; i < ; i++)
{
printf("arg:%s\n",args[i]);
}
if (arg < )
{
printf("arg<3\n");
return - ;
}
int port = atoi(args[]);
//第一步:初始化一个socket实例
int st = socket(AF_INET, SOCK_STREAM, ); //第二步:定义一个IP地址结构并设置值
struct sockaddr_in addr;
//内存初始化,将addr变量指向的内存签n个字节用0进行初始化填充
memset(&addr, , sizeof(addr));
//设置采用的协议为TCP/IP协议
addr.sin_family = AF_INET;
//设置端口号
addr.sin_port = htons(port);
//设置IP地址
addr.sin_addr.s_addr = inet_addr(args[]); //第三步:开始连接服务端
if (connect(st, (struct sockaddr*) & addr, sizeof(addr)) == -)
{
printf("connect fail %s\n", strerror(errno));
return EXIT_FAILURE;
} //第四步:初始化要发送的信息并且通过send函数发送数据
while ()
{
char s[];
memset(s, , sizeof(s));
//read(STDIN_FILENO, s, sizeof(s));
scanf("%s", s);
//strcpy(s, "hello world");
if (send(st, s, strlen(s), ) == -)
{
printf("send fail %s\n", strerror(errno));
return EXIT_FAILURE;
}
//客户端接受服务端消息之前情况缓冲区
memset(s, , sizeof(s));
//客户端接受服务端返回的消息
int rc = recv(st, s, sizeof(s), );
if (rc > )//如果接受服务端消息成功,就打印出来
{
printf("client recv : %s\n", s);
}
else
{
break;
}
} close(st);
getchar();
return EXIT_SUCCESS;
}
服务端
#include <stdio.h>
#include <stdlib.h>
#include <errno.h>
#include <sys/socket.h>
#include <sys/types.h>
#include <netinet/in.h>
#include <string.h>
#include<arpa/inet.h>
#include <error.h>
#include <unistd.h>
#include <arpa/inet.h>
#include <netinet/in.h>
//执行命令 ./ServerLinux.out 8080
int main(int arg, char* args[])
{
for (int i = ; i < ; i++)
{
printf("参数%d:%s", i, args[i]);
}
if (arg<)
{
return -;
}
int port = atoi(args[]);
int st = socket(AF_INET, SOCK_STREAM, ); //setsockopt 设置socket的一个属性,让地址可以重用。
int on = ;
if (setsockopt(st, SOL_SOCKET, SO_REUSEADDR, &on, sizeof(on)) == -)
{
printf("setsockopt failed:%s\n", strerror(errno));
return EXIT_FAILURE;
}
struct sockaddr_in addr;
memset(&addr, , sizeof(addr));
addr.sin_family = AF_INET;
addr.sin_port = htons(port);
//INADDR_ANY表示这个服务器上的所有Ip地址。一台服务器可以有多个ip地址。将socket绑定到这个机器的所有ip地址上
addr.sin_addr.s_addr = htonl(INADDR_ANY); //将ip地址与server程序绑定
if (bind(st, (struct sockaddr*) & addr, sizeof(addr)) == -)
{
printf("bind fail %s\n", strerror(errno));
return EXIT_FAILURE;
}
//server开始监听。 20代表同时有多少个连接过来(20并发)
if (listen(st, ) == -)
{
printf("listen fail %s\n", strerror(errno));
return EXIT_FAILURE;
}
char s[];
int client_st = ;//客户端socket
socklen_t len = ;//
struct sockaddr_in client_addr;//客户端IP
void* p = &client_addr;
int i = ;
for (i = ; i < ; i++)
{
memset(&client_addr, , sizeof(client_addr));
socklen_t len = sizeof(client_addr);
//accept会阻塞,直到有客户端连接过来。accept返回客户端的描述符
client_st = accept(st, (struct sockaddr*) & client_addr, &len);
if (client_st == -)
{
printf("accept fail %s\n", strerror(errno));
return EXIT_FAILURE;
}
//打印客户端的ip地址
printf("accept ip : %s\n", inet_ntoa(client_addr.sin_addr));
memset(s, , sizeof()); ////接受来自客户端的消息
//if (recv(client_st, s, sizeof(s), 0) == -1)
//{
// printf("receive fail %s\n", strerror(errno));
// close(client_st);
// return EXIT_FAILURE;
//}
//printf("内容:%s\n", s); while ()
{
memset(s, , sizeof(s));
//recv是阻塞调用,如果客户端不关闭,那么服务端就会死等
int rc = recv(client_st, s, sizeof(s), );
if (rc > )
{
printf("receive success %s\n", s);
memset(s, , sizeof(s));
//从控制台接受输入的数据
scanf("%s", s);
//服务端向客户端返回消息
send(client_st, s, sizeof(s), );
}
else if (rc == )//如果客户端关闭连接,server端接受时,返回0
{
printf("receive close\n");
break;
}
else
{
printf("receive fail %s\n", strerror(errno));
break;
}
}
close(client_st);//关闭客户端的socket
}
close(st);
getchar();
}
c++ Socket客户端和服务端示例版本二的更多相关文章
- c++ Socket客户端和服务端示例版本三(多线程版本)
客户端 #include <stdio.h> #include <stdlib.h> #include <errno.h> #include <sys/soc ...
- c++ Socket客户端和服务端示例版本一
客户端 #include <stdio.h> #include <stdlib.h> #include <errno.h> #include <sys/soc ...
- c#Socket客户端和服务端的信息发送
这是我制作的界面信息,c# Socket通信的简单使用,刚开始学习,不对的地方请大家指教,目前是可以运行的,之后自己在慢慢添加新的东西.同时了解Tcp协议的三次握手.希望对跟我一样的初学者有所帮助. ...
- socket 客户端和服务端通信
客户端要连接服务器:首先要知道服务器的IP地址.而服务器里有很多的应用程序,每一个应用程序对应一个端口号 所以客户端想要与服务器中的某个应用程序进行通信就必须要知道那个应用程序的所在服务器的IP地址, ...
- java Socket通信,客户端与服务端相互发消息
1.通信过程 网络分为应用层,http.ssh.telnet就是属于这一类,建立在传输层的基础上.其实就是定义了各自的编码解码格式,分层如下: 2.Socket连接 上述通信都要先在传输层有建立连接的 ...
- 基于开源SuperSocket实现客户端和服务端通信项目实战
一.课程介绍 本期带给大家分享的是基于SuperSocket的项目实战,阿笨在实际工作中遇到的真实业务场景,请跟随阿笨的视角去如何实现打通B/S与C/S网络通讯,如果您对本期的<基于开源Supe ...
- swoole 客户端和服务端不断通信
server.php <?php class Chat { const HOST = '0.0.0.0';//ip地址 0.0.0.0代表接受所有ip的访问 const PART = 9501; ...
- socket创建TCP服务端和客户端
看情况选择相对应的套接字*面向连接的传输--tcp协议--可靠的--流式套接字(SOCK_STREAM)*面向无连接的传输--udp协议--不可靠的--数据报套接字(SOCK_DGRAM) 在liun ...
- c++ 网络编程(一)TCP/UDP windows/linux 下入门级socket通信 客户端与服务端交互代码
原文作者:aircraft 原文地址:https://www.cnblogs.com/DOMLX/p/9601511.html c++ 网络编程(一)TCP/UDP 入门级客户端与服务端交互代码 网 ...
随机推荐
- (65)CRC32校验C语言版本
#include<iostream> # include <stdio.h> # include <string.h> typedef unsigned int u ...
- 大数据笔记(二十三)——Scala语言基础
一.Scala简介:一种多范式的编程语言 (*)面向对象 (*)函数式编程:Scala的最大特点 (*)基于JVM 二.Scala的运行环境 (1)命令行:REPL 进入: scala 退出::qui ...
- 当遇到npm ERR! Unexpected end of JSON input while parsing near……时的解决办法
运行npm install时有时会遇到以下错误: npm ERR! Unexpected end of JSON input while parsing near ... 这时可以先执行下面的命令: ...
- node、npm、git版本升级
node版本升级: npm install -g n 或者 npm i -g n --force n stable或者n --stable:安装最近稳定版本 n latest或者n --latest: ...
- shell脚本之case用法
你会经常发现自己在尝试计算一个变量的值,在一组可能的值中寻找特定值.在这种情形下, 你不得不写出很长的if-then-else语句,就像下面这样. $ cat test25.sh #!/bin/bas ...
- C++引用与传参
# include <iostream> using namespace std; void Swap(int *pa, int *pb) { int t = *pa; *pa = *pb ...
- zabbix 内网监控云服务器
今天 搞监控碰到了一个问题就是.内网机器搭建的zabbix服务器去监控云服务器agent的时候,agent 需要写服务端的IP地址. 我的思路是内网服务器映射自己公网IP地址的zabbix的端口100 ...
- Unity Ray 射线
射线:射线是3D世界一个向一个方向发射的一条无终点的线,在发射轨迹中与其他物体发生碰撞时,它将停止发射. 用途:射线范围比较广,多用于碰撞检测(如:子弹飞行是否击中目标).角色移动等. Ray是一个结 ...
- lnmp 安装yarn
Linux 安装 curl --silent --location https://dl.yarnpkg.com/rpm/yarn.repo | sudo tee /etc/yum.repos.d/y ...
- zip函数用于对列表对应元素打包成元组
zip() 函数用于将可迭代的对象作为参数,将对象中对应的元素打包成一个个元组,然后返回由这些元组组成的列表. 如果各个迭代器的元素个数不一致,则返回列表长度与最短的对象相同,利用 * 号操作符,可以 ...