iOS Socket第三方开源类库 ----AsyncSocket

假如你也是一个java程序员,而你又不是很懂Socket。

下面我的这篇文章也许能帮助你一些。

http://xiva.iteye.com/blog/993336

首先我们写好上面文章中的server端。

下面我们可以访问一下下面的地址:

http://code.google.com/p/cocoaasyncsocket/

这是一个开源框架。呵,不知道拿到自己程序中使用是否涉及侵权。

但是这句话“The CocoaAsyncSocket project is in the public domain.”是我有信心使用它们的源码,否则只能自己用c来写了,或者使用CFSocket、CFNetwork等类自己来写了。不过也无妨,应在在使用线程的情况下,我们也是可以实现的。

总之,为了开发的便捷,我使用了AsyncSocket这个类,这样可以异步通信。

建立一个基于视图的应用程序,按照http://code.google.com/p/cocoaasyncsocket/wiki/Reference_AsyncSocket

我们AsyncSocket.h和AsyncSocket.m到我们的项目中,并且导入CFNetwork.framework。这样基本准备工作就做好了。

下面提供我的应用中的代码以及界面图:

Socketdemoviewcontroller.h代码  

  1. //
  2. //  SocketDemoViewController.h
  3. //  SocketDemo
  4. //
  5. //  Created by xiang xiva on 10-7-10.
  6. //  Copyright 2010 __MyCompanyName__. All rights reserved.
  7. //
  8. #import <UIKit/UIKit.h>
  9. #import "AsyncSocket.h"
  10. #define SRV_CONNECTED 0
  11. #define SRV_CONNECT_SUC 1
  12. #define SRV_CONNECT_FAIL 2
  13. #define HOST_IP @"192.168.110.1"
  14. #define HOST_PORT 8080
  15. @interface SocketDemoViewController : UIViewController {
  16. UITextField *inputMsg;
  17. UILabel *outputMsg;
  18. AsyncSocket *client;
  19. }
  20. @property (nonatomic, retain) AsyncSocket *client;
  21. @property (nonatomic, retain) IBOutlet UITextField *inputMsg;
  22. @property (nonatomic, retain) IBOutlet UILabel *outputMsg;
  23. - (int) connectServer: (NSString *) hostIP port:(int) hostPort;
  24. - (void) showMessage:(NSString *) msg;
  25. - (IBAction) sendMsg;
  26. - (IBAction) reConnect;
  27. - (IBAction) textFieldDoneEditing:(id)sender;
  28. - (IBAction) backgroundTouch:(id)sender;
  29. @end

