client  and  server Demo of socket.

client send data to server.

server send data to client.

// this is client

#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <assert.h>
#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
#include <errno.h>
#include <string.h> #define BUFF_SIZE 1024 int main(int argc, char* argv[])
{
if(argc<=)
{
printf("usage:%s ip_address port_number \r\n", basename(argv[]));
return ;
} char* ip = argv[];
int port = atoi(argv[]); struct sockaddr_in address;
bzero(&address, sizeof(address));
address.sin_family = AF_INET;
address.sin_port = htons(port);
inet_pton(AF_INET,ip, &address.sin_addr); int sockfd = socket(PF_INET, SOCK_STREAM, );
assert(sockfd>=); struct sockaddr_in client; int connfd = connect(sockfd, (struct sockaddr*)&address, sizeof(address));
if(connfd < )
{
printf("errno is : %d...connection failed.\r\n", errno );
}
else
{ printf("client:----send-----start\r\n");
char data1[] = "C2S:hello server..";
char data2[] = "C2S:I am client.";
char data3[] = "C2S:centos6 system.Bye-Bye";
send(sockfd, data1, strlen(data1)+, );
sleep();
send(sockfd, data2, strlen(data2)+, );
sleep();
send(sockfd, data3, strlen(data3)+, );
sleep();
printf("client:----send-----finish\r\n"); printf("client:----recv-----start\r\n");
char buffer[BUFF_SIZE];
memset(buffer, '\0', sizeof(buffer));
int ret = recv(sockfd,buffer,sizeof(buffer)-,);
printf("get %d bytes. data:[%s]\r\n", ret, buffer); memset(buffer, '\0', sizeof(buffer));
ret = recv(sockfd,buffer,sizeof(buffer)-,);
printf("get %d bytes. data:[%s]\r\n", ret, buffer); memset(buffer, '\0', sizeof(buffer));
ret = recv(sockfd,buffer,sizeof(buffer)-,);
printf("get %d bytes. data:[%s]\r\n", ret, buffer);
printf("client:----recv-----finish\r\n"); //========================================== buffer[BUFF_SIZE];
memset(buffer, '\0', sizeof(buffer));
ret = recv(sockfd,buffer,sizeof(buffer)-,);
printf("get %d bytes. data:[%s]\r\n", ret, buffer); memset(buffer, '\0', sizeof(buffer));
ret = recv(sockfd,buffer,sizeof(buffer)-,);
printf("get %d bytes. data:[%s]\r\n", ret, buffer); memset(buffer, '\0', sizeof(buffer));
ret = recv(sockfd,buffer,sizeof(buffer)-,);
printf("get %d bytes. data:[%s]\r\n", ret, buffer); close(connfd);
} printf("-----connect closed----\r\n"); close(sockfd); return ;
}

this is  server:

#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <assert.h>
#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
#include <errno.h>
#include <string.h> #define BUFF_SIZE 1024 int main(int argc, char* argv[])
{
if(argc<=)
{
printf("usage:%s ip_address port_number \r\n", basename(argv[]));
return ;
} char* ip = argv[];
int port = atoi(argv[]); struct sockaddr_in address;
bzero(&address, sizeof(address));
address.sin_family = AF_INET;
address.sin_port = htons(port);
inet_pton(AF_INET,ip, &address.sin_addr); int sockfd = socket(PF_INET, SOCK_STREAM, );
assert(sockfd>=); int ret = bind(sockfd,(struct sockaddr*)&address, sizeof(address));
assert(ret!=-); ret = listen(sockfd,);
assert(ret!=-); struct sockaddr_in client;
socklen_t client_addlength = sizeof(client);
int connfd = accept(sockfd, (struct sockaddr*)&client, &client_addlength);
if(connfd < )
{
printf("errno is : %d\r\n", errno );
}
else
{
printf("server:----recv-----start\r\n");
char buffer[BUFF_SIZE];
memset(buffer, '\0', sizeof(buffer));
int ret = recv(connfd,buffer,sizeof(buffer)-,);
printf("get %d bytes. data:[%s]\r\n", ret, buffer); memset(buffer, '\0', sizeof(buffer));
ret = recv(connfd,buffer,sizeof(buffer)-,);
printf("get %d bytes. data:[%s]\r\n", ret, buffer); memset(buffer, '\0', sizeof(buffer));
ret = recv(connfd,buffer,sizeof(buffer)-,);
printf("get %d bytes. data:[%s]\r\n", ret, buffer);
printf("server:----recv-----finish\r\n");
sleep(); printf("server:----send-----start\r\n");
char data1[] = "S2C:hello client..";
char data2[] = "S2C:I am server.";
char data3[] = "S2C:centos7 system.Bye-Bye";
send(connfd, data1, strlen(data1)+, ); sleep();
send(connfd, data2, strlen(data2)+, );
sleep();
send(connfd, data3, strlen(data3)+, );
sleep();
printf("server:----send-----finish\r\n"); //======================================== close(STDOUT_FILENO);
dup(connfd); //N messages , once recv.
printf("S2C:==dup==I am server.centos7.");
printf("S2C:==dup==Hello client...");
printf("S2C:==dup==bye-bye."); close(connfd);
} printf("server----------connection closed--------"); close(sockfd); return ;
}

