#import "ViewController.h"

#import "AsyncSocket.h"

@interface ViewController ()<AsyncSocketDelegate,UITextFieldDelegate>

{

    //负责显示接受到的数据

    UITextView *_textView;

    

    //负责输入数据

    UITextField *_textField;

    

    //建立发送端

    AsyncSocket * sendSocket;

    

    //建立服务端

    AsyncSocket *serverSocket;

}



//建立一个数组保存连接

@property (nonatomic,strong) NSMutableArray *socketArray;



@end



@implementation ViewController



- (void)viewDidLoad {

    [super viewDidLoad];

    /**

     *  建立一个群聊,学生向老师端发送消息,老师端则显示全部信息

     */

    self.socketArray = [NSMutableArray arrayWithCapacity:0];

    [self createSocket];

    

    //创建界面

    [self createView];

    

    //创建一个定时器,没隔10秒清除一次数据

    [NSTimer scheduledTimerWithTimeInterval:10 target:self selector:@selector(clearTextView) userInfo:nil repeats:YES];

}



- (void)clearTextView{

    _textView.text = nil;

}



- (void)createView{

    _textView = [[UITextView alloc]initWithFrame:CGRectMake(0, 0, self.view.frame.size.width, 240)];

    _textView.backgroundColor = [UIColor blackColor];

    _textView.textColor = [UIColor whiteColor];

    [self.view addSubview:_textView];

    

    _textField = [[UITextField alloc]initWithFrame:CGRectMake(0, 240, self.view.frame.size.width, 44)];

    _textField.delegate = self;

    _textField.backgroundColor = [UIColor redColor];

    [self.view addSubview:_textField];

    

    

    

}





- (void)createSocket{

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

    

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

    

    //服务端绑定port,监听该port接受的数据

    /**

     *  port最大为65535。当中建议设置为5000以上,另外另一些特殊的port,比如8080为视频port。建议不要占用

     */

    [serverSocket acceptOnPort:5678 error:nil];

}



- (void)onSocket:(AsyncSocket *)sock didAcceptNewSocket:(AsyncSocket *)newSocket{

    //接受的一个新连接,这个新连接须要保存一下。然后持续保持连接

    [self.socketArray addObject:newSocket];

    

    //当中-1表示持续观察,假设设置为300,那么300秒以后就不再观察

    [newSocket readDataWithTimeout:-1 tag:100];

}



-(void)onSocket:(AsyncSocket *)sock didReadData:(NSData *)data withTag:(long)tag{

    

    //接受到的数据

    

    NSString *message = [[NSString alloc]initWithData:data encoding:NSUTF8StringEncoding];

    if (_textView) {

        //在原来的旧数据上面。追加新的 数据

        _textView.text = [NSString stringWithFormat:@"%@%@",_textView.text,message];

    }

    [sock readDataWithTimeout:-1 tag:100];

    

    

}





- (void)onSocket:(AsyncSocket *)sock didWriteDataWithTag:(long)tag{

    //发送成功

    

}



//发送数据

-(BOOL)textFieldShouldReturn:(UITextField *)textField{

    if (textField.text.length > 0 ) {

        //发送数据

        if (![sendSocket isConnected]) {

            //确定是否连接。假设没有连接,则開始连接

            

            [sendSocket connectToHost:@"10.8.155.176" onPort:5678 error:nil];

        }

        //当连接完毕以后。发送数据

        //拼接数据是谁说,我希望获得当前设备的名称

//        [[UIDevice currentDevice]systemName];该方法仅仅有在真机上才有效。在模拟器上无效

        NSString *message = [NSString stringWithFormat:@"%@说:%@",@"房骞",textField.text];

        

        [sendSocket writeData:[message dataUsingEncoding:NSUTF8StringEncoding] withTimeout:-1 tag:100];

    }

    return YES;

}

@end

