socket編程(三)---- 簡單的客戶端
1. socket客戶端函數描述
我們從上一篇文章的通信流程圖中可以看出,客戶端和服務端所有的函數基本一致,就只有一個用於建立連接的connect函數不同,下面我們來看看這個函數。
connect()
#include <sys/types.h> /* See NOTES */
#include <sys/socket.h>
int connect(int sockfd, const struct sockaddr *addr,
socklen_t addrlen);
客戶端與服務器端建立連接sockfd:套接字描述符
addr:客戶端的地址信息結構體
addrlen:上述結構體的大小
如果建立鍵連接成功,返回0,失敗返回-1
2. 搭建一個簡單的客戶端
#include<stdio.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <stdio.h>
#include <errno.h>
#include <unistd.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <string.h>
int main()
{
int sockfd = 0;
int ret = -1;
sockfd = socket(AF_INET, SOCK_STREAM, 0);
if(-1 == sockfd)
{
perror("func socket() error!");
return 0;
}
struct sockaddr_in addr;
addr.sin_family = AF_INET;
addr.sin_port = htons(4444);
addr.sin_addr.s_addr = inet_addr("127.0.0.1");
if( -1 == connect(sockfd, (struct sockaddr *)&addr, sizeof(addr)) )
{
perror("func connect() error!");
return 0;
}
char buff[100];
memset(buff, 0, sizeof(buff));
scanf("%s", buff);
ret = write(sockfd, buff, strlen(buff)); /* 發送數據,Linux上一切設備皆文件,顧所有的操作都能以文件的形式完成,成功返回發送的長度 */
if(ret < 0)
{
perror("func write() error!");
}
ret = recv(sockfd, buff, sizeof(buff), 0); /* 接收數據,返回接收的數據長度,等於0表示對方已關閉 */
if(ret < 0)
{
perror("func recv() error!");
close(sockfd);
return 0;
}
else if(0 == ret)
{
printf("peer has closed.\n");
close(sockfd);
return 0;
}
else
printf("recv: %s\n", buff);
close(sockfd);
return 0;
}