Linux socket program Demo1(client & server)的更多相关文章

  1. AndroidAsync :异步Socket,http(client+server),websocket和socket.io的Android类库

    AndroidAsync是一个用于Android应用的异步Socket,http(client+server),websocket和socket.io的类库.基于NIO,没有线程.它使用java.ni ...

  2. Linux SocketCan client server demo hacking

    /*********************************************************************** * Linux SocketCan client se ...

  3. Client/Server 模型 与socket

    Client/Server 模型  Sockets 是以 Client 和 Server 交互通信方式来使用的.典型的系统配置是把 Server 放在一台机器中,而把 Client 放在另一台机器中, ...

  4. 深入浅出 Redis client/server交互流程

    综述 最近笔者阅读并研究redis源码,在redis客户端与服务器端交互这个内容点上,需要参考网上一些文章,但是遗憾的是发现大部分文章都断断续续的非系统性的,不能给读者此交互流程的整体把握.所以这里我 ...

  5. Network client/server

    <Beginning Linux Programming_4th>  chapter 15 Sockets 1  A simple local client/server 1)  clie ...

  6. linux socket高性能服务器处理框架

    这个博客很多东西 http://blog.csdn.net/luozhonghua2014/article/details/37041765   思考一种高性能的服务器处理框架 1.首先需要一个内存池 ...

  7. Linux socket编程 DNS查询IP地址

    本来是一次计算机网络的实验,但是还没有完全写好,DNS的响应请求报文的冗余信息太多了,不只有IP地址.所以这次的实验主要就是解析DNS报文.同时也需要正确的填充请求报文.如果代码有什么bug,欢迎指正 ...

  8. [Python]再学 socket 之非阻塞 Server

    再学 socket 之非阻塞 Server 本文是基于 python2.7 实现,运行于 Mac 系统下 本篇文章是上一篇初探 socket 的续集, 上一篇文章介绍了:如何建立起一个基本的 sock ...

  9. Linux Socket 编程简介

    在 TCP/IP 协议中,"IP地址 + TCP或UDP端口号" 可以唯一标识网络通讯中的一个进程,"IP地址+端口号" 就称为 socket.本文以一个简单的 ...

随机推荐

  1. win7和win10自带桌面便签哪里找

    一些小伙伴习惯使用windows自带的便签功能,但win7和win10区别较大, 导致更新系统后不知道在哪里找,甚至以为没有该功能了, 其实不然,下面我总结了2种方法,希望能帮到有需要的人 win7( ...

  2. rxjava介绍

    Observable 在RxJava1.x中,最熟悉的莫过于Observable这个类了,笔者刚使用RxJava2.x时,创建一个Observable后,顿时是懵逼的.因为我们熟悉的Subscribe ...

  3. 打开excel打印时报“不能使用对象链接和嵌入”

    解决思路: 1.以WIN + R 打开命令行, 在命令行中输入dcomcnfg,打开组件服务. 2.在组件服务窗口中,点击到[控制根节点]->[组件服务]->[计算机]->[我的电脑 ...

  4. .Net与其他公司接口对接心得

    第一次搞这玩意,心里有点紧张,万事开头难,第一次搞过之后,以后就容易了,所以将这次经历记录下来. 这里我们暂且把对接的公司叫A吧,A公司会提供一个接口对接说明,下面是A公司提供的接口说明 请求内容说明 ...

  5. JS基础语法---函数练习part2---10个综合练习(运用:循环/数组/函数)

    练习1:求2个数中的最大值 function getMax(num1, num2) { return num1 > num2 ? num1 : num2; } console.log(getMa ...

  6. uni-app自定义Modal弹窗组件|仿ios、微信弹窗效果

    介绍 uniapp自定义弹窗组件uniPop,基于uni-app开发的自定义模态弹窗|msg信息框|alert对话框|confirm确认框|toast弱提示框 支持多种动画效果.多弹窗类型ios/an ...

  7. 区块链社交APP协议分析预告

    2017年,比特币的火热,直接导致了代币市场的繁荣: 2018年,作为信用体系的未来解决方案,区块链引发了互联网原住民的淘金热. 作为风口上的引流神器,区块链技术与社交网络结合起来,产生了一系列区块链 ...

  8. 如何使用 CODING 进行瀑布流式研发

    你好,欢迎使用CODING!这份最佳实践将帮助你通过 CODING 更好地实践瀑布流式开发流程. 什么是瀑布流式研发 1970 年温斯顿·罗伊斯(Winston Royce)提出了著名的"瀑 ...

  9. [b0035] python 归纳 (二十)_多进程数据共享和同步_共享内存Value & Array

    1. Code # -*- coding: utf-8 -*- """ 多进程 数据共享 共享变量 Value,Array 逻辑: 2个进程,对同一份数据,一个做加法,一 ...

  10. mysql-操作篇

    # ### mysqlctrl + l 清屏ctrl + c 终止[linux]service mysql start 启动mysqlservice mysql stop 停止mysqlservice ...