使用asyncsocket群聊的更多相关文章

  1. SignalR快速入门 ~ 仿QQ即时聊天,消息推送,单聊,群聊,多群公聊(基础=》提升)

     SignalR快速入门 ~ 仿QQ即时聊天,消息推送,单聊,群聊,多群公聊(基础=>提升,5个Demo贯彻全篇,感兴趣的玩才是真的学) 官方demo:http://www.asp.net/si ...

  2. smack 4.1创建群聊

    smack 4.1.1版本对群聊修改了很多,MultUserChat的构造函数修改成了私有,以前通过new MultUserChat创建聊天室,现在通过MultUserChatMananger先通过r ...

  3. Socket通信 简单实现私聊、群聊(dos命令下)

    很久以前的一个Demo,这里服务器只做转发功能,根据ID地址和端口号来标识身份,群聊和私聊只是简单实现, 服务器代码如下: import java.util.*; import java.io.*; ...

  4. Strophe.js连接XMPP服务器Openfire、Tigase实现Web私聊、群聊(MUC)

    XMPP(Extensible Messaging and Presence Protocol)是一种网络即时通讯协议,它基于XML,具有很强的扩展性,被广泛使用在即时通讯软件.网络游戏聊天.Web聊 ...

  5. 一例完整的websocket实现群聊demo

    前言 业余我都会花一些时间在tcp.http和websocket等领域的学习,现在觉得有点收获,所以把一个基于websocket的群聊功能的例子提供给大家玩玩.当然这是一个很完整的例子,包括webso ...

  6. ASP.NET SignalR 与 LayIM2.0 配合轻松实现Web聊天室(三) 之 实现单聊,群聊,发送图片,文件。

    上篇讲解了如何搭建聊天服务器,以及客户端js怎么和layui的语法配合.服务器已经连接上了,那么聊天还会远吗? 进入正题,正如上一篇提到的我们用 Client.Group(groupId)的方法向客户 ...

  7. 阿里百川IMSDK--自定义群聊界面

    // 获取群对象 YWTribe *tribe = [self.tribesArray objectAtIndex:indexPath.row]; // 发起群聊 UIViewController * ...

  8. Java-->实现群聊功能(C/S模式--TCP协议)

    --> Java 对TCP协议的支持: --> java.net包中定义了两个类ServerSocket 和Socket ,分别用来实现双向连接的server 端和client 端. -- ...

  9. 【从0開始Tornado建站】群聊

    群聊的前台主要代码: {%block content%} <!--<p class='text-success h3'>測试版本号,每天凌晨4:00清水,enjoy it~~:-)& ...

随机推荐

  1. HTML5轻松实现拍照上传功能[转载]

    转载 http://www.18sucai.com/article/275.htm 传统方法如果想实现拍照功能,需要后台应用程序复杂的编写,但随着html5的发展,在HTML5规范的支持下,Web A ...

  2. python 3---if判断成绩练习

    需求根据用户输入的成绩分档,要求如下: 1. 如果成绩大于60分,输出"及格"2. 如果成绩大于70分,输出"良"3. 如果成绩大于80分,输出"好& ...

  3. Python学习笔记整理总结【语言基础篇】

    一.变量赋值及命名规则① 声明一个变量及赋值 #!/usr/bin/env python # -*- coding:utf-8 -*- # _author_soloLi name1="sol ...

  4. js个位数补0

    //获取并格式化当前时间 var _getTime = function(){ var arr=['00','01','02','03','04','05','06','0,'08','09'], / ...

  5. .Net中各种不同的对象创建方式的速度差异

    在.Net中,微软给我们提供了很多不同的创建对象实例的方法,它们的速度又各有不同,以下一一列举. 使用new关键字 这在.Net中是最常见,也是速度最快的方式:                     ...

  6. 激光相机数据融合(4)--KITTI数据集中matlab接口说明及扩展

    KITTI数据集接口已经提供了matlab接口,本篇将说明详细说明其应用并与PCL进行对接.PCL为C++点云处理语言库,详情可见:http://pointclouds.org/ 程序可以从官网下载, ...

  7. Android WebView 上传各种文件(包括拍照 录像 录音 文件 音乐 等,用到图片或拍照的,可以参考下)

    我也是从网上扒下来的,经过多次实验,找到了个好用的.网上能搜到最多的也就是这个解决方案,我英文不好,也没仔细研究,但大多数都是出自这: http://stackoverflow.com/questio ...

  8. input[type='file']样式美化及实现图片预览

    前言 上传图片是常见的需求,多使用input标签.本文主要介绍 input标签的样式美化 和 实现图片预览. 用到的知识点有: 1.input标签的使用 2.filelist对象 和 file对象 3 ...

  9. 关于node的前端项目编译时内存溢出问题

    最近在做一个基于vue 的多页面项目  , 页面n++多,编译时发生node内存溢出问题,继而百度之,得到解答,故记录之. '如图' 只需在 package.json 里面   加上    --max ...

  10. H5新增标签

    <!DOCTYPE html ><html><head><meta http-equiv="Content-Type" content=& ...