API对接实战:外呼接口及通话记录推送
xsobi 2024-12-17 17:07 19 浏览
在白码低代码开发平台上对接七陌外呼接口,实现选择客户进行外呼,并保存通话记录的功能。
外呼接口实现
官方接口文档:http://developer.7moor.com/v2docs/dialout/
1、对接数据查询
向七陌商务索取到七陌用户中心账号密码,在查询页面查询到三个参数
let accountId = "T0********";//账户id
let apiSecret = "495b60****************5f0555af";//账户secret
let host = "https://openapis.7moor.com";//请求域名
查询页面:http://developer.7moor.com/data-query/
2、接口鉴权信息
- 时间戳
//时间
let date = new Date();
let YY = date.getFullYear();
let MM = (date.getMonth() + 1 < 10 ? '0' + (date.getMonth() + 1) : date.getMonth() + 1);
let DD = (date.getDate() + 1 <= 10 ? '0' + date.getDate() : date.getDate());
let hh = (date.getHours() + 1 <= 10 ? '0' + date.getHours() : date.getHours());
let mm = date.getMinutes() + 1 <= 10 ? '0' + date.getMinutes() : date.getMinutes();
let ss = date.getSeconds() + 1 <= 10 ? '0' + date.getSeconds() : date.getSeconds();
let time = YY + MM + DD + hh + mm + ss;
- 包头验证信息Authorization
//包头验证信息 Authorization的值为 Base64编码(账户Id +冒号+时间戳)
let buffer = $modules.lib.Buffer.from(accountId + ":" + time);
let authorization = buffer.toString("base64");
- 请求参数sig
//sig, 32位大写MD5加密 (帐号Id + 帐号APISecret +时间戳)
const crypto = $modules.crypto;
const hash = crypto.createHash('md5');
let sig = hash.update(accountId + apiSecret + time).digest('hex').toLocaleUpperCase();
3、外呼接口请求地址
//请求地址
let url = host + "/v20180426/call/dialout/" + accountId + "?sig=" + sig;
4、请求头部
//请求头部
let headers = {
"Content-Type": "application/json;charset=utf-8",
"Authorization": authorization,
}
5、请求体
相关参数参考官方文档:http://developer.7moor.com/v2docs/dialout/
//请求体
let data = {
"FromExten": $input.FromExten,
"Exten": $input.Exten,
"ExtenType": typeMap[$input.ExtenType],
"ActionID": $input.ActionID,
"DialoutStrVar": $input.DialoutStrVar,
};
为了方便用户端理解,extenType参数输入增加map
//ExtenType map
let typeMap = {
"手机": "Local",
"软电话": "sip",
"IP话机": "gateway",
}
6、发起外呼请求
//外呼
let call = await $modules.curl(url, {
method: "post",
dataType: "json",
headers,
data,
});
7、输出请求结果
//输出
//$output.sig = sig;
//$output.authorization = authorization;
$output.request = data;
$output.result = call.data;
$output.success = call.data.Succeed.toString();
$output.msg = call.data.Message;
坐席接听方式说明:外呼时强制坐席使用该接听方式进行外呼。Local为“手机”,”sip为“软电话”需登录企话宝,gateway为“语音网关”,需注册绑定IP话机。
- Sip方式外呼效果:
通话记录事件推送实现
官方接口文档:http://developer.7moor.com/event/
1、设置推送地址
添加一个webhook,设置路径。
将完整路径复制,与用户中心账户名一并发给七陌业务员,让对方配置该路径。
2、处理接收的信息
async function hook($req = request, $resp = response, $modules = modules) {
//返回字符串 200,告知七陌已成功接收
$resp.body = "200";
let json = {
query: $req.query,//接收的数据,get方式
body: $req.body,//接收的数据,post方式
timestamp: new Date().toString()
}
//保存接收的数据
$modules.data.saveData("60177fad283f87288d276269", {
"60177fc32f8b27288c6023dd": JSON.stringify(json)
})
}
接收到的数据:
相关推荐
- 5.5英寸触屏,搭载“安卓系统”的智能计算器评测:这设计挺脑洞
-
“计算器”可以说是我们日常生活中较为常用的一款电子产品,纵使手机上也有计算器功能,且足以替代实物计算器,但现在还是有很多人习惯用实物计算器,例如;做批发的店铺老板,计算器就放在店铺显眼位置,结账时顺手...
- Android之父晒新款手机,造型酷似遥控器
-
安迪·鲁宾大家可能并不陌生,鲁宾曾一手创建了安卓操作系统,被外界誉为“安卓之父”。2015年鲁宾又创立智能手机公司EssentialProductsInc,还获得亚马逊和腾讯的投资。在筹备两年后,...
- WP8.1的IE11为何不支持淘宝网触屏版?
-
IT之家(www.ithome.com):WP8.1的IE11为何不支持淘宝网触屏版?众所周知IE浏览器有自己的一个内核(简称IE内核),WP8.1系统的自带移动版IE11浏览器,但为什么iOS、An...
- 手机屏幕失灵乱跳乱点,屏幕时好时坏是怎么回事?
-
我们平时在使用手机的时候,如果我们的手机经常出现屏幕不受控制,手机屏幕会出现乱跳自己乱点的一些情况,这是什么问题呢?出现这种问题我们应该怎么去解决呢,今天我们九一手机维修就来跟大家说说这个问题该怎样去...
- 跨界表演有风险,百事手机 P1 众筹宣告失败
-
大家还记得曾经轰动一时的百事手机P1吗?这款10月份曝光、11月份众筹的手机在京东众筹失败,已经退款。想要喝着百事可乐玩着百事手机的网友,赶紧该干嘛干嘛去吧。据悉,百事可乐P1采用铝合金...
- “傀儡”病毒感染超10万台手机
-
本报讯(记者孙奇茹)手机在没人操作的情况下,竟然自己亮屏、执行一些动作。这不是闹鬼,而是手机中毒了。日前,猎豹移动安全实验室发出警报,全球首个伪造模拟用户操作的安卓病毒被截获,并被命名为“傀儡(Go...
- Android事件分发机制
-
事件分发机制Android事件分发是指在Android系统中,当用户触摸屏幕或执行其他操作时,系统如何将这些事件传递给正确的视图或组件进行处理的过程。Android事件分发遵循一种称为"事件分...
- Android让视图像玻璃一样破裂
-
AndroidUILibs之BrokenView1.说明BrokenView让视图产生玻璃破裂的效果。注意:该库只能在API14以上的设备上运行2.配置在模块的build.gradle上面添加...
- 车载大屏爽翻了?英国研究机构:大尺寸触摸屏比酒驾更危险
-
大屏不仅蔓延到手机,汽车也不例外,得益于更加直观的人机交互体验,车载触控大屏逐渐成为越来越多车企的主流选择。然而最新的一项研究证明——触控大屏比酒驾、毒驾更危险。日前,英国一项道路安全研究报告指出,当...
- 安卓系统被曝严重安全漏洞 恶意程序竟能秘密拍照或录制音视频
-
央视网消息:据今日俄罗斯网站20号报道,以色列一家知名网络安全公司宣称发现谷歌、三星等制造商生产的安卓手机,系统存在严重安全漏洞,黑客能够在未经手机机主许可的情况下,操控安卓手机秘密拍摄照片、录制视...
- 央视曝光:安卓系统曝漏洞!有人可能正在用你的手机...
-
近日,谷歌、三星等制造商生产的安卓手机,被曝出系统存在严重安全漏洞。黑客能够在未经手机机主许可的情况下,操控安卓手机秘密拍摄照片、录制音视频并上传。点击下方,先看视频↓↓↓视频来源:央视新闻利用漏洞!...
- 安卓系统曝漏洞!有人可能正在用你的手机秘密拍照
-
近日,谷歌、三星等制造商生产的安卓手机,被曝出系统存在严重安全漏洞。黑客能够在未经手机机主许可的情况下,操控安卓手机秘密拍摄照片、录制音视频并上传。利用漏洞“恶意应用程序”拍照、录音视频并上传据今日俄...
- 安卓用户注意了 你的爱机可能会面临新式恶意攻击
-
据外媒报道,最近,东京早稻田大学的三名学者称,现代Android智能手机容易受到一种名为“Tap'nGhost”的新型攻击,这种攻击可以使不存在的“手指”点击手机屏幕,以采取行动。“Tap'nGh...
- Android学习之Touch事件的处理
-
在移动开发过程当中,我们经常会遇到手势处理和事件触摸的情况,如果不了解整个事件的处理机制,对于开发的同学和码农是非常痛苦的,但是事件触摸的处理确实是一个非常复杂的过程,细讲起来,估计我都能讲迷糊,这里...
- 办公小技巧:制作模糊查询效果Excel下拉菜单
-
在Excel单元格中输入特定范围的内容时,一般会利用数据有效性生成下拉列表的方式进行,但如果源列表的内容太多(比方说有数百个),这时再通过下拉列表查找需要的值就很不方便了。如果采用智能感知的模糊查询下...
- 一周热门
- 最近发表
- 标签列表
-
- grid 设置 (58)
- 移位运算 (48)
- not specified (45)
- 导航栏 (58)
- context xml (46)
- scroll (43)
- dedecms模版 (53)
- c 视频教程下载 (33)
- listview排序 (33)
- characterencodingfilter (33)
- getmonth (34)
- label换行 (33)
- android studio 3 0 (34)
- html转js (35)
- 索引的作用 (33)
- checkedlistbox (34)
- xmlhttp (35)
- mysql更改密码 (34)
- 权限777 (33)
- htmlposition (33)
- 学校网站模板 (34)
- textarea换行 (34)
- 轮播 (34)
- asp net三层架构 (38)
- bash (34)