客户端

#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客户端和服务端示例版本二的更多相关文章

  1. c++ Socket客户端和服务端示例版本三(多线程版本)

    客户端 #include <stdio.h> #include <stdlib.h> #include <errno.h> #include <sys/soc ...

  2. c++ Socket客户端和服务端示例版本一

    客户端 #include <stdio.h> #include <stdlib.h> #include <errno.h> #include <sys/soc ...

  3. c#Socket客户端和服务端的信息发送

    这是我制作的界面信息,c# Socket通信的简单使用,刚开始学习,不对的地方请大家指教,目前是可以运行的,之后自己在慢慢添加新的东西.同时了解Tcp协议的三次握手.希望对跟我一样的初学者有所帮助. ...

  4. socket 客户端和服务端通信

    客户端要连接服务器:首先要知道服务器的IP地址.而服务器里有很多的应用程序,每一个应用程序对应一个端口号 所以客户端想要与服务器中的某个应用程序进行通信就必须要知道那个应用程序的所在服务器的IP地址, ...

  5. java Socket通信,客户端与服务端相互发消息

    1.通信过程 网络分为应用层,http.ssh.telnet就是属于这一类,建立在传输层的基础上.其实就是定义了各自的编码解码格式,分层如下: 2.Socket连接 上述通信都要先在传输层有建立连接的 ...

  6. 基于开源SuperSocket实现客户端和服务端通信项目实战

    一.课程介绍 本期带给大家分享的是基于SuperSocket的项目实战,阿笨在实际工作中遇到的真实业务场景,请跟随阿笨的视角去如何实现打通B/S与C/S网络通讯,如果您对本期的<基于开源Supe ...

  7. swoole 客户端和服务端不断通信

    server.php <?php class Chat { const HOST = '0.0.0.0';//ip地址 0.0.0.0代表接受所有ip的访问 const PART = 9501; ...

  8. socket创建TCP服务端和客户端

    看情况选择相对应的套接字*面向连接的传输--tcp协议--可靠的--流式套接字(SOCK_STREAM)*面向无连接的传输--udp协议--不可靠的--数据报套接字(SOCK_DGRAM) 在liun ...

  9. c++ 网络编程(一)TCP/UDP windows/linux 下入门级socket通信 客户端与服务端交互代码

    原文作者:aircraft 原文地址:https://www.cnblogs.com/DOMLX/p/9601511.html c++ 网络编程(一)TCP/UDP  入门级客户端与服务端交互代码 网 ...

随机推荐

  1. IT界须知的故事——仙童八叛徒

    原文:http://blog.sina.com.cn/s/blog_457012450100vnbl.html 许多电脑史学家都认为,要想了解美国硅谷的发展史,就必须了解早期的仙童半导体公司.这家公司 ...

  2. express 请求参数的一些问题

    先说点别的,项目入口是index.js,运行 node index 启动项目. 路由部分app.get('/', function(req, res) { res.send('hello, expre ...

  3. MATLAB之图像分块处理

    file_path = 'D:/MATLAB/bin/IMAGES/GreenChannels/_512_pixel/';% 图像文件夹路径 img_path_list = dir(strcat(fi ...

  4. linux上的常用的系统自带命令

    wikipedia 发现的分类,发现还有好多没用过.. Unix command-line interface programs and shell builtins   File system ca ...

  5. C++引用与传参

    # include <iostream> using namespace std; void Swap(int *pa, int *pb) { int t = *pa; *pa = *pb ...

  6. 一、基础篇--1.1Java基础-抽象类和接口的区别

    抽象类和接口的区别 抽象类和接口在设计层面的区别主要体现在:接口是对动作的抽象,抽象类是对根源.类的抽象.抽象类表示的是,这个对象是什么,接口表示的是,这个对象可以做什么. 比如,男人.女人是人,人是 ...

  7. 6、Shiro之自定义realm

    1.创建一个包存放我们自定义的realm文件: 创建一个类名为CustomRealm继承AuthorizingRealm并实现父类AuthorizingRealm的方法,最后重写: CustomRea ...

  8. Quartz最佳实践

    本文来自对http://www.quartz-scheduler.org/documentation/best-practices.html的翻译. 表示还没用过Quartz,正准备用的,然后在官网上 ...

  9. 阶段3 1.Mybatis_05.使用Mybatis完成CRUD_8 Mybatis中的返回值深入-调整实体类属性解决增和改方法的报错

    如果实体类和数据库表内的字段没有保持一致 修改了属性子弹. 重新生成getter和setter还有toString方法 测试类里面,相关set的方法就都会报错. 只需要修改为最新的set方法就可以了. ...

  10. 操作系统 - Windows操作系统 - WindowsXP - 安装|命令|使用 - 汇总

    开启ipc$ net share ipc$ 开启admin$ net share admin$ 端口 开放445端口对外访问系统层面:regedit -> 搜索HKEY_LOCAL_MACHIN ...