1. 程式人生 > >Linux客戶端與伺服器相互實現聊天功能

Linux客戶端與伺服器相互實現聊天功能

這個實現方法只能夠單執行緒聊天,recv是阻塞的,你發一句我回一句,必須一來一回,後文會記錄多執行緒實現聊天

客戶端程式碼如下

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

int main(int arg, char *args[])
{
	if (arg < 3)
	{
		return -1;
	}

	int port = atoi(args[2]);
	int st = socket(AF_INET, SOCK_STREAM, 0);//初始化socket

	struct sockaddr_in addr; // 定義一個IP地址的結構
	memset(&addr, 0, sizeof(addr));
	addr.sin_family = AF_INET;// 設定結構地址型別為TCP/IP地址
	addr.sin_port = htons(port); // 制定一個埠號:8080,htons:將short型別從host位元組型別轉到net位元組型別
	// 將字元型別的IP地址轉化為int,賦給addr結構
	//addr.sin_addr.s_addr = inet_addr("127.0.0.1");
	addr.sin_addr.s_addr = inet_addr(args[1]);

	//
	if (connect(st, (struct sockaddr *)&addr, sizeof(addr)) == -1)
	{
		printf("connect failed %s\n", strerror(errno));
		return EXIT_FAILURE;
	}

	char s[1024];
	while (1)
	{
		memset(s, 0, sizeof(1024));
		read(STDIN_FILENO, s, sizeof(s)); // 從鍵盤讀取使用者輸入
		if (send(st, s, strlen(s), 0) == -1)
		{
			printf("send failed %s\n", strerror(errno));
			return EXIT_FAILURE;
		}

		memset(s, 0, sizeof(s));
		if (recv(st, s, sizeof(s), 0) > 0)// 如果接受資料失敗迴圈結束,這裡是阻塞呼叫,會停在這裡等待服務端傳送訊息,服務端也是一樣
			printf("recv %s\n", s);
		else
			break;
	}
	close(st);

	return EXIT_SUCCESS;
}
服務端程式碼如下
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <errno.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>

int main(int arg, char *args[])
{
	if (arg < 2)
	{
		return -1;
	}
	int port = atoi(args[1]);
	int st = socket(AF_INET, SOCK_STREAM, 0); //初始化socket

	int on = 1;
	if (setsockopt(st, SOL_SOCKET, SO_REUSEADDR, &on, sizeof(on)) == -1)
	{
		printf("setsockopt failed %s\n", strerror(errno));
		return EXIT_FAILURE;
	}

	struct sockaddr_in addr; // 定義一個IP地址結構
	memset(&addr, 0, sizeof(addr));
	addr.sin_family = AF_INET; // 將addr結構的屬性定位為TCP/IP地址
	addr.sin_port = htons(port); // 將本地位元組順序轉化為網路位元組順序
	addr.sin_addr.s_addr = htonl(INADDR_ANY); // INADDR_ANY代表這個server上所有的地址

	// 將ip與server程式繫結
	if (bind(st, (struct sockaddr *) &addr, sizeof(addr)) == -1)
	{
		printf("bind failed %s\n", strerror(errno));
		return EXIT_FAILURE;
	}

	// server端開始listen
	if (listen(st, 20) == -1)
	{
		printf("listen failed %s\n", strerror(errno));
		return EXIT_FAILURE;
	}
	//printf("listen success\n");
	char s[1024];
	int client_st = 0;
	struct sockaddr_in client_addr; // 表示client端的IP地址
	int i;
	for (i = 0; i < 5; i++)
	{
		memset(&client_addr, 0, sizeof(client_addr));
		socklen_t len = sizeof(client_addr);
		// accept會阻塞,直到有客戶端連線過來,accept返回client的socket描述符
		client_st = accept(st, (struct sockaddr*) &client_addr, &len);
		if (client_st == -1)
		{
			printf("accept failed %s\n", strerror(errno));
			return EXIT_FAILURE;
		}

		printf("accept by %s\n", inet_ntoa(client_addr.sin_addr));
		while (1)
		{
			memset(s, 0, sizeof(1024));
			int rc = recv(client_st, s, sizeof(s), 0);// 是阻塞呼叫,客戶端也是一樣
			if (rc > 0)
			{
				printf("revc is %s\n", s);
				memset(s, 0, sizeof(s));
				read(STDIN_FILENO, s, sizeof(s));
				send(client_st, s, strlen(s), 0);
			} else
			{
				if (rc == 0)
				{
					printf("client socket closed\n");
				}
				else
				{
					printf("recv failed %s\n", strerror(errno));
				}
				break;
			}
		}
		close(client_st);


	}
	close(st);
	return 0;
}

