网络服务器的应用程序,面向连接的网络应用程序--服务器端

Linux环境下有专门用于读写面向连接的套接字函数,分别是send函数和recv函数,send函数和recv函数原型如下:

ssize_t recv(int sockfd, void *buff, size_t nbytes, int flags);

头文件: #include

参数说明:第一个参数sockfd是指定发送端套接字描述符,第二个参数buff存放要发送数据的缓冲区,第三个参数nbytes是实际要发送的数据的字节数,第四个参数flags一般设置为0。

返回值:成功返回发送实际发送的数据的字节数,失败返回-1.

ssize_t send(int sockfd, const void *buff, size_t nbytes, int flags);

头文件: #include

参数说明:第一个参数sockfd是指定发送端套接字描述符,第二个参数buff存放recv函数接收到数据的缓冲区,第三个参数nbytes是指明buff的长度,第四个参数flags一般设置为0。

返回值:recv函数返回值有3种情况

大于0,表示成功接收数据,返回值是实际接收的字节数;

等于0,表示无可用数据或者通信端已经结束了发送数据;

等于-1,表示接收数据出错。

现在要用send和recv函数来写一个面向连接数据传输的服务器端程序,流程图如下:

7517abf61dce84cd13a5059e0698aa9e.png

服务器端的执行流程

961d18b3bfe1bf6fd37f71020eea88f6.png

服务器端的执行流程B

程序代码如下所示:

#include #include#include#include#include#include#include#include

#define MAX_LINE 100

int main(void)

{structsockaddr_in sin;structsockaddr_in cin;intl_fd;intc_fd;

socklen_t len;charbuf[MAX_LINE];charaddr_p[INET_ADDRSTRLEN];int port = 8000;intn;

bzero(&sin, sizeof(sin));

sin.sin_family=AF_INET;

sin.sin_addr.s_addr=INADDR_ANY;

sin.sin_port=htons(port);/*创立套接字,使用TCP协议*/

if((l_fd = socket(AF_INET, SOCK_STREAM, 0)) == -1)

{

perror("fail to creat socket");

exit(1);

}/*将地址和套节字绑定*/

if(bind(l_fd, (struct sockaddr *) &sin, sizeof(sin)) == -1)

{

perror("fail to bind");

exit(1);

}/*开始监听连接请求*/

if(listen(l_fd, 10) == -1)

{

perror("fail to listren");

exit(1);

}

printf("waiting...\n");while(1)

{/*接受连接请求,从此函数中返回后就可以开始通信了*/

if((c_fd = accept(l_fd, (struct sockaddr *) &cin, &len)) == -1)

{

perror("fail to accept");

exit(1);

}/*调用recv函数读取客户端传来的信息,不设置任何特殊的标志*/n= recv(c_fd, buf, MAX_LINE, 0);if(n = -1)

{

perror("fail to receive");

exit(1);

}else if(n == 0)

{

printf("the connect has been closed\n");

close(c_fd);continue;

}/*将客户端地址转换为字符串*/inet_ntop(AF_INET,&cin.sin_addr, addr_p, sizeof(addr_p));

printf("client IP is %s, port is %s \n", addr_p, ntohs(cin.sin_port));

printf("connect is : %s\n", buf);

n=strlen(buf);

sprintf(buf,"%d", n);/*使用send函数将转换后的字符串发送给客户端,不设置任何特殊的标志*/n= send(c_fd, buf, strlen(buf) + 1, 0);if(n == -1)

{

perror("fail to send");

exit(1);

}if(cloes(c_fd) == -1)

{

perror("fail to close");

exit(1);

}

}return 0;

}

原文:http://www.cnblogs.com/Mr--Yang/p/6719917.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值