用户信息托管
本文档旨在指导开发者如何在融云即时通讯 iOS 客户端 SDK 中实现用户信息订阅、查询和 监听,同时支持用户信息与权限的修改、查询。 通过本文档, iOS 开发者将了解如何获取和跟踪用户信息,以及如何在用户信息变更、订阅状态变更时接收通知。
提示
此功能在 5.10.0 版本开始支持。
开通服务
使用此功能前,您须在控制台开通信息托管服务。
用户信息管理
SDK 提供了用户信息修改、查询、订阅的相关接口。但客户端 SDK 仅支持修改自已的用户信息。
用户信息设置
使用 updateMyUserProfile:success:error:
接口可以修改自已的用户信息。
RCUserProfile 属性介绍:
属性名 | 类型 | 描述 |
---|---|---|
name | NSString | 昵称,长度不超过 32 个字符。 |
portraitUri | NSString | 头像地址,长度不超过 128 个字符。 |
uniqueId | NSString | 用户应用号,支持大小写字母、数字,长度不超过 32 个字符。请注意 SDK 不支持设置此字段。 |
NSString | Email,长度不超过 128 个字符。 | |
birthday | NSString | 生日,长度不超过 32 个字符 |
gender | RCUserGender | 性别 |
location | NSString | 所在地,长度不超过 32 个字符。 |
role | NSUInteger | 角色,支持 0~100 以内数字。 |
level | NSUInteger | 级别,支持 0~100 以内数字。 |
userExtProfile | NSDictionary<NSString *, NSString *> | 自定义扩展信息,默认最多可以设置 20 个用户信息(以 Key、Value 方式设置,扩展用户信息的 Key 需通过开发者后台进行设置)
|
代码示例
RCUserProfile *userProfile = [[RCUserProfile alloc] init];
userProfile.name = @"name";
[[RCCoreClient sharedCoreClient] updateMyUserProfile:userProfile success:^{
// 更新成功
} error:^(RCErrorCode errorCode, NSString * _Nullable errorKey) {
// 更新失败
}];
获取当前用户信息
您可以使用 getMyUserProfile:error:
方法获取当前用户信息。
代码示例
[[RCCoreClient sharedCoreClient] getMyUserProfile:^(RCUserProfile *userProfile) {
// 获取成功
} error:^(RCErrorCode errorCode) {
// 获取失败
}];
批量获取他人用户信息
您可以使用 getUserProfiles:success:error:
方法查询指定用户的用户信息。一次最多查询 20个 用户的用户信息。
代码示例
NSArray *userIds = @[@"userId1", @"userId2"];
[[RCCoreClient sharedCoreClient] getUserProfiles:userIds success:^(NSArray<RCUserProfile *> *userProfiles) {
// 获取成功
} error:^(RCErrorCode errorCode) {
// 获取失败
}];
用户权限
客户端 SDK 提供了用户权限的设置和获取接口,通过 RCUserProfileVisibility
枚举来表示用户权限。
枚举值 | 用户权限 |
---|---|
RCUserProfileVisibilityNotSet | 未设置:以 AppKey 权限设置为准,默认是此状态。 |
RCUserProfileVisibilityInvisible | 都不可见:任何人都不能搜索到我的用户信息,名称、头像除外。 |
RCUserProfileVisibilityEveryone | 所有人:应用中任何用户都可以 查看到我的用户信息。 |
用户权限设置
您可以使用 updateMyUserProfileVisibility:success:error
方法设置当前用户的用户信息访问权限。
代码示例
[[RCCoreClient sharedCoreClient] updateMyUserProfileVisibility:RCUserProfileVisibilityEveryone success:^{
// 修改成功
} error:^(RCErrorCode errorCode) {
// 修改失败
}];
用户权限获取
您可以使用 getMyUserProfileVisibility:
方法获取当前用户的用户信息访问权限。