iOS開發(fā)項目- 基于WebSocket的聊天通訊(1)
公司項目需要開發(fā)一個類似QQ、微信的即時IM聊天功能,做到實(shí)時監(jiān)控消息,需要用的技術(shù)是websocket。
概述WebSocket:
1.1 為什么我們需要WebSocket這樣的實(shí)時的通信協(xié)議?
WebSocket是web通信方式的一種,像我們熟知的HTTP協(xié)議也是web通信方式的一種。但是我們知道HTTP協(xié)議是一種無狀態(tài)的協(xié)議,其服務(wù)端本身不具備識別客戶端的能力,必須借助外部的一些信息比如說session和cookie,才能與特定的客戶端保持通信。也就是說我們所發(fā)送的每一個HTTP的請求都會帶上請求頭中一些相應(yīng)的信息還有cookie,這明顯會增加我們傳輸?shù)男畔⒌捏w量從而帶來一定的網(wǎng)絡(luò)延遲,對于一些對通信的實(shí)時性要求比較高的應(yīng)用來說就是不可忍受的了,比如說聊天程序或者是運(yùn)行在瀏覽器中的實(shí)時小游戲。最郁悶的卻還是這些頭信息和cookie往往對于服務(wù)器響應(yīng)客戶端的請求來說是多余的,也就是說雖然我每個請求都帶了這些信息,但是服務(wù)器與客戶端的交互過程中可能根本用不上這些信息。
為了改善HTTP請求的這種網(wǎng)絡(luò)延遲的情況,也出現(xiàn)了一些適應(yīng)不同需求的其他的[web通信]方式,比如說:輪詢,長輪詢(long-polling),數(shù)據(jù)流,EventSouce等等,WebSocket便是其中一種。
實(shí)際上大多數(shù)基于因特網(wǎng)(或者局域網(wǎng))的網(wǎng)絡(luò)鏈接通常都包含長連接和基于TCP套接字的雙向消息交換。但是TCP協(xié)議是屬于最底層的網(wǎng)絡(luò)通信協(xié)議了,讓一些不能信任的客戶端腳本去訪問底層的TCP套接字顯然是不太安全的,因此WebSocket實(shí)現(xiàn)了一種較為安全的方案,它允許客戶端腳本在客戶端和支持WebSocket協(xié)議的服務(wù)器之間創(chuàng)建雙向的套接字連接。從而使實(shí)時通信的某些網(wǎng)絡(luò)操作變得簡單。
1.2 WebSocket是如何工作的?
我們知道了WebSocket的主要作用是,允許服務(wù)器端與客戶端進(jìn)行全雙工(full-duplex)的實(shí)時通信。這里有個例子特別好:HTTP協(xié)議像發(fā)電子郵件,發(fā)出后必須等待對方回信;WebSocket則是像打電話,服務(wù)器端和客戶端可以同時向?qū)Ψ桨l(fā)送數(shù)據(jù),它們之間存著一條持續(xù)打開的數(shù)據(jù)通道。
1.Pod導(dǎo)入SocketRocket
platform :ios,'7.0' target '白__Socket--Demo1' do pod 'SocketRocket', '~> 0.5.1' end
2.導(dǎo)入對象SRWebSocket
#import "ViewController.h"
#import "SRWebSocket.h"
@interface ViewController ()<SRWebSocketDelegate>
@property(nonatomic,strong) SRWebSocket *webSocket;
@end
@implementation ViewController
- (void)viewDidLoad {
[super viewDidLoad];
}
//初始化
- (void)Reconnect{
NSLog(@"1221---open");
self.webSocket.delegate = nil;
[self.webSocket close];
self.webSocket = [[SRWebSocket alloc] initWithURLRequest:[NSURLRequest requestWithURL:[NSURL URLWithString:@"ws://192.168.5.120:4141"]]];
self.webSocket.delegate = self;
self.title = @"Opening Connection...";
[self.webSocket open];
}
- (void)viewWillAppear:(BOOL)animated{
[self Reconnect];
}
- (void)viewDidDisappear:(BOOL)animated{
// Close WebSocket
self.webSocket.delegate = nil;
[self.webSocket close];
self.webSocket = nil;
}
3.SRWebSocketDelegate
//連接成功
//代理方法實(shí)現(xiàn)
#pragma mark - SRWebSocketDelegate
- (void)webSocketDidOpen:(SRWebSocket *)webSocket{
NSLog(@"Websocket Connected");
self.title = @"Connected!";
}
//連接失敗
- (void)webSocket:(SRWebSocket *)webSocket didFailWithError:(NSError *)error{
NSLog(@":( Websocket Failed With Error %@", error);
self.title = @"Connection Failed! (see logs)";
self.webSocket = nil;
}
//接收到新消息的處理
- (void)webSocket:(SRWebSocket *)webSocket didReceiveMessage:(id)message{
// NSString *str1 = self.replyContent.text;
// NSString *str2 = [str1 stringByAppendingFormat:@"%@\n",message];
// self.replyContent.text = str2;
NSLog(@"%@--askl",message);
}
//連接關(guān)閉
- (void)webSocket:(SRWebSocket *)webSocket didCloseWithCode:(NSInteger)code reason:(NSString *)reason wasClean:(BOOL)wasClean{
NSLog(@"Closed Reason:%@",reason);
self.title = @"Connection Closed! (see logs)";
self.webSocket = nil;
}
//該函數(shù)是接收服務(wù)器發(fā)送的pong消息,其中最后一個是接受pong消息的,
在這里就要提一下心跳包,一般情況下建立長連接都會建立一個心跳包,
用于每隔一段時間通知一次服務(wù)端,客戶端還是在線,這個心跳包其實(shí)就是一個ping消息,
我的理解就是建立一個定時器,每隔十秒或者十五秒向服務(wù)端發(fā)送一個ping消息,這個消息可是是空的
- (void)webSocket:(SRWebSocket *)webSocket didReceivePong:(NSData *)pongPayload{
NSString *reply = [[NSString alloc] initWithData:pongPayload encoding:NSUTF8StringEncoding];
NSLog(@"%@",reply);
}
#pragma mark - SendButton Response
- (IBAction)sendAction:(id)sender {
[self.view endEditing:YES];
// WebSocket
if (self.webSocket) {
[self.webSocket send:@"您好 !"];
}
}
實(shí)現(xiàn)效果:

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
iOS實(shí)現(xiàn)動態(tài)自適應(yīng)標(biāo)簽
這篇文章主要為大家詳細(xì)介紹了iOS動態(tài)自適應(yīng)標(biāo)簽的相關(guān)資料,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-03-03
Flutter之TabBarView組件項目實(shí)戰(zhàn)示例
這篇文章主要為大家介紹了Flutter之TabBarView組件項目實(shí)戰(zhàn)示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-10-10
iOS實(shí)現(xiàn)兩個控制器之間數(shù)據(jù)的雙向傳遞
這篇文章主要為大家詳細(xì)介紹了iOS實(shí)現(xiàn)兩個控制器之間數(shù)據(jù)的雙向傳遞的相關(guān)資料,感興趣的小伙伴們可以參考一下2016-05-05
iOS面試中如何優(yōu)雅回答B(yǎng)lock導(dǎo)致循環(huán)引用的問題
這篇文章主要給大家介紹了iOS面試中關(guān)于如何優(yōu)雅回答B(yǎng)lock導(dǎo)致循環(huán)引用的問題的相關(guān)資料,文中通過圖文介紹的非常相信,相信對大家具有一定的參考價值,需要的朋友們下面來一起看看吧。2017-03-03
iOS利用AFNetworking3.0——實(shí)現(xiàn)文件斷點(diǎn)下載
這篇文章主要介紹了iOS利用AFNetworking3.0——實(shí)現(xiàn)文件斷點(diǎn)下載,具有一定的參考價值,有興趣的可以了解一下。2017-01-01
iOS9蘋果將原h(huán)ttp協(xié)議改成了https協(xié)議的方法
這篇文章主要介紹了iOS9蘋果將原h(huán)ttp協(xié)議改成了https協(xié)議的方法的相關(guān)資料,需要的朋友可以參考下2016-01-01
iOS 點(diǎn)擊圖片放大效果的實(shí)現(xiàn)
本篇文章主要介紹了iOS 點(diǎn)擊圖片放大效果的實(shí)現(xiàn),這種效果一般在微博,微信朋友圈中比較常見,有興趣的可以了解一下。2017-01-01
iOS擼一個簡單路由Router的實(shí)現(xiàn)代碼
這篇文章主要介紹了iOS擼一個簡單路由Router的實(shí)現(xiàn)代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-09-09

