linux下第一个socket编程实现的局域网内通信(基于TCP)

<span style="font-family: Arial, Helvetica, sans-serif;">服务器端:</span>

#include<stdio.h>
#include<unistd.h>
#include<stdlib.h>
#include<sys/socket.h>
#include<sys/types.h>
#include<sys/socket.h>
#include<netinet/in.h>
int main(int argc, char *argv[])
{
	int server_sockfd, client_sockfd;
	int server_len, client_len;
	struct sockaddr_in server_address;
	struct sockaddr_in client_address;
	int i, byte;
	char char_send[100], char_recv[100];
	unlink("server_socket");            //删除原有server_socket对象
	server_sockfd = socket(AF_INET, SOCK_STREAM, 0); 
	server_address.sin_family = AF_INET;
	//server_address.sin_addr.s_addr = htonl(INADDR_ANY);
	server_address.sin_addr.s_addr = inet_addr("192.168.1.102"); //服务器地址
	server_address.sin_port = 9735;   //服务器监听地址
	server_len = sizeof(server_address);


	bind(server_sockfd, (struct sockaddr *)&server_address, server_len);
	//绑定socket对象
	listen(server_sockfd, 5);
	printf("server linsting\n");

	client_len = sizeof(client_address);
	client_sockfd = accept(server_sockfd, (struct sockaddr *)&client_address, (socklen_t *)&client_len);
	while(1) {
		if((byte = recv(client_sockfd, &char_recv, strlen(char_recv), 0)) == -1) {
			perror("recv");
			exit(EXIT_FAILURE);
		}
		printf("recv:%s\n", char_recv);
		printf("send:");
		//scanf("%s\n", char_send);
		gets(char_send);
		if((byte = send(client_sockfd, &char_send, strlen(char_send), 0)) == -1) {
			perror("send");
			exit(EXIT_FAILURE);
		}
	}
	shutdown(client_sockfd, 2);
	shutdown(server_sockfd, 2);
	return 0;
}


client端:


#include<stdio.h>
#include<sys/types.h>
#include<sys/socket.h>
#include<netinet/in.h>
#include<arpa/inet.h>
#include<unistd.h>
#include<stdlib.h>
int main(int argc, char *argv[])
{
	int sockfd;
	int len;
	struct sockaddr_in address;
	int result;
	int i,byte;
	char char_recv[100], char_send[100];
	if((sockfd = socket(AF_INET, SOCK_STREAM, 0)) == -1) {
		perror("socket");
		exit(EXIT_FAILURE);
	}
	address.sin_family = AF_INET;
	address.sin_addr.s_addr = inet_addr("192.168.1.102"); //服务器地址
	address.sin_port = 9735;   //服务器监听地址
	len = sizeof(address);
	if((result = connect(sockfd, (struct sockaddr *)&address, len)) == -1) {
		perror("connect");
		exit(EXIT_FAILURE);
	}
	while(1) {
		printf("send:");
	//	scanf("%s\n",char_send);
		gets(char_send);
		if((byte = send(sockfd, &char_send, strlen(char_send), 0)) == -1) {
			perror("send");
			exit(EXIT_FAILURE);
		}


		if((byte = recv(sockfd, &char_recv, strlen(char_recv), 0)) == -1) {
			perror("recv");
			exit(EXIT_FAILURE);
		}
		printf("recv:%s\n", char_recv);
	}
	close(sockfd);
	return 0;
}


程序只是简单的实现通信,下一步准备实现多线程多人聊天

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值