socket編程(三)---- 簡單的客戶端

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;
}




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