makefile檔案如下
.SUFFIXES: .c .o

CC=gcc
ASRCS=sock.c			
BSRCS=server.c
	
AOBJS=$(ASRCS:.c=.o)
BOBJS=$(BSRCS:.c=.o)

AEXEC=client
BEXEC=server

all:$(AOBJS) $(BOBJS)
	$(CC) -o $(AEXEC) $(AOBJS)
	$(CC) -o $(BEXEC) $(BOBJS)
	@echo '-------------ok--------------'

.c.o:
	$(CC) -Wall -g -o [email protected]
-c $< clean: rm -f $(AOBJS) rm -f $(BOBJS) rm -f core*



相關推薦

Linux客戶伺服器相互實現聊天功能

這個實現方法只能夠單執行緒聊天,recv是阻塞的,你發一句我回一句,必須一來一回,後文會記錄多執行緒實現聊天 客戶端程式碼如下 #include <stdio.h> #include <stdlib.h> #include <string.h

SWUST--Java實驗(七) 客戶伺服器聊天實現

import java.awt.BorderLayout; import java.awt.EventQueue; import javax.swing.JFrame; import javax.swing.JPanel; import javax.swing.border.EmptyBorde

基於TCP協議實現Linux客戶伺服器之間的通訊,實現多執行緒、多程序伺服器

TCP是TCP/IP協議族中一個比較重要的協議,這是一種可靠、建立連結、面向位元組流的傳輸,工作在傳輸層。和TCP相對的不可靠、無連結、面向資料報的協議UDP,瞭解UDP客戶端與伺服器之間通訊請戳UDP協議實現的伺服器與客戶端通訊 TCP協議建立連線 首

linux下socket實現多個客戶伺服器的通訊

學習完《UNIX環境高階程式設計》套接字一章的內容之後,自己實現了單個客戶端與伺服器的通訊程式,後面想想要是多個客戶端如何與伺服器通訊呢?這就有了這篇文章。 伺服器端程式: #include<stdio.h> #include <stdlib.h&g

linux下socket程式設計 select實現非阻塞模式多臺客戶伺服器通訊

select函式原型如下: int select (int maxfds, fd_set *readfds, fd_set *writefds, fd_set *exceptfds, struct timeval *timeout); select系統呼叫是用來讓我們的程式

Python中的TCP程式設計,實現客戶伺服器聊天(socket)

1、在TCP中,客戶端的實現流程:(1)、建立客戶端的socket物件   (2)、建立與伺服器之間的聯絡  (3)、傳送請求  (4)、接收資料  (5)、關閉連線 2、服務端的實現流程:(1)、建立服務端的socket物件  (2)、繫結服務端的地址 (3)、設定監聽器

Socket編程實現客戶服務器一對一聊天

