http://www.ox-holdings.com

发布的版本本次发布的版本号为,将注册群通知消息过滤接口移动到 MsgService

摘要即时通信云博客园云集SDK新版揭橥,本次公布的版本号为:2.5.0。公布的本子此次发布的版本号为 2.5.0版,更新时间为:二零一五年十二月08日。iOS 2.5.0 更新内容新扩充加准时清理 SDK 日志的功效丰裕闲谈室不常禁言的接口扶持中间转播新闻网络通话新扩充是还是不是自动旋转远端画面包车型地铁设置autoRotateRemoteVideo改善修复闲扯室 Tip 音信无法正常分析的难题Android 2.5.0 更新内容新增添1. 抬高文本音信的全局搜索接口:MsgService#searchAllMessageHistory。2. 增加音信转发功效:MessageBuilder#createForwardMessage,补助除公告消息和音摄像音信以外的音信类型。3. 增加闲谈室有的时候禁言接口:ChatRoomService#markChatRoomTempMute,协理设置有的时候禁言时长。更换1. 将注册群布告新闻过滤接口移动到 MsgService中:MsgService#registerIMMessageFilter ,并帮助单聊和群聊的打招呼类型音讯过滤,不再限于群布告消息,相同的时间协理音摄像类型新闻过滤。2. 聊天室布局调治,闲谈室业务仅在 UI 进度管理。3. SDK 输出jar包按模块分离:nim-sdk.jar(必得)、nim-chatroom.jar(可选闲谈室模块)、nim-rts.jar(可选实时会话白板模块)、nim-avchat.jar(可选实时音录像模块)、nrtc-sdk.jar(实时会话、实时音录制根基库),供开辟者按需组合使用。Web SDK 2.5.0 更新内容改换获取顾客著名影片数组节制每一回最三只好得到1四16个片子新扩充转发音讯重发消息获得包蕴关键词的地头历史记录新扩大参数global表示是或不是全局寻找同步按钮syncExtraTeamInfo, 调控是还是不是同步额外的群新闻, 暗中认可true会同步额外的群消息, 如今席卷最近登入顾客是不是开启有个别群的新闻提示 (SDK 只是存款和储蓄了此信息, 具体用此音信来做什么专门的工作完全由开荒者调节卡塔尔调用接口改进本人的群属性来关闭/开启有个别群的新闻提醒调用接口是或不是需求群音信公告来询问是不是必要群新闻文告设置聊天室偶尔禁言Windows(PC卡塔尔SDK 2.5.0 更新内容修复语音播报结束延迟难题对话列表更新时音信未读数目错误的主题素材新扩充音讯历史本地全局搜索, nim_msglog.h群组扩充得到群新闻和成员音讯的一道接口, nim_team.h闲谈室偶然禁言, nim_chatroom.h音信转载接口, nim_talk.h音摄像扶持SOCKS5代理对端录制画面自动旋转开关下载地址请从以下官方网站地址下载:

订阅事件

  • 向特定客户订阅特定事件

演示代码

nim.subscribeEvent({
type: 100000,
accounts: ['cs3', 'cs4'],
subscribeTime: 70,
sync: true,
done: subscribeEventDone
});
function subscribeEventDone(error, obj) {
console.log('订阅事件' + (!error?'成功':'失败'), error, obj);
}

