嵌入式linux實現scoket通信(語言)

服務端

等待客戶端的連接

#include <stdlib.h>
#include <sys/types.h>
#include <stdio.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <string.h>
#include <arpa/inet.h>
int main()
{
int sfp,nfp;  //定義兩個描述符
struct sockaddr_in s_add,c_add;
int sin_size;
unsigned short portnum=0x8888;  //服務端使用端口
printf("Hello,welcome to my server !\r\n");
sfp = socket(AF_INET,SOCK_STREAM, 0);
if(-1 == sfp)
{
printf("socket fail ! \r\n");
return -1;
}
printf("socket ok !\r\n");

//填充服務器端口地址信息,以便下面使用此地址和端口監聽
bzero(&s_add,sizeof(struct sockaddr_in));
s_add.sin_family=AF_INET;
s_add.sin_addr.s_addr=htonl(INADDR_ANY);//地址使用全0,即所有
s_add.sin_port=htons(portnum);
//使用bind進行端口綁定
if(-1 == bind(sfp,(struct sockaddr *)(&s_add), sizeof(struct sockaddr)))
{
printf("bind fail !\r\n");
return -1;
}
printf("bind ok !\r\n");
//開始監聽相應的端口
if(-1 == listen(sfp,5))
{
printf("listen fail !\r\n");
return -1;
}
printf("listen ok\r\n");
while(1)
{
sin_size = sizeof(struct sockaddr_in);
/*accept服務端使用函數,調用時即進入阻塞狀態,等待用戶進行連接,在沒有客戶端進行連接時,程序停止在此處, 
   不會看到後面的打印,當有客戶端進行連接時,程序馬上執行一次,然後再次循環到此處繼續等待。 
   此處accept的第二個參數用於獲取客戶端的端口和地址信息。*/
nfp = accept(sfp, (struct sockaddr *)(&c_add), &sin_size);
if(-1 == nfp)
{
printf("accept fail !\r\n");
return -1;
}
printf("accept ok!\r\nServer start get connect from %s : %#x\r\n",inet_ntoa(c_add.sin_addr),c_add.sin_port);

if(-1 == send(nfp,"hello,welcome to my server \r\n",32,0))
{
printf("write fail!\r\n");
return -1;
}
printf("write ok!\r\n");
close(nfp);
}
close(sfp);
return 0;
}

客戶端

#include <stdlib.h>
#include <sys/types.h>
#include <stdio.h>
#include<unistd.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <string.h>
#include <arpa/inet.h>
int main()
{
int cfd; //客戶端套接字
int recbytes;
int sin_size;
char buffer[1024]={0};
struct sockaddr_in s_add,c_add;
unsigned short portnum=0x8888;
char *s=NULL;
printf("Hello,welcome to client !\r\n");

cfd = socket(AF_INET, SOCK_STREAM, 0);
if(-1 == cfd)
{
printf("socket fail ! \r\n");
return -1;
}
printf("socket ok !\r\n");

bzero(&s_add,sizeof(struct sockaddr_in));
s_add.sin_family=AF_INET;
s_add.sin_addr.s_addr= inet_addr("127.0.0.1");
s_add.sin_port=htons(portnum);
s=inet_ntoa(*(struct in_addr*)&s_add.sin_addr.s_addr);
printf("server ip is:%s,port is:%#x\r\n",s,s_add.sin_port);
if(-1 == connect(cfd,(struct sockaddr *)(&s_add), sizeof(struct sockaddr)))
{
printf("connect fail !\r\n");
return -1;
}
printf("connect ok !\r\n");

if(-1 == (recbytes = recv(cfd,buffer,1024,0)))
{
printf("read data fail !\r\n");
return -1;
}
printf("read ok\r\nREC:\r\n");
buffer[recbytes]='\0';
printf("%s\r\n",buffer);
getchar();
close(cfd);
return 0;
}

運行結果

在這裏插入圖片描述
在這裏插入圖片描述

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章