====== 好友管理 ====== 更新时间:2021-12-31 新版文档见:[[ccim:ios:relationship|用户关系管理]]。 ---- 注:环信不是好友也可以聊天,不推荐使用环信的好友机制。如果你有自己的服务器或好友关系,请自己维护好友关系。 好友管理涉及到的环信SDK头文件如下: // 好友方法调用部分,比如添加代理,移除代理,添加,删除好友等 IEMContactManager.h // 好友的协议回调方法部分,比如监听接收好友请求的回调方法等 EMContactManagerDelegate.h ===== 获取好友列表 ===== 获取好友列表,环信提供了两种方法。 ==== 从服务器获取所有的好友 ==== [[EMClient sharedClient].contactManager getContactsFromServerWithCompletion:^(NSArray *aList, EMError *aError) { if (!aError) { NSLog(@"获取所有好友成功 -- %@",aList); } else { NSLog(@"获取所有好友失败的原因 --- %@", aError.errorDescription); } }]; === 从数据库获取所有的好友 === // 从服务器获取所有好友之后,才能从本地获取到好友 NSArray *userlist = [[EMClient sharedClient].contactManager getContacts]; ===== 好友申请 ===== ==== 发送加好友申请 ==== 环信 iOS SDK 提供了添加好友的方法。 /*! * 添加好友 * * @param aUsername 要添加的用户 * @param aMessage 邀请信息 * @param aCompletionBlock 完成的回调 */ - (void)addContact:(NSString *)aUsername message:(NSString *)aMessage completion:(void (^)(NSString *aUsername, EMError *aError))aCompletionBlock; // 调用 [[EMClient sharedClient].contactManager addContact:@"6001" message:@"我想添加您为好友" completion:^(NSString *aUsername, EMError *aError) { if (!aError) { NSLog(@"添加好友成功 -- %@",aUsername); } else { NSLog(@"添加好友失败的原因 --- %@", aError.errorDescription); } }]; ==== 监听加好友请求 ==== 当您收到好友请求,如果您没有处理,请自己保存数据,新协议下不会每次都发送。 协议:EMContactManagerDelegate 代理: //注册好友回调 [[EMClient sharedClient].contactManager addDelegate:self delegateQueue:nil]; //移除好友回调 [[EMClient sharedClient].contactManager removeDelegate:self]; 监听回调 /*! * 用户A发送加用户B为好友的申请,用户B会收到这个回调 * * @param aUsername 用户名 * @param aMessage 附属信息 */ - (void)friendRequestDidReceiveFromUser:(NSString *)aUsername message:(NSString *)aMessage; ==== 同意加好友申请 ==== /*! * 同意加好友的申请 * * @param aUsername 申请者 * @param aCompletionBlock 完成的回调 */ - (void)approveFriendRequestFromUser:(NSString *)aUsername completion:(void (^)(NSString *aUsername, EMError *aError))aCompletionBlock; // 调用: [[EMClient sharedClient].contactManager approveFriendRequestFromUser:@"6001" completion:^(NSString *aUsername, EMError *aError) { if (!aError) { NSLog(@"同意加好友申请成功"); } else { NSLog(@"同意加好友申请失败的原因 --- %@", aError.errorDescription); } }]; ==== 拒绝加好友申请 ==== /*! * 拒绝加好友的申请 * * @param aUsername 申请者 * @param aCompletionBlock 完成的回调 */ - (void)declineFriendRequestFromUser:(NSString *)aUsername completion:(void (^)(NSString *aUsername, EMError *aError))aCompletionBlock; // 调用: [[EMClient sharedClient].contactManager declineFriendRequestFromUser:@"6001" completion:^(NSString *aUsername, EMError *aError) { if (!aError) { NSLog(@"拒绝加好友申请成功"); } else { NSLog(@"拒绝加好友申请失败的原因 --- %@", aError.errorDescription); } }]; ==== 好友申请处理结果回调 ==== 监听回调 /*! @method @brief 用户A发送加用户B为好友的申请,用户B同意后,用户A会收到这个回调 */ - (void)friendRequestDidApproveByUser:(NSString *)aUsername; /*! @method @brief 用户A发送加用户B为好友的申请,用户B拒绝后,用户A会收到这个回调 */ - (void)friendRequestDidDeclineByUser:(NSString *)aUsername; ===== 删除好友 ===== /*! * 删除好友 * * @param aUsername 要删除的好友 * @param aIsDeleteConversation 是否删除会话 * @param aCompletionBlock 完成的回调 */ - (void)deleteContact:(NSString *)aUsername isDeleteConversation:(BOOL)aIsDeleteConversation completion:(void (^)(NSString *aUsername, EMError *aError))aCompletionBlock; // 调用: [[EMClient sharedClient].contactManager deleteContact:@"6001" isDeleteConversation:YES completion:^(NSString *aUsername, EMError *aError) { if (!aError) { NSLog(@"删除好友成功"); } else { NSLog(@"删除好友失败的原因 --- %@", aError.errorDescription); } }]; ==== 删除好友回调 ==== 监听回调 /*! @method @brief 用户B删除与用户A的好友关系后,用户A,B会收到这个回调 */ - (void)friendshipDidRemoveByUser:(NSString *)aUsername; ===== 黑名单 ===== ==== 获取好友黑名单 ==== 环信的黑名单体系是独立的,与好友无任何关系。也就是说,您可以将任何人加入黑名单,不论他是否与您是好友关系。同时,如果您将好友加入黑名单,则他仍然是您的好友,只不过同时也在黑名单中。 查询黑名单列表,环信提供了两种方法。 === 异步方法 === /*! * 从服务器获取黑名单列表 * * @param aCompletionBlock 完成的回调 */ - (void)getBlackListFromServerWithCompletion:(void (^)(NSArray *aList, EMError *aError))aCompletionBlock; // 调用: [[EMClient sharedClient].contactManager getBlackListFromServerWithCompletion:^(NSArray *aList, EMError *aError) { if (!aError) { NSLog(@"获取黑名单列表成功 -- %@",aList); } else { NSLog(@"获取黑名单列表失败的原因 --- %@", aError.errorDescription); } }]; === 从数据库获取黑名单列表 === // 从服务器获取黑名单列表之后,才能从本地获取到黑名单列表 NSArray *blockList = [[EMClient sharedClient].contactManager getBlackList]; ==== 加入黑名单 ==== /*! * 将用户加入黑名单 * * @param aUsername 要加入黑名单的用户 * @param aCompletionBlock 完成的回调 */ - (void)addUserToBlackList:(NSString *)aUsername completion:(void (^)(NSString *aUsername, EMError *aError))aCompletionBlock; // 调用: [[EMClient sharedClient].contactManager addUserToBlackList:@"6001" completion:^(NSString *aUsername, EMError *aError) { if (!aError) { NSLog(@"将用户加入黑名单成功"); } else { NSLog(@"将用户加入黑名单失败的原因 --- %@", aError.errorDescription); } }]; ==== 移出黑名单 ==== 接口调用 /*! * 将用户移出黑名单 * * @param aUsername 要移出黑命单的用户 * @param aCompletionBlock 完成的回调 */ - (void)removeUserFromBlackList:(NSString *)aUsername completion:(void (^)(NSString *aUsername, EMError *aError))aCompletionBlock; // 调用: [[EMClient sharedClient].contactManager removeUserFromBlackList:@"6001" completion:^(NSString *aUsername, EMError *aError) { if (!aError) { NSLog(@"将用户移出黑名单成功"); } else { NSLog(@"将用户移出黑名单失败的原因 --- %@", aError.errorDescription); } }]; ---- 上一页:[[im:ios:basics:message|消息]] 下一页:[[im:ios:basics:group|群组管理]]