局域网实现linux服务器端和客户端通信

一、配置两台电脑的网络

1.查看物理机ip地址

(1)Win+R打开运行,输入cmd
 
(2)在cmd下输入ipconfig得到本机ip为192.168.3.2
 

2.配置虚拟机ip

(1)打开虚拟机设置
 
(2)设置网络连接模式
 
(3)在Ubuntu下设置ip
 
注意:物理机和虚拟机的IP不能一样,但必须处于同一网段。
我测试的时候物理机IP是192.168.3.2,虚拟机IP设置的是192.168.3.190。
(4)测试两台电脑是否连通

在终端下输入ping 192.168.3.X

二、编写服务器端和客户端程序

1.服务器端代码

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <sys/un.h>
#include <arpa/inet.h>
#include <netinet/in.h>

const int port = 8888;
const char* ip = "192.168.64.190"; //服务器端IP

int main()
{
	  int ser_sock = socket(AF_INET, SOCK_STREAM, 0); //创建套接字,即创建socket 
	  if(ser_sock < 0)
	  {
		  perror("socket");
		  return 1;
	  }

	  struct sockaddr_in addr; //绑定信息,即命名socket
	  addr.sin_family = AF_INET; 
	  addr.sin_port = htons(port); 
	  addr.sin_addr.s_addr = inet_addr(ip); 
	  /*inet_addr函数将用点分十进制字符串表示的
	  IPv4地址转化为用网络字节序整数表示的IPv4地址 */
	  
	  if(bind(ser_sock, (struct sockaddr*)&addr, sizeof(addr)) < 0) 
	  {	            
	       perror("bind"); 
	       return 2; 	   
	  } 

	  int listen_sock = listen(ser_sock, 5); //监听socket
	  if(listen_sock < 0)
	  {
		  perror("listen");
		  return 3;
	  }

      /*接受连接*/
	  struct sockaddr_in peer;
	  socklen_t peer_len;
	  char buf[1024];
	  int accept_fd = accept(ser_sock, (struct sockaddr*)&peer, &peer_len);

	  if(accept_fd < 0)
	  {
		  perror("accept");
		  return 4;
	  }
	  else
	  {
		  printf("connect from %s, port %d \n", inet_ntop(AF_INET,&peer.sin_addr, buf, 1024), ntohs(peer.sin_port));
	  }

	  while(1)
	  {
		  memset(buf, '\0', sizeof(buf));
		  ssize_t size = read(accept_fd, buf, sizeof(buf) - 1);
		  if(size > 0)
		  {
			  printf("client: %s\n", buf);
		  }
		  else if(size == 0)
		  {
			  printf("read is done...\n");
			  break;
		  }
		  else 
		  {
			  perror("read");
			  break;
		  }
          printf("server:");
		  fflush(stdout);
          size = read(0, buf, sizeof(buf) - 1);
		  if(size > 0)
		  {
			  buf[size - 1] = '\0';
		  }
		  else if(size == 0)
		  {
			  printf("read is done...\n");
			  break;
		  }
		  else
		  {
			  perror("read");
			  break;
		  }	  
		  write(accept_fd, buf, strlen(buf));
	  }
		close(ser_sock);
	  return 0;
}

2.客户端代码

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <sys/un.h>
#include <arpa/inet.h>
#include <netinet/in.h>

const int port = 8888;
const char* ip = "192.168.64.190"; //服务器IP

int main()
{
	  int clt_sock = socket(AF_INET, SOCK_STREAM, 0); //创建套接字,即创建socket 
	  if(clt_sock < 0)
	  {
		  perror("socket");
		  return 1;
	  }

	  struct sockaddr_in addr; //绑定信息,即命名socket 
	  addr.sin_family = AF_INET; 
	  addr.sin_port = htons(port); 
	  addr.sin_addr.s_addr = inet_addr(ip); 
	  /*inet_addr函数将用点分十进制字符串表示的
	  IPv4地址转化为用网络字节序整数表示的IPv4地址 */

	  //发起连接
	  socklen_t addr_len = sizeof(addr);
	  int connect_fd = connect(clt_sock, (struct sockaddr*)&addr, addr_len);
	  if(connect_fd < 0)
	  {
		  perror("connect");
		  return 2;
	  }
	  char buf[1024];

	  while(1)
	  {
		  memset(buf, '\0', sizeof(buf));
		  printf("client please enter: ");
		  fflush(stdout);
		  ssize_t size = read(0, buf, sizeof(buf) - 1);
		  if(size > 0)
		  {
			  buf[size - 1] = '\0';
		  }
		  else if(size == 0)
		  {
			  printf("read is done...\n");
			  break;
		  }
		  else
		  {
			  perror("read");
			  return 4;
		  }
		 // printf("client: %s\n", buf);
          write(clt_sock, buf, strlen(buf));
		  size = read(clt_sock, buf, sizeof(buf));
		  if(size > 0)
		  {
		 	  buf[size] = '\0';
		  }
		  else if(size == 0)
		  {
			  printf("read is done...\n");
			  break;
		  }
		  else 
		  {
			  perror("read");
			  return 5;
		  }
		  printf("server: %s\n", buf);
	   }
	  close(clt_sock);
	  return 0;
}

三、运行结果


 
  • 6
    点赞
  • 36
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值