bug servers sys 編程 獲取 post edr class 一個 Socket(套接字) 使用Socket編程實現數據的交互需要經歷以下幾個步驟: 1、創建Socket: Socket socket = new Socket("host",p

五、通過Protobuf整合Netty實現對協議訊息客戶伺服器通訊實戰

目錄 一、Protocol Buffers 是什麼? 二、Protocol Buffers 檔案和訊息詳解 三、專案實戰,直接掌握的protobuf應用。 一、Protocol Buffers 是什麼?         1、官網翻譯

java利用socket實現客戶伺服器的連線資料傳遞

網路上的兩個程式通過一個雙向的通訊連線實現資料的交換,這個雙向鏈路的一端稱為一個 socket。socket 也就是套接字,可以用來實現不同虛擬機器或者不同計算機之間的通訊。在 Java 語言中,socket 可以分為兩種型別:面向連線的 socket 通訊協議(TCP)和麵向無連線的 socket

實現PHP伺服器+Android客戶(Retrofit+RxJava)第四天客戶伺服器通訊的實現

我的上一篇文章已經介紹了retrofit+rxjava的配置(包括快取),從這一篇開始就開始講我要實現的這個app網路請求部分的構思,也就是要請求那些資料,資料的型別等等。 我要實現的客戶端 看圖: 看了介面基本應該能知道要實現的效果了

利用Python中SocketServer 實現客戶伺服器間非阻塞通訊

利用SocketServer模組來實現網路客戶端與伺服器併發連線非阻塞通訊。 首先,先了解下SocketServer模組中可供使用的類: BaseServer:包含伺服器的核心功能與混合(mix-in)類掛鉤;這個類只用於派生,所以不會生成這個類的例項;可以考慮使用TCPS

Java NIO學習筆記(四) 使用JDK 1.7 NIO2.0 實現客戶伺服器的通訊

JDK1.7 提供了全新的非同步NIO模式。稱為:NIO2.0或AIO。該模式引入了新的非同步通道的概念,並提供了非同步檔案通道和非同步套接字通道的實現。非同步通道提供兩種方式獲取獲取操作結果。分別是: 通過java.util.concurrent

2017.8.22 用python實現簡單基於TCP/IP的客戶伺服器

伺服器端 import socket serversocket=socket.socket(socket.AF_INET,socket.SOCK_STREAM) serversocket.bind((

Onvif客戶伺服器通訊時鑑權的自實現

OnvifDigest.h /** SHA1 digest size in octets */ #define SOAP_SMD_SHA1_SIZE (20) /** Size of the random nonce */ #define SOAP_WSSE_NONCELEN (20) #define

Qt實現客戶伺服器訊息傳送檔案傳輸

客戶端與伺服器之間的資料傳送在很多案例場景裡都會有應用。這裡Jungle用Qt來簡單設計實現一個場景,即: ①兩端:伺服器QtServer和客戶端QtClient ②功能:服務端連線客戶端,兩者能夠互相傳送訊息,傳送檔案,並且顯示檔案傳送進度。 環境:VS

Mina長連線框架實現Android客戶伺服器通訊

一、概述         Apache Mina Server 是一個網路通訊應用框架,也就是說,它主要是對基於TCP/IP、UDP/IP協議棧的通訊框架(當然,也可以提供JAVA 物件的序列化服務、虛擬機器管道通訊服務等),Mina 可以幫助我們快速開發高效能、高擴充套件

Linux下網路程式設計之自定義協議進行併發多客戶伺服器的通訊(多程序處理併發)不足佔用資源太多

自定義協議訊息體*********msg.h*************#ifndef _MSG_H_#define _MSG_H_struct msg{ char head[10]; //頭部 char msg_chck; //效驗碼 char buff[512];/

Socket模擬客戶伺服器

程式碼如下: #include <stdio.h> #include <WinSock2.h> #include <process.h> #pragma comment(lib, "ws2_32.lib") HANDLE g_hEvent = NUL

Socket-tcp協議客戶伺服器互聯

客戶端 using System; using System.Collections.Generic; using System.Linq; using System.Net; using System.Net.Sockets; using System.Text; using System.T

01-撩課JavaEE-客戶伺服器

一、CS與BS Client/Server:PC客戶端、伺服器架構 Client/Server PC客戶端、伺服器架構 特點: 在伺服器當中就主要是一個數據庫, 把所有的業務邏輯以及介面都交給客戶端完成 優點: 較為安全,使用者介面豐富,使用者體驗好 缺點: