#include <stdio.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <arpa/inet.h>
#include <string.h>
#include <unistd.h>
#define PORT 9998
void handl_client(int client_socket)
{
char buf[1024] = {"asdsadsadsadsa"};
while (1)
{
int ret = read(client_socket, buf, sizeof(buf)-1);
if (-1 == ret)
{
perror ("read error");
}
if (0 == ret)
{
printf ("客户端退出\n");
break;
}
buf[ret] = '\0';
printf ("收到客户端数据:%s\n", buf);
int i;
for (i = 0; i < ret-1; i++)
{
buf[i] += 'A' - 'a';
}
write(client_socket, buf, ret);
}
}
int main(int argc, char **argv)
{
// 1、创建套接字
// 第一个参数:使用的协议族
// 第二个参数:使用的协议类型
// 第三个参数:一般写 0
int listen_socket = socket(AF_INET, SOCK_STREAM, 0);
if(-1 == listen_socket)
{
perror("创建套接字失败");
return -1;
}
struct sockaddr_in addr;
memset(&addr, 0, sizeof(struct sockaddr_in));
addr.sin_family = AF_INET; /* Internet地址族 */
addr.sin_port = htons(PORT); /* 端口号 */
addr.sin_addr.s_addr = htonl(INADDR_ANY); /* IP地址, 绑定本地的所有ip地址*/
// 2、绑定本地的 ip 地址和端口
// 第一个参数:需要绑定的套接字
// 第二个参数:是要绑定的ip和端口
// 第三个参数:第二个参数所占的字节数
int ret = bind(listen_socket, (const struct sockaddr *)&addr, sizeof(addr));
if(-1 == ret)
{
perror("绑定失败");
return -1;
}
// 3、监听套接字
ret = listen(listen_socket, 5);
if(-1 == ret)
{
perror("监听失败");
return -1;
}
printf ("等待客户端连接.........\n");
// 4、处理客户端的连接
// accept 是一个阻塞型函数,如果没有客户端连接,会一直阻塞
// 第一个参数:需要监听的套接字
// 第二个参数:如果成功建立连接,该参数保存的是连接的客户端的ip地址和端口
// 第三个参数:客户端地址的长度,该参数是一个传入传出参数,不能写NULL
// 返回值:如果成功连接,返回一个用于和客户端通信的套接字,不是之前的监听套接字,注意区分
struct sockaddr_in client_addr;
socklen_t len = sizeof(client_addr);
int client_socket = accept(listen_socket, (struct sockaddr *)&client_addr, &len);
if (-1 == client_socket)
{
perror("accept 失败");
return -1;
}
printf ("客户端的 ip = %s, 端口 = %d\n", inet_ntoa(client_addr.sin_addr), ntohs(client_addr.sin_port));
handl_client(client_socket);
return 0;
}
tcp服务器
最新推荐文章于 2024-03-25 01:17:00 发布