socketdemoviewcontroller.m代码  

  1. //
  2. //  SocketDemoViewController.m
  3. //  SocketDemo
  4. //
  5. //  Created by xiang xiva on 10-7-10.
  6. //  Copyright 2010 __MyCompanyName__. All rights reserved.
  7. //
  8. #import "SocketDemoViewController.h"
  9. @implementation SocketDemoViewController
  10. @synthesize inputMsg, outputMsg;
  11. @synthesize client;
  12. /*
  13. // The designated initializer. Override to perform setup that is required before the view is loaded.
  14. - (id)initWithNibName:(NSString *)nibNameOrNil bundle:(NSBundle *)nibBundleOrNil {
  15. self = [super initWithNibName:nibNameOrNil bundle:nibBundleOrNil];
  16. if (self) {
  17. // Custom initialization
  18. }
  19. return self;
  20. }
  21. */
  22. /*
  23. // Implement loadView to create a view hierarchy programmatically, without using a nib.
  24. - (void)loadView {
  25. }
  26. */
  27. // Implement viewDidLoad to do additional setup after loading the view, typically from a nib.
  28. - (void)viewDidLoad {
  29. //[super viewDidLoad];
  30. [self connectServer:HOST_IP port:HOST_PORT];
  31. //监听读取
  32. }
  33. // Override to allow orientations other than the default portrait orientation.
  34. - (BOOL)shouldAutorotateToInterfaceOrientation:(UIInterfaceOrientation)interfaceOrientation {
  35. return YES;
  36. }
  37. - (void)didReceiveMemoryWarning {
  38. // Releases the view if it doesn‘t have a superview.
  39. [super didReceiveMemoryWarning];
  40. // Release any cached data, images, etc that aren‘t in use.
  41. }
  42. - (void)viewDidUnload {
  43. self.client = nil;
  44. // Release any retained subviews of the main view.
  45. // e.g. self.myOutlet = nil;
  46. }
  47. - (int) connectServer: (NSString *) hostIP port:(int) hostPort{
  48. if (client == nil) {
  49. client = [[AsyncSocket alloc] initWithDelegate:self];
  50. NSError *err = nil;
  51. //192.168.110.128
  52. if (![client connectToHost:hostIP onPort:hostPort error:&err]) {
  53. NSLog(@"%@ %@", [err code], [err localizedDescription]);
  54. UIAlertView *alert = [[UIAlertView alloc] initWithTitle:[@"Connection failed to host "
  55. stringByAppendingString:hostIP]
  56. message:[[[NSString alloc]initWithFormat:@"%@",[err code]] stringByAppendingString:[err localizedDescription]]
  57. delegate:self
  58. cancelButtonTitle:@"OK"
  59. otherButtonTitles:nil];
  60. [alert show];
  61. [alert release];
  62. //client = nil;
  63. return SRV_CONNECT_FAIL;
  64. } else {
  65. NSLog(@"Conectou!");
  66. return SRV_CONNECT_SUC;
  67. }
  68. }
  69. else {
  70. [client readDataWithTimeout:-1 tag:0];
  71. return SRV_CONNECTED;
  72. }
  73. }
  74. - (IBAction) reConnect{
  75. int stat = [self connectServer:HOST_IP port:HOST_PORT];
  76. switch (stat) {
  77. case SRV_CONNECT_SUC:
  78. [self showMessage:@"connect success"];
  79. break;
  80. case SRV_CONNECTED:
  81. [self showMessage:@"It‘s connected,don‘t agian"];
  82. break;
  83. default:
  84. break;
  85. }
  86. }
  87. - (IBAction) sendMsg{
  88. NSString *inputMsgStr = self.inputMsg.text;
  89. NSString * content = [inputMsgStr stringByAppendingString:@"\r\n"];
  90. NSLog(@"%a",content);
  91. NSData *data = [content dataUsingEncoding:NSISOLatin1StringEncoding];
  92. [client writeData:data withTimeout:-1 tag:0];
  93. //[data release];
  94. //[content release];
  95. //[inputMsgStr release];
  96. //继续监听读取
  97. //[client readDataWithTimeout:-1 tag:0];
  98. }
  99. #pragma mark -
  100. #pragma mark close Keyboard
  101. - (IBAction) textFieldDoneEditing:(id)sender{
  102. [sender resignFirstResponder];
  103. }
  104. - (IBAction) backgroundTouch:(id)sender{
  105. [inputMsg resignFirstResponder];
  106. }
  107. #pragma mark socket uitl
  108. - (void) showMessage:(NSString *) msg{
  109. UIAlertView * alert = [[UIAlertView alloc]initWithTitle:@"Alert!"
  110. message:msg
  111. delegate:nil
  112. cancelButtonTitle:@"OK"
  113. otherButtonTitles:nil];
  114. [alert show];
  115. [alert release];
  116. }
  117. #pragma mark socket delegate
  118. - (void)onSocket:(AsyncSocket *)sock didConnectToHost:(NSString *)host port:(UInt16)port{
  119. [client readDataWithTimeout:-1 tag:0];
  120. }
  121. - (void)onSocket:(AsyncSocket *)sock willDisconnectWithError:(NSError *)err
  122. {
  123. NSLog(@"Error");
  124. }
  125. - (void)onSocketDidDisconnect:(AsyncSocket *)sock
  126. {
  127. NSString *msg = @"Sorry this connect is failure";
  128. [self showMessage:msg];
  129. [msg release];
  130. client = nil;
  131. }
  132. - (void)onSocketDidSecure:(AsyncSocket *)sock{
  133. }
  134. - (void)onSocket:(AsyncSocket *)sock didReadData:(NSData *)data withTag:(long)tag{
  135. NSString* aStr = [[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding];
  136. NSLog(@"Hava received datas is :%@",aStr);
  137. self.outputMsg.text = aStr;
  138. [aStr release];
  139. [client readDataWithTimeout:-1 tag:0];
  140. }
  141. #pragma mark dealloc
  142. - (void)dealloc {
  143. [client release];
  144. [inputMsg release];
  145. [outputMsg release];
  146. [super dealloc];
  147. }
  148. @end

还是先给出我的界面吧,否则很难懂这些代码

这样大家满意了吧!

好了说了这么多我们还是来看看代码究竟怎么回事吧。

首先从头文件开始看吧,

1,导入头文件#import "AsyncSocket.h",然后是一些宏

2,声明一个AsyncSocket对象,其他就是一些IBoutlet

再次我们看看视图加载,

Java代码  

  1. - (void)viewDidLoad {
  2. //[super viewDidLoad];
  3. [self connectServer:HOST_IP port:HOST_PORT];
  4. //监听读取
  5. }

显然我们调用了connectServer::这个方法。

在这个方法中,首先初始化我们的对象,使用代理的方式。对象显示是self。然后我们便需在我们的类中实现它的各种方法,来得到各种我们想得到的。

client = [[AsyncSocket alloc] initWithDelegate:self];

下面就是连接服务器了,

[client connectToHost:hostIP onPort:hostPort error:&err]

并且当client不为空时,我们就读取服务器的信息

[client readDataWithTimeout:-1 tag:0];

Java代码  

  1. - (void)onSocket:(AsyncSocket *)sock didReadData:(NSData *)data withTag:(long)tag{
  2. NSString* aStr = [[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding];
  3. NSLog(@"Hava received datas is :%@",aStr);
  4. self.outputMsg.text = aStr;
  5. [aStr release];
  6. [client readDataWithTimeout:-1 tag:0];
  7. }

在这个方法中很耐人寻味,主要就是在于递归的调用。

Sendmsg代码  

  1. - (IBAction) sendMsg{
  2. NSString *inputMsgStr = self.inputMsg.text;
  3. NSString * content = [inputMsgStr stringByAppendingString:@"\r\n"];
  4. NSLog(@"%a",content);
  5. NSData *data = [content dataUsingEncoding:NSISOLatin1StringEncoding];
  6. [client writeData:data withTimeout:-1 tag:0];
  7. }

我们在看看上面发送消息的代码,中的在于"\r\n"的拼接,否则在java端的程序,无法知道你发过来的信息是否结束,当然你也可以使用其他的方式来读取客户端,比如定时;但是我在java端写的server是readLine来判断的,所以需要拼接这个\r\n.

其他的代码除了asyncSocket代理外都是我们所熟悉的。

这些都是asyncsocket代理的代码  

  1. - (void)onSocket:(AsyncSocket *)sock didConnectToHost:(NSString *)host port:(UInt16)port{
  2. [client readDataWithTimeout:-1 tag:0];
  3. }
  4. - (void)onSocket:(AsyncSocket *)sock willDisconnectWithError:(NSError *)err
  5. {
  6. NSLog(@"Error");
  7. }
  8. - (void)onSocketDidDisconnect:(AsyncSocket *)sock
  9. {
  10. NSString *msg = @"Sorry this connect is failure";
  11. [self showMessage:msg];
  12. [msg release];
  13. client = nil;
  14. }
  15. - (void)onSocketDidSecure:(AsyncSocket *)sock{
  16. }
  17. - (void)onSocket:(AsyncSocket *)sock didReadData:(NSData *)data withTag:(long)tag{
  18. NSString* aStr = [[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding];
  19. NSLog(@"Hava received datas is :%@",aStr);
  20. self.outputMsg.text = aStr;
  21. [aStr release];
  22. [client readDataWithTimeout:-1 tag:0];
  23. }

到此就结束了。

时间: 2024-11-05 15:51:28

iOS Socket第三方开源类库 ----AsyncSocket的相关文章

iOS常用第三方开源类库

1.AFNetworking AFNetworking 采用 NSURLConnection + NSOperation, 主要方便与服务端 API 进行数据交换, 操作简单, 功能强大, 现在许多人都用它取代 ASIHTTPRequest 2.Apple Reachability 网络监测,可以参考下这篇文章iOS网络监测如何区分2.3.4G? 3.DOUAudioStreamer 豆瓣的开源软件,DOUAudioStreamer 是 iOS 和 Mac 的基于核心音频的流媒体音频播放器 4.

使用CocoaPods管理第三方开源类库

iOS开发中经常会用到许多第三方类库,比如AFNetworking.FMDB.JSONKit等等,使用CocoaPods这个工具就能很方便得对工程中用到的类库进行管理,包括自动下载配置以及更新. 首先需要下载安装CocoaPods,系统要求有ruby环境,至少OS X 10.9以后是自带ruby环境的(Python也自带了),使用"ruby -v"命令可以查看当前ruby版本. 配置过程如下: 1.ruby环境 不放心的话可以先确认下ruby环境,据说由于GFW的影响,大都把Ruby镜

IOS开发第三方开源库

IOSios开发第三方开源库 1. AFNetworking 在众多iOS开源项目中,AFNetworking可以称得上是最受开发者欢迎的库项目.AFNetworking是一个轻量级的iOS.Mac OS X网络通信类库,现在是GitHub上第三大Objective-C库.它建立在NSURLConnection.NSOperation等类库的基础上,让很多网络通信功能的实现变得十分简单,因此,许多iOS应用开发都会使用到它. 支持HTTP请求和基于REST的网络服务(包括GET.POST.PUT

IM开发之Socket通信开源类库CocoaAsyncSocket

CocoaAsyncSocket:https://github.com/robbiehanson/CocoaAsyncSocket CocoaAsyncSocket是用的最广泛的socket开发库,在iOS开发中使用socket,一般都是用第三方库CocoaAsyncSocket 打开连接看了下作者的开源类库,满满的崇拜感!!! 相关教程:https://github.com/robbiehanson/CocoaAsyncSocket/wiki/Intro_GCDAsyncSocket http

iOS开发经常使用的第三方开源类库、组件

1.AFNetworking AFNetworking 采用 NSURLConnection + NSOperation, 主要方便与服务端 API 进行数据交换, 操作简单, 功能强大, 现在许多人都用它取代 ASIHTTPRequest 2.Apple Reachability 网络监测,可以参考下这篇文章iOS网络监测如何区分2.3.4G? 3.DOUAudioStreamer 豆瓣的开源软件,DOUAudioStreamer 是 iOS 和 Mac 的基于核心音频的流媒体音频播放器 4.

网易新闻iOS版在开发过程中曾经使用过的第三方开源类库、组件

1.AFNetworkingAFNetworking 采用 NSURLConnection + NSOperation, 主要方便与服务端 API 进行数据交换, 操作简单, 功能强大, 现在许多人都用它取代 ASIHTTPRequest 2.Apple Reachability网络监测,可以参考下这篇文章iOS网络监测如何区分2.3.4G? 3.DOUAudioStreamer豆瓣的开源软件,DOUAudioStreamer 是 iOS 和 Mac 的基于核心音频的流媒体音频播放器 4.FXB

iOS GitHub 第三方开源库

1.TouchXML XML解析 https://github.com/TouchCode/TouchXML 2.一款开源的cocos2d游戏 https://github.com/haqu/tweejump 3.Reachability https://github.com/tonymillion/Reachability 4.AFNetworking https://github.com/AFNetworking/AFNetworking 5.ASIHTTPRequest https://g

AndroidStuido如何加入第三方的开源类库。

AndroidStudio越来越多的人使用了,下面介绍AndroidStudio像Eclipse上一样加入第三方开源类库的方法: 1.如果开源类库是放在GITHUB 上面托管的话,那么可以直接远程加入开源类库,不过个人不建议这样做,因为这样的话,改类库的源码不方便,进入你的项目编辑BUILD.GRADLE目录,在dependencies中加入引入库说明,如何: 加入引入库后的图: 你需要引入哪个库就去找那个库的GITHUB的托管地址的Including into your project 目录下

最全面的iOS和Mac开源项目和第三方库汇总

UI 下拉刷新 EGOTableViewPullRefresh – 最早的下拉刷新控件. SVPullToRefresh – 下拉刷新控件. MJRefresh – 仅需一行代码就可以为UITableView或者CollectionView加上下拉刷新或者上拉刷新功能.可以自定义上下拉刷新的文字说明.具体使用看“使用方法”. (国人写) XHRefreshControl – XHRefreshControl 是一款高扩展性.低耦合度的下拉刷新.上提加载更多的组件.(国人写) CBStoreHou