之前公司的即時聊天用的是常輪循认然,一直都覺得很不科學(xué)樊展,最近后臺說配置好了socket服務(wù)器购城,我高興地準備用asyncsocket,但是告訴我要用websocket刨疼,基于HTML5的泉唁,HTML5中提出了一種新的雙向通信協(xié)議--WebSocket,本文嘗試采用這種技術(shù)來實現(xiàn)以上的實時聊天功能揩慕。
在搜索了很多資料后亭畜,用square大神的SocketRocket進行實現(xiàn),會比較簡單迎卤,同時URL和端口拴鸵,發(fā)送消息參數(shù)需要和后臺約定好。
首先pod導(dǎo)入SocketRocket
platform :ios, '7.0'
pod 'SocketRocket', '~> 0.5.0'
然后在搭建一個最簡單的頁面蜗搔,只有一個輸入框和button
在控制器中導(dǎo)入頭文件
#import
創(chuàng)建
SRWebSocket*webSocket;
簡單點劲藐,在viewDidLoad中實例化并且設(shè)置代理,鏈接URL和規(guī)定端口號樟凄,
webSocket.delegate=nil;
[webSocketclose];
webSocket= [[SRWebSocketalloc]initWithURLRequest:[NSURLRequestrequestWithURL:[NSURLURLWithString:@"你的服務(wù)器URL和端口號"]]];
webSocket.delegate=self;
NSLog(@"Opening Connection...");
[webSocketopen];
記得要遵守協(xié)議聘芜,實現(xiàn)delegate方法
#pragma mark - SRWebSocketDelegate
- (void)webSocketDidOpen:(SRWebSocket*)webSocket;{
NSLog(@"Websocket Connected");
NSError*error;
NSData*jsonData = [NSJSONSerializationdataWithJSONObject:@{@"id":@"chat",@"clientid":@"hxz",@"to":@""}options:NSJSONWritingPrettyPrintederror:&error];
NSString*jsonString = [[NSStringalloc]initWithData:jsonDataencoding:NSUTF8StringEncoding];
[webSocketsend:jsonString];
}
- (void)webSocket:(SRWebSocket*)webSocket didFailWithError:(NSError*)error;{
NSLog(@":( Websocket Failed With Error %@", error);
webSocket =nil;
}
- (void)webSocket:(SRWebSocket*)webSocket didReceiveMessage:(id)message;{
NSLog(@"Received \"%@\"", message);
}
- (void)webSocket:(SRWebSocket*)webSocket didCloseWithCode:(NSInteger)code reason:(NSString*)reason wasClean:(BOOL)wasClean;{
NSLog(@"WebSocket closed");
webSocket =nil;
}
- (IBAction)sendMessage:(id)sender {
NSError*error;
NSData*jsonData = [NSJSONSerializationdataWithJSONObject:@{@"id":@"chat",@"clientid":@"hxz",@"to":@"mary",@"msg":@{@"type":@"0",@"content":self.textfield.text}}options:NSJSONWritingPrettyPrintederror:&error];
NSString*jsonString = [[NSStringalloc]initWithData:jsonDataencoding:NSUTF8StringEncoding];
[webSocketsend:jsonString];
}
其中webSocketDidOpen是在鏈接服務(wù)器成功后回調(diào)的方法,在這里發(fā)送一次消息缝龄,把id 名字發(fā)送到服務(wù)器汰现,告知服務(wù)器挂谍,
在send方法中有兩個選擇:
// Send a UTF8 String or Data.
- (void)send:(id)data;
// Send Data (can be nil) in a ping message.
- (void)sendPing:(NSData*)data;
第一個是需要發(fā)送JSON字符串格式的Data,必須把對象轉(zhuǎn)換成JSON字符串格式瞎饲,否則報錯口叙,第二種是發(fā)送NSData類型,而且根據(jù)注釋可以為nil
在文本框輸入消息嗅战,發(fā)送后在對方消息列表顯示成功:
對方發(fā)送消息給我這端時庐扫,didReceiveMessage方法接受到消息后會執(zhí)行,輸出消息內(nèi)容:
完成~