参数解释

  • type, 事件类型,顾客自定义可公布事件类型值为100000上述,通过上层逻辑定义其意义;1为服务器特殊事件,即多端登入景况,可订阅不可发布。
  • subscribeTime, 订阅关系的得力时间,单位秒 60s~30天(2592000),默认30天
  • sync 订阅后是不是及时联合最新事件,true:同步,false:不一致步,暗中认可可步
  • vaildTime, 客户发表事件的可行时间,可选参数,以秒为单位,范围在60s~7天(604800s),默认7天
  • broadcastType, 事件广播类型,可选参数,1:仅在线 2:在线和离线,暗中同意2(在线和离线卡塔尔
  • sync, 是不是同步给协和,可选参数,true/false,暗许false
  • done, 客商自定义的结果回调函数
  • 此回调包蕴八个参数,第一个参数为error,倘使成功则error为null;第一个参数为obj, 它有叁个字段failedAccounts的值为操作的类型, 具体品种如下:
  • failedAccounts, 战败的账号数组,要是为空数组则意味着操作全体成功

摘要即时通信云知乎云信于前年四月06日通知3.8.0版,此次更新为根本版本的次要更新,详细情况见小说内容。公布的版本这次发表的版本号为 3.8.0版,更新时间为:二零一七年011月07日。iOS 更新内容新扩大聊天室针对一定成员,支持 nick, avatar 和 extension 字段的服务器存款和储蓄。SDK 点对点音录像接口支持PushKit, 新添相关接口:新的 SDK 基本配备注入接口,协理填写云信 PushKit 推送证书名复制- (void卡塔尔(قطر‎registerWithOption:(NIMSDKOption *卡塔尔国option;更新云信 PushKitToken复制- (voidState of QatarupdatePushKitToken:(NSData *卡塔尔(قطر‎token;Android 更新内容新添1. 聊天室针对一定成员,帮忙 nick, avatar 和 extension 字段的长久化。改动1. 照准 oppo 手提式有线电话机 IPC 相当难题增多容错管理。2. 修复全文字笔迹核实索偶现的 InternalError 难点。3. 指向性解包出错的极端气象增加容错管理。Windows(PC卡塔尔 SDK 更新内容新扩充闲聊室更新固定成员新闻时,扶持nick,avator和ext字段的长久化语音访谈模块路线相关参数类型改为宽字符, nim_audio.hWeb SDK 更新内容新扩充新增加通用同步图片预览接口,帮忙私有化定制方案连接早先化帮忙选拔总是公约更换修复忽视群众文化艺术告音信配置以往,对群状态改善相关bug修复不开启数据库情状下,会话未读数不许的主题素材下载地址请从以下官方网址地址下载:

摘要即时通信云和讯云信于二〇一七年02月06日揭露4.0版,本次更新为重中之重版本更新,详细情况见作品内容。发表的版本此次发布的版本号为 4.0版,更新时间为:前年0十一月06日。iOS 更新内容新增加智能手机器人作用,增添新的机器人微机NIM罗布otManager。闲谈室连麦队列更改后数据同步,现在可以从NIMChatroomNotificationContent中的ext字段读取到现实的改变数据了。发送谈心室音信时,可以透过安装新闻中NIMMessageSetting的historyEnabled字段来支配是还是不是存服务器历史记录。Android 更新内容新扩展1. 联网One plus推送服务。2. 接入搜狐Bot(智能手机器人卡塔尔(قطر‎功用,扩大RobotService、罗布otServiceObserve接口。3. 猛增谈天室发新闻是还是不是存历史记录的按键,发送闲谈室音信时得以选取是还是不是存入历史记录。4. 聊天室连麦队列更改后数据同步。更改1. 被叫语音、录像通话未接听计入未读数。2. 修复选择聊天室 tip 消息获得content 为空的难点。Windows(PC卡塔尔 SDK 更新内容新增添机器人模块, nim_robot.h闲聊室音信不存历史记录开关闲谈室队列退换公告扩充更改内容扶植Https(私下认可Http)修复修复管理后台创造群(无需顾客同意)时,在线客商端非常小概一齐该群消息到地点的标题修复申请参预群(不必要管理员同意)时,本地群列表里未有该群音讯的主题素材Web SDK 更新内容新扩展新添机器人新闻收发接口新添机器人暗中同意bot类型信息的xml深入深入分析方法新扩展闲话室发送消息可选不保留历史消息配置改动修复部分金立机型断网重连后合计解析难题修复转载消息数据库记录有误的难题下载地址请从以下官方网站地址下载:

摘要即时通信云网易云信SDK新版发表,这一次发布的版本号为:2.8.0,为宽度更新版本,首要增添了新闻撤回作用。公布的本子此番公布的版本号为 2.8.0版,更新时间为:二零一五年四月一日。iOS 2.8.0 更新内容新增加信息撤回成效新闻增加来源字段变改革过断网后登时重连闲谈室轻便退步的主题材料Android 2.8.0 更新内容新扩张1. 充裕音信撤回效能:MsgService#revokeMessage, MsgServiceObserve#observeRevokeMessage。2. 足够删减钦赐会话的旅游新闻接口:MsgService#deleteRoamingRecentContact。3. 大幅度增加保存音信到本地接口:MsgService#saveMessageToLocal 可以设置音讯存款和储蓄的时间点。4. 消息中增多获取音讯发送方类型接口:IMMessage#getFromClientType。更换1. 轻易全文字笔迹核准索插件包大小。2. 清空会话本地消息记录 MsgService#clearChattingHistory 接口保留 RecentContact 中的 tag, extension, time 属性。Web SDK 2.8.0 更新内容新扩张音信撤回Windows(PC卡塔尔国 SDK 2.8.0 更新内容修复V2.7.0本子下载文件暂停继续下载的主题素材。闲谈室接口注册发送音讯回执回调接口命名改正:nim_chatroom_reg_send_msg_arc_cb接口改造为nim_chatroom_reg_send_msg_ack_cb。 nim_chatroom.h新闻历史插入本地DB一条音信的接口命名和参数调度:typedef void(*nim_msglog_write_db_only_async)(const char *account_id, NIMSessionType to_type, const char *msg_id, const char *json_msg, const char *json_extension, nim_msglog_res_cb_func cb, const void *user_data); 调整为 typedef void(*nim_msglog_insert_msglog_async)(const char *talk_id, const char *json_msg, bool need_update_session, const char *json_extension, nim_msglog_res_cb_func cb, const void *user_data); 。 nim_msglog.h合并错误码:10414和10450联合为10414,新扩大错误码kNIMLocalResMsgNosDownloadCheckError。nim_res_code_def.h群成员接受退群众文化艺术告后群成员数量不从地面删除,通过标识位标志为无用,具体调用方法请参照他事他说加以考查api文书档案或支付文书档案。修复某种意况下session change通告时session id为空的标题。新添撤回音讯。 nim_talk.h下载地址请从以下官方网站地址下载:

老铁对象

知音对象有以下字段:

  • account: 账号
  • alias: 昵称
  • custom: 扩大字段, 开辟者能够自动扩大, 提议封装成JSON格式字符串
  • createTime: 成为死党的年华
  • updateTime: 更新时间

发送谈天室自定义音讯

var value = Math.ceil(Math.random()*3);
var content = {
type: 1,
data: {
value: value
}
};
var msg = chatroom.sendCustomMsg({
content: JSON.stringify(content),
done: sendChatroomMsgDone
});
console.log('正在发送聊天室自定义消息, id=' + msg.idClient);

Blob

  • 将包含 MIME type 和 base64 数据的 data URL 转换为 Blob 对象
var dataURL = '';

var blob = NIM.blob.fromDataURL(dataURL);

// blob instanceof Blob === true;

宣告订阅事件

  • 向各样顾客端发表独立事件

演示代码

nim.publishEvent({
type: 100000,
value: 2,
custom: 'hello world',
vaildTime: 60,
sync: false,
done: publishEventDone
});
function publishEventDone(error, obj) {
console.log('发布事件' + (!error?'成功':'失败'), error, obj);
}

参数解释

  • type, 事件类型,客商自定义可发表事件类型值为100000上述,通过上层逻辑定义其意义
  • value, 事件值,与相应事件类型一一对应,用上层订阅其意思,必需是自然数
  • custom, 客户自定义事件的扩展属性,可选参数,最大256字节
  • vaildTime, 顾客发布事件的管事时间,可选参数,以秒为单位,范围在60s~7天(604800s),默认7天
  • broadcastType, 事件广播类型,可选参数,1:仅在线 2:在线和离线,暗许2(在线和离线卡塔尔
  • sync, 是或不是同步给和睦,可选参数,true/false,暗中认可false
  • done, 客户自定义的结果回调函数,第二个参数为error,假如成功则error为null

群诚邀形式

群约请形式有以下三种

  • 'manager' (独有管理员/群主能够诚邀客人入群卡塔尔国
  • 'all' (全部人能够邀约客人入群卡塔尔国

已读回执

  • 对话对象加了一本性质msgReceiptTime代表音信已读回执时间戳, 若是有此字段, 表达那时候间戳此前的具备音信对方均已读
  • 一时仅对'p2p'会话起效率
  • 此字段不必然有, 唯有对方发送过已读回执之后才会有
  • 调用接口发送信息已读回执来发送音讯已读回执
  • 调用接口询问新闻是或不是被对方读过了来询问消息是不是被对方读过了

工具方法

发送文书音讯

  • 文本消息是消息的一种
  • 开荒者能够直接发送文书新闻
  • 协理以下二种情景
  • 由此参数fileInput传扬文件接受 dom 节点或然节点 ID
  • 透过参数blob传入 Blob 对象
  • 经过参数dataURL传播满含 MIME type 和 base64 数据的 data U福睿斯L, 此用法要求浏览器帮忙 window.Blob
  • 经过参数wxFilePath流传一时文件路线, 仅供Wechat小程序行使, 通过 wx.chooseImage 大概 wx.startRecord 取得的有时文件路线
  • SDK会先将文件上传到文件服务器, 然后把得到的文本对象在uploaddone回调中传给客商, 然后将其拼装成文件信息发送出去。
  • 开荒者也得以先预览文件来博取文件对象, 然后调用此接口发送文书新闻。
  • 直接发送文书音信的话会在beforesend回调里面传出SDK生成的idClient, 就算先预览文件再发送, 那么此接口会直接重临idClient
  • 参数type钦点了要发送的文件类型, 富含图形、音频、录制和通常文书, 对应的值分别为'image''audio''video''file', 不传默以为'file'
  • 图形、音频、摄像和平常文书的区分在于具体的文书音信不平等, 具体字段请参见
  • 图片对象
  • 节奏对象
  • 录制对象
  • 文件对象
  • 文件大小限定为最大100M
  • 高等浏览器会在上传前就检验文件大小
  • IE8和IE9会在上传完毕后检查实验文件大小
nim.sendFile({
scene: 'p2p',
to: 'account',
type: 'image',
fileInput: fileInput,
beginupload: function(upload) {
// - 如果开发者传入 fileInput, 在此回调之前不能修改 fileInput
// - 在此回调之后可以取消图片上传, 此回调会接收一个参数 `upload`, 调用 `upload.abort();` 来取消文件上传
},
uploadprogress: function(obj) {
console.log('文件总大小: ' + obj.total + 'bytes');
console.log('已经上传的大小: ' + obj.loaded + 'bytes');
console.log('上传进度: ' + obj.percentage);
console.log('上传进度文本: ' + obj.percentageText);
},
uploaddone: function(error, file) {
console.log(error);
console.log(file);
console.log('上传' + (!error?'成功':'失败'));
},
beforesend: function(msg) {
console.log('正在发送p2p image消息, id=' + msg.idClient);
pushMsg(msg);
},
done: sendMsgDone
});

图形操作

使用预览文件和出殡文书新闻取得图片 url 之后,能够调用 SDK 提供的图样操作来拍卖图片, 全体的操作在 NIM 和 Chatroom 上都提供, 下文仅以 NIM 为例给出使用办法, 图片操作分为两大类

  • 一类是经过 url 拼接的不二诀窍来拍卖图片, 此类接口是同台的, 平时用于显示图片, 通过此类措施变通的 url 仅可用以 UI 呈现, 调用任何非图片管理接口的时候无法传回此类 url
  • 预览图片通用方法
  • 预览去除图片元消息
  • 预览图片品质
  • 预览interlace图片
  • 预览旋转图片
  • 预览高斯模糊图片
  • 预览裁剪图片
  • 预览生成缩略图
  • 一类是通过服务器来管理图片, 此类接口是异步的, 日常用于转移新的 url, 调用任何非图片管理接口的时候能够流传此类 url
  • 剔除图片元消息
  • 改革图片品质
  • interlace图片
  • 旋转图片
  • 高斯模糊图片
  • 剪裁图片
  • 浮动缩略图
  • 拍卖图片

消息

示范代码

  • 此接口为单例形式, 对于同三个账号, 恒久再次回到同一份实例, 即唯有首先次调用会开端化四个实例
  • 连绵起伏调用此接口会一向回到早先化过的实例, 同期也会调用接口更新配备更新传入的配置
  • 接二连三调用此接口时, 如若连接已断开, 会自动建立连接
  • 当发生掉线时,SDK会自动实行重连
  • 开辟者在收受onconnect回调之后表示链接已经济建设立, 那时候 SDK 会初步同盟数据, 随后在抽取onsyncdone回调之后表示 SDK 实现了数额同步工作, 那时候开采者能够举办渲染UI等操作了。
  • 这里的data代表数量, 在背后章节的躬体力行代码中会多次行使这些目的
  • 这里的nim意味着 SDK, 在末端章节的示范代码中会数次选取这么些对象.
  • 这里的参数而不是具备的最初化参数, 请查阅其余章节的开始化参数
  • 初始化SDK
  • 多端登陆开端化参数
  • 客商关系先导化参数
  • 知音关系初叶化参数
  • 客户名片开始化参数
  • 群组最早化参数
  • 会话最初化参数
  • 音讯早先化参数
  • 系统通报起始化参数
  • 一同到位
  • 全部的起头化代码
var data = {};
// 注意这里, 引入的 SDK 文件不一样的话, 你可能需要使用 SDK.NIM.getInstance 来调用接口
var nim = NIM.getInstance({
// debug: true,
appKey: 'appKey',
account: 'account',
token: 'token',
onconnect: onConnect,
onwillreconnect: onWillReconnect,
ondisconnect: onDisconnect,
onerror: onError
});
function onConnect() {
console.log('连接成功');
}
function onWillReconnect(obj) {
// 此时说明 SDK 已经断开连接, 请开发者在界面上提示用户连接已断开, 而且正在重新建立连接
console.log('即将重连');
console.log(obj.retryCount);
console.log(obj.duration);
}
function onDisconnect(error) {
// 此时说明 SDK 处于断开状态, 开发者此时应该根据错误码提示相应的错误信息, 并且跳转到登录页面
console.log('丢失连接');
console.log(error);
if (error) {
switch (error.code) {
// 账号或者密码错误, 请跳转到登录页面并提示错误
case 302:
break;
// 重复登录, 已经在其它端登录了, 请跳转到登录页面并提示错误
case 417:
break;
// 被踢, 请提示错误后跳转到登录页面
case 'kicked':
break;
default:
break;
}
}
}
function onError(error) {
console.log(error);
}

智能手机器人简要介绍

  • 智能闲聊机器人建设方案依托和讯IM即时电视发表、语音识别、语义精晓等服务,为开拓者提供人机交互作用API/SDK、语音识别、意图识别、知识库配置、动态接口等成效,可以在使用IM内快速集成场景丰裕的智能闲聊机器人。
  • 详见搜狐人工智能

安装闲聊室黑名单

  • 被插手黑名单的人将不可能进来此闲聊室
  • account: 待设置的账号
  • isAdd: true代表增多, false代表移除
  • 当有人被参加黑名单时, 全部谈心室成员会收到类型为'blackMember'的谈天室公告音信。
  • 当有人被移除黑名单时, 全部闲谈室成员会收到类型为'blackMember'的闲扯室布告新闻。
  • custom: 扩充字段, 借使填了, 那么其余谈心室成员选取的谈心室文告新闻的attach.custom的值为此字段
  • 引入应用JSON格式构建, 非JSON格式的话, Web端会不奇怪采用, 但是会被其它端扬弃
chatroom.markChatroomBlacklist({
account: 'account',
isAdd: true,
done: markChatroomBlacklistDone
});
function markChatroomBlacklistDone(error, obj) {
console.log('添加聊天室黑名单' + (!error?'成功':'失败'), error, obj.member);
}

闲聊室新闻类型

  • 'text' (文本)
  • 'image' (图片)
  • 'audio' (音频)
  • 'video' (视频)
  • 'file' (文件)
  • 'geo' (地理地方卡塔尔
  • 'custom' (自定义音讯State of Qatar
  • 'tip' (提示音讯卡塔尔(قطر‎
  • 唤醒音信用于会话内之处提醒,如步向会话时现身的应接音讯,可能会话命中敏感词后的提醒音讯等等.
  • 'notification' (闲聊室布告音讯卡塔尔(قطر‎
  • 好几闲谈室操作后有所闲谈室成员会收到一条相应的聊天室文告音讯, 详细介绍请参见闲聊室文告音信的品类

投入静音列表

  • SDK只承受掩护静音列表, 具体要基于静音列表进行的操作由开辟者决定
  • SDK内部调用nim.markInMutelist来完毕实际工作
nim.addToMutelist({
account: 'account',
done: addToMutelistDone
});
function addToMutelistDone(error, obj) {
console.log(error);
console.log(obj);
console.log('加入静音列表' + (!error?'成功':'失败'));
if (!error) {
addToMutelist(obj);
}
}

管理图片

此方式选拔一组图片操作, 按操作顺序依次拍卖图片, 可选的操作满含:

  • 更正图片品质
  • interlace图片
  • 旋转图片
  • 高斯模糊图片
  • 剪裁图片
  • 扭转缩略图

每种操作所需的参数请参见下边包车型大巴顺序艺术, 除了地点方法列出来的参数之外, 每一种操作需求提供操作类型, 分别是

  • 'quality'
  • 'interlace'
  • 'rotate'
  • 'blur'
  • 'crop'
  • 'thumbnail'
// 裁剪后旋转
var url = 'http://nim.nos.netease.com/MTAxMTAwMg==/bmltYV8xNDc5OTNfMTQ0MzE0NTgyNDI0M184YjFkYTMwMS02NjcxLTRiYjktYTUwZC04ZTVlZjZlNzZjMzA=';
nim.processImage({
url: url,
ops: [
{
type: 'crop',
x: 100,
y: 0,
width: 250,
height: 250,
},
{
type: 'thumbnail',
mode: 'cover',
width: 80,
height: 80
}
],
done: processImageDone
});
function processImageDone(error, obj) {
console.log(error);
console.log(obj);
console.log('处理图片' + (!error?'成功':'失败'));
}

登录端

登陆端代表报到在有些设备上的相干消息, 好似下字段

  • type: 登录的器材项目
  • os: 登入设备的操作系统
  • mac: 登陆设备的 mac 地址
  • deviceId: 登入设备ID, uuid
  • account: 登入的帐号
  • connectionId: 登入设备分配的连年号
  • ip: 登录的服务器 IP
  • time: 登陆时间
  • online: 是或不是在线

出殡音讯

  • 跟发新闻相关的接口有
  • 出殡文书新闻
  • 预览文件
  • 发送文书音讯
  • 发送地理地点新闻
  • 发送提示音信
  • 发送自定义新闻
  • 出殡机器人音讯
  • 出殡消息的配置选项
  • 出殡本地音讯
  • 重发音信
  • 倒车音信
  • 新闻撤回
  • 先表达多少个具有发送消息的接口都用到的参数
  • scene参数用来钦赐发送音信的场景
  • to参数用来内定音信的接收方, 发送点对点音讯时填帐号, 发送群音讯时填群ID
  • 发送音信的接口会回去SDK生成的ID, 对应该为字段idClient, 有叁个不一是一向发送文书音信是在beforesend回调里获取这些值
  • done回调中能够依照error对象和音讯对象的idClient字段来分明相应的音讯的出殡和安葬状态。
  • 如果error为空, 那么注明idClient相应的音讯发送成功
  • error不为空, 表明idClient相应的消息发送战败, error含有详细的错误消息
  • 以下代码都以发送点对点音讯(scene'p2p')为例, 如需发送群音讯, 请将scene的值替换为'team', 将to的值替换为群ID

SDK 概述

博客园云信 SDK 为 Web 应用提供几个宏观的 IM 系统开辟框架, 屏蔽掉 IM 系统的千头万绪的底细, 对外提供比较容易的 API 接口, 方便第三方接受飞快集成 IM 功效。
新浪云信还支付了可供开采者们仿效,如何利用该SDK的Web 德姆o:

  • Web源码导读
  • Web(移动端H5State of Qatar源码导读(不满含音摄像State of Qatar

校订图片下载的名字

  • 此方法会再次来到三个新的地点
var url = 'http://nim.nos.netease.com/MTAxMTAwMg==/bmltYV8xNDc5OTNfMTQ0MzE0NTgyNDI0M184YjFkYTMwMS02NjcxLTRiYjktYTUwZC04ZTVlZjZlNzZjMzA=';
var nameUrl = nim.packFileDownloadName({
url: url,
name: '测试.jpg'
});
console.log(nameUrl);

数据库包容性

在支撑数据库的浏览器上 SDK 会将数据缓存到数据库中, 后续同步都以增量更新, 加快开始化速度

删去亲密的朋友

  • 剔除好朋友后, 被剔除的人会收到一条项目为'deleteFriend'的系统通报, 此类系统通报的from字段的值为删除方的帐号, to字段的值为被删除方的账号。
nim.deleteFriend({
account: 'account',
done: deleteFriendDone
});
function deleteFriendDone(error, obj) {
console.log(error);
console.log(obj);
console.log('删除好友' + (!error?'成功':'失败'));
if (!error) {
onDeleteFriend(obj.account);
}
}

高斯模糊图片

  • 只帮衬通过预览文件或出殡文书新闻获得的图纸 url, 恐怕经过其余图片操作后取得的图形 url
var url = 'http://nim.nos.netease.com/MTAxMTAwMg==/bmltYV8xNDc5OTNfMTQ0MzE0NTgyNDI0M184YjFkYTMwMS02NjcxLTRiYjktYTUwZC04ZTVlZjZlNzZjMzA=';
var blurUrl = nim.blurImage({
url: url,
radius: 5,
sigma: 3,
done: blurImageDone
});
function blurImageDone(error, obj) {
console.log(error);
console.log(obj);
console.log('高斯模糊图片' + (!error?'成功':'失败'));
}

踢闲聊室成员

  • account: 待踢的账号
  • custom: 扩大字段, 就算填了, 那么别的闲谈室成员选用的谈天室公告音信的attach.custom的值为此字段, 被踢的人接到的ondisconnect回调接纳的参数的custom的值为此字段
  • 引进应用JSON格式营造, 非JSON格式的话, Web端会正常选拔, 可是会被其他端扬弃
  • 当有人被踢出谈天室时, 全部谈天室成员会收到类型为'kickMember'的谈天室公告音讯。
chatroom.kickChatroomMember({
account: 'account',
done: kickChatroomMemberDone
});
function kickChatroomMember(error, obj) {
console.log('踢人' + (!error?'成功':'失败'), error, obj);
}

闲聊室功用概述

  • 现阶段不扶助通过 SDK 接口创设/解散闲谈室。
  • 进去闲谈室时必得树立新的连接,退出闲谈室大概被踢会断开连接,在闲聊室中掉线会有机关心注重连,开辟者供给监听谈天室连接景况来做出科学的分界面表现。
  • 补助闲谈人数无上限。
  • 闲聊室只同意客户手动步向,不能够举行诚邀。
  • 帮衬同时步入四个闲谈室,会确立多少个三番五次。
  • 断开谈心室连接后,服务器不会再推送该谈心室的新闻给此顾客。
  • 在举行任何操作此前,必得先步向闲谈室。即必得先起始化好谈心室并且吸纳onconnect回调。
  • 顾客踏入谈天室之后,不会接到此闲聊室的野史音讯推送。如有历史消息供给,能够调用音讯查询接口实行突显。
  • 聊天室成员分固定成员和旅客二种等级次序。

知音关系开首化参数

  • 此间的参数并非富有的开始化参数, 请查阅初始化 SDK, 甚至任何章节的初步化参数
  • 初始化SDK
  • 多端登陆初叶化参数
  • 客户关系先河化参数
  • 老铁关系初阶化参数
  • 顾客名片起初化参数
  • 群组初步化参数
  • 会话开首化参数
  • 消息起始化参数
  • 系统通报开端化参数
  • 联合到位
  • 一体化的伊始化代码
  • 请参考管理系列通报此中的跟基友相关的逻辑

示范代码

var nim = NIM.getInstance({
onfriends: onFriends,
onsyncfriendaction: onSyncFriendAction
});
function onFriends(friends) {
console.log('收到好友列表', friends);
data.friends = nim.mergeFriends(data.friends, friends);
data.friends = nim.cutFriends(data.friends, friends.invalid);
refreshFriendsUI();
}
function onSyncFriendAction(obj) {
console.log(obj);
switch (obj.type) {
case 'addFriend':
console.log('你在其它端直接加了一个好友' + obj.account + ', 附言' + obj.ps);
onAddFriend(obj.friend);
break;
case 'applyFriend':
console.log('你在其它端申请加了一个好友' + obj.account + ', 附言' + obj.ps);
break;
case 'passFriendApply':
console.log('你在其它端通过了一个好友申请' + obj.account + ', 附言' + obj.ps);
onAddFriend(obj.friend);
break;
case 'rejectFriendApply':
console.log('你在其它端拒绝了一个好友申请' + obj.account + ', 附言' + obj.ps);
break;
case 'deleteFriend':
console.log('你在其它端删了一个好友' + obj.account);
onDeleteFriend(obj.account);
break;
case 'updateFriend':
console.log('你在其它端更新了一个好友', obj.friend);
onUpdateFriend(obj.friend);
break;
}
}
function onAddFriend(friend) {
data.friends = nim.mergeFriends(data.friends, friend);
refreshFriendsUI();
}
function onDeleteFriend(account) {
data.friends = nim.cutFriendsByAccounts(data.friends, account);
refreshFriendsUI();
}
function onUpdateFriend(friend) {
data.friends = nim.mergeFriends(data.friends, friend);
refreshFriendsUI();
}
function refreshFriendsUI() {
// 刷新界面
}

参数解释

  • onfriends, 同步基友列表的回调, 会传入好友列表friends
  • friends的习性invalid包涵被剔除的至交列表
  • 此回调是增量回调, 能够调用nim.mergeFriends和nim.cutFriends来归总数据
  • onsyncfriendaction, 当前报到客商在任何端举行亲密的朋友相关的操作后的回调
  • 操作满含
  • 直接加为好朋友
  • 报名加为很好的朋友
  • 通过好朋友申请
  • 驳倒基友申请
  • 删除老铁
  • 履新亲密的朋友
  • 此回调会吸收接纳三个参数obj, 它有多个字段type的值为操作的类型, 具体项目如下:
  • 'addFriend' (直接加为基友卡塔尔, 这时候obj的字段如下:
  • account的值为被直接加为老铁的账号
  • friend为被直接加为基友的基友对象
  • ps为附言
  • 'applyFriend' (申请加为老铁卡塔尔(قطر‎, 那时obj的字段如下:
  • account的值为被申请加为死党的账号
  • ps为附言
  • 'passFriendApply' (通过亲密的朋友申请卡塔尔, 这时obj的字段如下:
  • account的值为被通过基友申请的账号
  • friend为被通过基友申请的好朋友对象
  • ps为附言
  • 'rejectFriendApply' (推却好朋友申请State of Qatar, 那个时候obj的字段如下:
  • account的值为被拒绝基友申请的账号
  • ps为附言
  • 'deleteFriend' (删除好朋友卡塔尔(قطر‎, 那时候obj的字段如下:
  • account的值为被删去亲密的朋友的账号
  • 'updateFriend' (更新亲密的朋友卡塔尔(قطر‎, 这时候obj的字段如下:
  • friend的值为被更新的亲密的朋友对象
  • 能够调用nim.mergeFriends和nim.cutFriendsByAccounts来合併数据

闭门羹入群申请

  • 顾客能够申请插手高档群, 指标群的群主和管理员会收到一条项目为'applyTeam'的系统通报, 此类系统通报的from字段的值为申请方的帐号, to字段的值为相应的群ID, 高档群的群主和大班在接到入群申请后, 能够选择通过大概拒却入群申请。
  • 如果透过申请, 那么该群的富有群成员会收到一条项目为'passTeamApply'的群文告新闻, 此类群公告音信的from字段的值为经过入群申请的人的帐号, to字段的值为相应的群ID, attach有二个字段team的值为相应的群对象, attach有多少个字段account的值为申请方的帐号, attach有一个字段members的值为被通过报名的群成员列表。
  • 如果闭门羹申请, 那么申请人会收下一条项目为'rejectTeamApply'的系统通报, 此类系统通报的from字段的值为拒却方的帐号, to字段的值为相应的群ID, attach有三个字段team的值为对应的群。
  • 参数from填申请方的帐号, 该参数的名字在v1.3.0本子中从account变为from
  • ps: 附言, 选填, 开辟者也能够使用JSON格式的字符串来扩充此内容
// 假设 sysMsg 是通过回调 `onsysmsg` 收到的系统通知
nim.rejectTeamApply({
idServer: sysMsg.idServer,
teamId: 123,
from: 'a2',
ps: '就不',
done: rejectTeamApplyDone
});
function rejectTeamApplyDone(error, obj) {
console.log(error);
console.log(obj);
console.log('拒绝入群申请' + (!error?'成功':'失败'));
}

发送群新闻

发送群音讯时只需将上文中各种发送新闻接口的scene替换为'team', 将to替换为群ID

会话开端化参数

  • 此处的参数实际不是富有的起先化参数, 请查阅初始化 SDK, 以至此外章节的起先化参数
  • 初始化SDK
  • 多端登陆开首化参数
  • 客户关系初叶化参数
  • 好朋友关系起头化参数
  • 客商名片初步化参数
  • 群组伊始化参数
  • 会话初步化参数
  • 消息最先化参数
  • 系统通报伊始化参数
  • 一同到位
  • 完全的开头化代码

亲自去做代码

var nim = NIM.getInstance({
onsessions: onSessions,
onupdatesession: onUpdateSession
});
function onSessions(sessions) {
console.log('收到会话列表', sessions);
data.sessions = nim.mergeSessions(data.sessions, sessions);
updateSessionsUI();
}
function onUpdateSession(session) {
console.log('会话更新了', session);
data.sessions = nim.mergeSessions(data.sessions, session);
updateSessionsUI();
}
function updateSessionsUI() {
// 刷新界面
}

参数解释

  • syncSessionUnread, 是还是不是同步会话的未读数, 暗中同意不一致台
  • 一旦选取同步
  • 那就是说在一个端读过的对话在别的端也会被标识为已读
  • 在调用安装当前对话的时候 SDK 会自动同步三遍未读数, 从此一旦接到当前对话的消息, 须要手动调用重新苏醒设置会话未读数来一块未读数
  • onsessions, 同步近些日子对话列表回调, 会传入会话列表, 准期间正序排列, 即近期聊过天的坐落于列表的最后面
  • 此回调是增量回调, 能够调用nim.mergeSessions来统一数据
  • onupdatesession, 更新会话的回调, 会传入对话对象, 以下情形会选拔此回调
  • 抽出音信
  • 发送音讯
  • 设置当前对话
  • 重新初始化会话未读数

聊天室

请查阅支付希图来下载并引入SDK 文件

立异闲聊室音讯

  • 当履新谈心室新闻时, 全体聊天室成员会收到类型为'updateChatroom'的闲聊室通告新闻。

可更新的字段有

  • 'name': 闲谈室名字
  • 'announcement': 聊天室公告
  • 'broadcastUrl': 直播地址
  • 'custom': 第三方增加字段
chatroom.updateChatroom({
chatroom: {
name: 'newName',
announcement: 'newAnnouncement',
broadcastUrl: 'newBroadcastUrl',
},
needNotify: true,
custom: 'biu',
custom: 'newCustom',
done: updateChatroomDone
})
function updateChatroomDone () {
console.log('更新聊天室信息' + (!error?'成功':'失败'), error, obj);
}

删除全体地点系统通报

  • 如果不支持数据库, 算成功
  • 此措施同期会清空系统通报未读数, 开垦者会吸收接纳onupdatesysmsgunread
nim.deleteAllLocalSysMsgs({
done: deleteAllLocalSysMsgsDone
});
function deleteAllLocalSysMsgsDone(error, obj) {
console.log(error);
console.log(obj);
console.log('删除所有本地系统通知' + (!error?'成功':'失败'));
}

重新载入参数当前应对

  • 重新载入参数当前对话后, 全数会话在选用消息之后会更新未读数
nim.resetCurrSession();

自定义系统通报

  • 开垦者可以向其余顾客或群发送自定义系统通报, 默许只发给在线客商, 假诺须要发送给离线顾客, 那么须求安装参数sendToOnlineUsersOnly=false, 请仿照效法上边包车型大巴演示代码
  • 自定义系统通报和自定义消息的分别如下
  • 自定义音讯归于消息, 会存款和储蓄在云信的消息数据库中, 须求跟其余信息一起表现给客商。
  • 自定义系统通报归属系统通报, 用于第三方布告自个儿, 不会储存在云信的数据库中, SDK不会深入分析那一个布告, SDK仅仅肩负传递这个通告。
  • SDK 不存款和储蓄自定义系统通报, 不管理自定义系统通报的未读数
  • 可选参数有
  • yidunEnable: 是还是不是必要过易盾反垃圾
  • antiSpamContent: 在开启yidunEnable后, 开采者自定义的反垃圾字段(json格式卡塔尔国,格式如下:{"type": 1, "data": "custom content"} 字段表达:type:1.文书,2.图片,3摄像,data内容:文本内容or图片地址or录像地址
var content = {
type: 'type',
value: 'value'
};
content = JSON.stringify(content);
var msgId = nim.sendCustomSysMsg({
scene: 'p2p',
to: 'account',
content: content,
sendToOnlineUsersOnly: false,
apnsText: content,
done: sendCustomSysMsgDone
});
console.log('正在发送p2p自定义系统通知, id=' + msgId);
function sendCustomSysMsgDone(error, msg) {
console.log('发送' + msg.scene + '自定义系统通知' + (!error?'成功':'失败') + ', id=' + msg.idClient);
console.log(error);
console.log(msg);
}

删去某些会话的地头音讯

  • 如果不支撑数据库, 算成功
nim.deleteLocalMsgsBySession({
scene: 'p2p',
to: 'account',
done: deleteLocalMsgsBySessionDone
});
function deleteLocalMsgsBySession(error, obj) {
console.log(error);
console.log(obj);
console.log('删除会话本地消息' + (!error?'成功':'失败'));
}

取得本地历史记录

  • sessionId 若是提供该参数, 那么查询该会话的新闻
  • sessionIds 假设提供该参数, 那么查询那多少个会话的新闻
  • start=0 最初时间
  • end=Infinity 截至时间
  • desc=true true 表示从 end 开始查, false 表示从 begin 开始查
  • limit=100 limit 数量约束
  • type 音信类型, 就算提供该参数, 那么查询该项目标新闻
  • types 假如提供该参数, 那么查询这几种类型的新闻
  • keyword 倘诺提供参数, 那么查询相配该重大词的新闻
nim.getLocalMsgs({
sessionId: 'p2p-account'
limit: 100,
done: getLocalMsgsDone
})
function getLocalMsgsDone(error, obj) {
console.log('获取本地消息' + (!error?'成功':'失败'), error, obj)
}

群组成效概述

SDK 提供了普通群以至高端群二种方式的群功效。 高端群具有更加多的权能操作,三种群聊方式在共有操作上保持了接口一致。推荐 应用程式开拓时只选拔一种群类型实行付出。普通群和高等群在基准上是不能够相互转换的,他们的群类型在创立时就已经规定。在 SDK 2.4.0 版本后,高端群能够具备普通群的漫天功效,推荐应用高档群实行开采。

  • 平凡群 开辟手册中所说起的习见群都等同于 德姆o 中的探究组。普通群未有权限操作,适用于连忙创立多少人会话的场合。每种普通群唯有二个协会者。管理员能够对群进行增减员操作,普通成员只好对群实行增员操作。在累积新成员的时候,并无需经过对方同意。
  • 高档群 高档群在权力上有越来越多的范围,权限分为群主、助理馆员、以致群成员。

参与黑名单

  • 若果贰个客户被投入了黑名单, 那么就不再会接受此客商发送的新闻
  • SDK内部调用nim.markInBlacklist来产生实际专门的学问
nim.addToBlacklist({
account: 'account',
done: addToBlacklistDone
});
function addToBlacklistDone(error, obj) {
console.log(error);
console.log(obj);
console.log('加入黑名单' + (!error?'成功':'失败'));
if (!error) {
addToBlacklist(obj);
}
}

群被约请格局

群被诚邀格局有以下两种

  • 'needVerify' (须求特邀方同意卡塔尔国
  • 'noVerify' (不须要约请方同意State of Qatar

点击查阅最早的作品

云端历史记录

预览文件

  • 开辟者能够预览文件, 援救以下三种情景
  • 因而参数fileInput传播文件选拔 dom 节点也许节点 ID
  • 因此参数blob传入 Blob 对象
  • 通过参数dataURL传扬富含 MIME type 和 base64 数据的 data UTucsonL, 此用法要求浏览器支持 window.Blob
  • 透过参数wxFilePath传播不时文件路线, 仅供微信小程序选择, 通过 wx.chooseImage 只怕 wx.startRecord 取得的不常文件路径
  • SDK会将文件上传到文件服务器, 然后将获得的文本对象在done回调中传给开拓者, 文件对象有以下二种
  • 图形对象
  • 节奏对象
  • 录制对象
  • 文本对象
  • 开荒者在得到文件对象之后, 可以调用发送文书音讯来发送文书新闻。
  • 文件大小节制为最大100M
  • 高端浏览器会在上传前就检查评定文件大小
  • IE8/IE9 会在上传实现后检验文件大小
nim.previewFile({
type: 'image',
fileInput: fileInput,
uploadprogress: function(obj) {
console.log('文件总大小: ' + obj.total + 'bytes');
console.log('已经上传的大小: ' + obj.loaded + 'bytes');
console.log('上传进度: ' + obj.percentage);
console.log('上传进度文本: ' + obj.percentageText);
},
done: function(error, file) {
console.log('上传image' + (!error?'成功':'失败'));
// show file to the user
if (!error) {
var msg = nim.sendFile({
scene: 'p2p',
to: 'account',
file: file,
done: sendMsgDone
});
console.log('正在发送p2p image消息, id=' + msg.idClient);
pushMsg(msg);
}
}
});

客户名片早先化参数

  • 此间的参数并非兼顾的开始化参数, 请查阅初始化 SDK, 甚至别的章节的起头化参数
  • 初始化SDK
  • 多端登入发轫化参数
  • 客户关系初步化参数
  • 老铁关系初阶化参数
  • 客户名片开端化参数
  • 群组初步化参数
  • 会话早先化参数
  • 音信早先化参数
  • 系统通报初叶化参数
  • 联机到位
  • 一体化的初步化代码

亲自去做代码

var nim = NIM.getInstance({
onmyinfo: onMyInfo,
onupdatemyinfo: onUpdateMyInfo,
onusers: onUsers,
onupdateuser: onUpdateUser
});
function onMyInfo(user) {
console.log('收到我的名片', user);
data.myInfo = user;
updateMyInfoUI();
}
function onUpdateMyInfo(user) {
console.log('我的名片更新了', user);
data.myInfo = NIM.util.merge(data.myInfo, user);
updateMyInfoUI();
}
function updateMyInfoUI() {
// 刷新界面
}
function onUsers(users) {
console.log('收到用户名片列表', users);
data.users = nim.mergeUsers(data.users, users);
}
function onUpdateUser(user) {
console.log('用户名片更新了', user);
data.users = nim.mergeUsers(data.users, user);
}

参数解释

  • onmyinfo: 同步登陆顾客名片的回调, 会传入顾客名片
  • onupdatemyinfo: 当前报到客户在任何端改过自身的个人名片之后的回调, 会传入顾客名片
  • onusers: 同步基友客户名片的回调, 会传入客商著名影片数组
  • 此回调是增量回调, 能够调用nim.mergeUsers来合併数据
  • onupdateuser: 客户名片更新后的回调, 会传入客商名片,请参考顾客名片更新机会

预览图片质量

  • 只协理通过预览文件或发送文书消息得到的图纸 url, 只怕通过别的图片操作后取得的图样 url
  • 私下认可图片品质为100,开采者能够减低图片品质来省流量
var url = 'https://nim.nos.netease.com/MTAxMTAwMg==/bmltYV8xNDc5OTNfMTQ0MzE0NTgyNDI0M184YjFkYTMwMS02NjcxLTRiYjktYTUwZC04ZTVlZjZlNzZjMzA=';
var qualityUrl = nim.viewImageQuality({
url: url,
quality: 20
});
// 预览图片质量后的图片 url 如下
// qualityUrl === 'https://nim.nos.netease.com/MTAxMTAwMg==/bmltYV8xNDc5OTNfMTQ0MzE0NTgyNDI0M184YjFkYTMwMS02NjcxLTRiYjktYTUwZC04ZTVlZjZlNzZjMzA=?imageView&quality=20'
// 开发者在浏览器中打开上面的链接之后, 可以直接修改 url 里面的数字来观察不同的预览图片质量的结果

改善本地会话

  • 更新 id 对应的本地会话
  • 如果不扶助数据库, 算成功
  • 借使对应的对话不设有, 算成功, 再次来到 null
  • 那一个字段只会被更新到地面数据库, 不会被更新到服务器上
  • 当前只同意更新 localCustom
nim.updateLocalSession({
id: 'p2p-account',
localCustom: '{"key","value"}',
done: updateLocalSessionDone
});
function updateLocalSessionDone(error, obj) {
console.log(error);
console.log(obj);
console.log('更新本地会话' + (!error?'成功':'失败'));
}

获取群

  • 开采者能够调用此接口获取群资料
nim.getTeam({
teamId: 123,
done: getTeamDone
});
function getTeamDone(error, obj) {
console.log(error);
console.log(obj);
console.log('获取群' + (!error?'成功':'失败'));
}

郑重声明:本文版权归新匍京a奥门-最全网站手机版app官方下载所有,转载文章仅为传播更多信息之目的,如作者信息标记有误,请第一时间联系我们修改或删除,多谢。