1、即时通讯简介:即时通讯英文名为:Instant Messaging,简称IM,是一个终端服务,允许两人或多人使用网路即时的传递文字讯息、档案、语音与视频交流。
2、即时通讯代表作:QQ、微信、Facebook、MSN等。
3、iOS 如何实现即时通讯?
3.1.使用Socket 自己写一个通讯协议。
3.2.使用XMPPframework、环信、融云、LeanClound等三方 框架。
4、EaseMob简介
环信是基于Jabber/XMPP协议的即时通讯服务器。
环信是北京易掌云峰科技有限公司推出的即时通讯云平台,环信将基于移动互联网的即时通讯能力通过云端开放的 Rest API 和客户端 SDK 包的方式提供给开发者和企业。
环信全面支持iOS、Android、Web等多种平台,在流量、电量、长连接、语音、位置、安全等能力做了极致的优化,让移动开发者摆脱繁重的移动IM通讯底层开发,最大限度地缩短产品开发周期,最短的时间内让App拥有移动IM能力。
简单的说:只要集成了EaseMobSDK,然后做简单的配置,实现简单的代码便能让你的App实现聊天的功能。
环信官网:http://www.easemob.com
5、EaseMobSDK的导入
5.1. 提前准备
下载iOS的环信SDK、注册环信即时通讯云账号、登陆到管理后台、在我的应用中创建一个应用、如果需要推送功能的在苹果的个人开发中心创建一个推送证书并导出(如果不需要就省略)
5.2、SDK导入
5.2.1、将下载完的环信SDK中的EaseMobSDK拖入到项目中
EaseMobSDK中的lib文件夹中包含以下两个.a文件libEaseMobClientSDK:包含所有功能
libEaseMobClientSDKLite:不包含实时语音
所以只需要保留一个
同时需要在include文件夹中也需要删除一个文件夹
6、导入框架
·MobileCoreServices.framework
·CFNetwork.framework
·libEaseMobClientSDKLite.a
·libsqlite3.dylib
·libstdc++.6.0.9.dylib
·libz.dylib
·libiconv.dylib
·libresolv.dylib
·libxml2.dylib
·需要对象做配置Build Settings->Linking->Other Linker Flags 中 添加-ObjC 或者 force_load 静态库路径
7、应用程序生命周期方法中实现环信中对应的方法
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
{
[[EaseMob sharedInstance] application:application didFinishLaunchingWithOptions:launchOptions];
return YES;
}
// App进入后台
- (void)applicationDidEnterBackground:(UIApplication *)application{
[[EaseMob sharedInstance] applicationDidEnterBackground:application];
}
// App将要从后台返回
- (void)applicationWillEnterForeground:(UIApplication *)application{
[[EaseMob sharedInstance] applicationWillEnterForeground:application];
}
// 申请处理时间
- (void)applicationWillTerminate:(UIApplication *)application{
[[EaseMob sharedInstance] applicationWillTerminate:application];
}
8、EaseMob 注册
注意:注册账号不能为中文、在环信后台管理创建应用时需要选择开放注册。
8.1、聊天管理器
·获取方式:[EaseMob sharedInstance].chatManager
·获取聊天管理器对象后,可以做登陆、聊天等操作。
·聊天管理器其实就是遵守了一堆功能操作的协议。
8.2、注册账号的方式
/*
@method
@brief 在聊天服务器上创建账号
@discussion
@param username 用户名
@param password 密码
@param pError 错误信息
@result 是否注册成功
*/
- (BOOL)registerNewAccount:(NSString *)username
password:(NSString *)password
error:(EMError **)pError;
/*
@method
@brief 异步方法, 在聊天服务器上创建账号
@discussion 在注册过程中, EMChatManagerLoginDelegate中的didRegisterNewAccount:password:error:回调会被触发
@param username 用户名
@param password 密码
@result
*/
- (void)asyncRegisterNewAccount:(NSString *)username
password:(NSString *)password;
/*
@method
@brief 异步方法, 在聊天服务器上创建账号
@discussion
@param username 用户名
@param password 密码
@param completion 回调
@param aQueue 回调时的线程 @result
*/
- (void)asyncRegisterNewAccount:(NSString *)username
password:(NSString *)password
withCompletion:(void (^)(NSString *username,
NSString *password, EMError *error))completion
onQueue:(dispatch_queue_t)aQueue;
9、EaseMob登陆
登录方式:使用异步block方式登陆
/*
@method
@brief 使用用户名密码登录聊天服务器
@discussion 如果登陆失败, 返回nil
@param username 用户名
@param password 密码
@param pError 错误信息
@result 登录后返回的用户信息
*/
(NSDictionary *)loginWithUsername:(NSString *)username
password:(NSString *)password
error:(EMError **)pError;
/*
@method
@brief 异步方法, 使用用户名密码登录聊天服务器
@discussion 在登陆过程中, EMChatManagerLoginDelegate中的didLoginWithInfo:error:回调会被触发
@param username 用户名
@param password 密码
@result
*/
(void)asyncLoginWithUsername:(NSString *)username
password:(NSString *)password;
/*
@method
@brief 异步方法, 使用用户名密码登录聊天服务器@discussion
@param username 用户名
@param password 密码
@param completion 回调
@param aQueue 回调时的线程
@result
*/
(void)asyncLoginWithUsername:(NSString *)username
password:(NSString *)password
completion:(void (^)(NSDictionary *loginInfo, EMError *error))completion
onQueue:(dispatch_queue_t)aQueue;
注:如果不想看到乱七八糟的数据可以用以下代码关闭
[[EaseMob sharedInstance] registerSDKWithAppKey:kEaseMobAppKey
apnsCertName:kEaseMobPushName otherConfig:
@{kSDKConfigEnableConsoleLogger:@(NO)}];
10、自动登录
实现原理:在登陆成功之后将登陆信息存储到沙盒中,下次程序启动从沙盒中拿到用户名和密码直接调用登陆的接口。
注:以上操作环信SDK已经做好了,我们只需要设置自动登陆的属性即可(setIsAutoLoginEnabled)
// 自动登陆完成的回调方法
- (void)didAutoLoginWithInfo:(NSDictionary *)loginInfo error:(EMError *)error
{
NSLog(@"loginInfo = %@",loginInfo);
[MBProgressHUD hideAllHUDsForView:self.window animated:YES];
if (error) {
[[TKAlertCenter defaultCenter]postAlertWithMessage:@"登陆失败"];
}else{
[[TKAlertCenter defaultCenter]postAlertWithMessage:@"登陆成功"];
[self loginSuccess];
}
}
未完待续、、、