【随便看看】十分钟用 FAAS 给天猫精灵增加自定义能力

本文涉及的产品
简介: ## 背景 - 虽然天猫精灵目前功能已很丰富,但还有些定制化高的服务无法满足,比如查询学校课表,考研信息,公交状态,特定网站状态等。不过天猫精灵提供了开放平台能力,使得我们可以轻松给天猫精灵添加这些自定义能力。 - 本文做个简单示例,和天猫精灵说小爱同学,天猫精灵回复"小爱同学,我是天猫精灵" 来展示一下如何通过天猫精灵调用我们的自定义服务。 - 查阅文档,可知要实现这个功能,关键有两步,一

背景

  • 虽然天猫精灵目前功能已很丰富,但还有些定制化高的服务无法满足,比如查询学校课表,考研信息,公交状态,特定网站状态等。不过天猫精灵提供了开放平台能力,使得我们可以轻松给天猫精灵添加这些自定义能力。
  • 本文做个简单示例,和天猫精灵说小爱同学,天猫精灵回复"小爱同学,我是天猫精灵" 来展示一下如何通过天猫精灵调用我们的自定义服务。
  • 查阅文档,可知要实现这个功能,关键有两步,一是让天猫精灵识别,二是搭建自定义服务进行回复

实现

注册技能

  • 天猫精灵接入还是比较简单的,注册完成开发者后,就直接在平台添加自定义技能就可以了。

1. 添加自定义技能『小爱同学』

2. 在侧边栏"意图" tab 中添加意图

  • 因为我们只做一个简单的呼唤,所以就用个简单的默认意图就好了,注意默认意图并不是兜底意图,而是当只说 调用词 时触发的意图
  • 如果有多种功能,可以使用例句来教会天猫精灵怎么区分不同意图,文档链接

3. 在侧边栏"回复逻辑"中配置回调,可以看到此处需要填写 webhook url,也就是我们实际自定义服务的地址.目前还没搭建,下面我们将用 faas 搭建

  • 需要注意的是这边有个校验文件,开放平台为了验证服务的有权性,会要检验服务根目录下有没有这个文件。我们先把文件下载下来,后续使用, 文档链接

服务搭建

  • 服务搭建的方式有很多,此处我们选择采用 aliyun 的 faas 服务, 也就是函数计算进行搭建。函数计算有个好处在于不用关心真实服务器,只需要编写自定义逻辑即可。而且关键每月还有100万次的免费调用额度,约等于不要钱 ? https://fc.console.aliyun.com
  • 函数计算为三层结构 1个服务 -> n个函数-> m个触发器。每个服务可以有多个函数;每个函数为一个工程,里面有一个入口函数;然后由触发器去调用这个函数, 常用的有 http 触发器,定时触发器等
  • 可见我们需要的就是创建一个服务,然后两个函数,一个用于应答天猫精灵,一个用于天猫精灵的验权。
  1. 新建一个服务,名字随意
  2. 新建两个函数,分别叫 xiaoai 和 auth ,对应的触发器名字分别为 xiaoai_http, auth_http,用于应答和校验

应答服务

  • 应答服务很简单,就是返回 "小爱同学,我是天猫精灵"
  • 因此我们只需要收到请求直接返回就好,代码如下, 复制到代码执行的在线编辑器中,点击保存即可
var getJsonBody = require('body/json');

exports.handler = (req, resp, context) => {
    getJsonBody(req, function (err, data) {
        if (!data || !data.utterance) {
            resp.send("post body wrong! " + data);
        }
        resp.setStatusCode(200);
        resp.setHeader('content-type', 'application/json');
        resp.send(JSON.stringify(
            {
                "returnCode": "0",
                "returnErrorSolution": "",
                "returnMessage": "",
                "returnValue": {
                    "reply": `小爱同学,我是天猫精灵`,
                    "resultType": "RESULT",
                    "executeCode": "SUCCESS",
                    "msgInfo": ""
                }
            }));
    });
}
  • 在下方的测试中,便可以输入上面的 body,测试一下结果
  • 至此,应答服务完成

校验服务

  • 校验服务就更简单了,就是模仿一个文件读取,返回文件内容即可.
  • 因此打开上面下载的校验文件,将文件内容替换到下面的 xxx 中, 粘贴到代码执行的编辑框中,点击保存即可。
exports.handler = (req, resp, context) => {
    resp.setHeader('content-type', 'text/plain');
    resp.send("xxx")
}
  • 在下方的测试验证处直接 get 便可看到返回 body 即为上面的 xxx

路径注册

  • 完成了上面两个服务后,虽然可以直接用各个函数的触发器对应的网址直接访问,但是由于验权文件必须要在根目录的 /aligenie/ 下,因此还需通过 自定义域名 来统一域名
  • 打开自定义域名,可以看到有一个默认域名,我们就直接编辑这个域名, 添加两个路径,一个为 /aligenie/aaa.txt, 将 aaa 替换为上面下载的验权文件的文件名, 一个为 /xiaoai/*

大功告成

  • 将天猫精灵 webhook 地址改成我们上面的自定义域名即可
  • 在测试验证便可进行测试了,打开真机测试则可在 taobao 账号绑定的天猫精灵上进行测试

Tips

  • 本文仅演示了简单的 faas 服务,因此采用了直接页面编辑的方式,对于复杂的业务逻辑,比如要安装依赖包,debug 的测试的,建议是用 aliyun 的 funcraft 提供了一种在本地可以测试服务和快速发布的方法。 不过需要注意的是其 template.yml 生成的配置一般不含日志部分,日志部分手工配置比较难写,建议通过导出功能,直接导出在界面上配置好的参数
  • 对于线上运行情况可以通过 函数计算 的日志查询进行查看, 首次配置需要开通下 aliyun 的日志服务。

参考资料

相关实践学习
基于函数计算一键部署掌上游戏机
本场景介绍如何使用阿里云计算服务命令快速搭建一个掌上游戏机。
建立 Serverless 思维
本课程包括: Serverless 应用引擎的概念, 为开发者带来的实际价值, 以及让您了解常见的 Serverless 架构模式
目录
相关文章
|
1月前
|
vr&ar 图形学
2D丨3D元宇宙游戏系统开发详细规则/需求步骤/逻辑方案/源码步骤
Developing a 2D/3D metaverse game system involves multiple aspects, including game design, graphics engines, virtual world construction, social interaction, and economic systems. The following is a summary of a development plan:
|
2月前
|
人工智能 语音技术 云计算
基于客户真实使用场景的云剪辑Timeline问题解答与代码实操
本文为阿里云智能媒体服务IMS「云端智能剪辑」实践指南第6期,从客户真实实践场景出发,分享一些Timeline小技巧(AI_TTS、主轨道、素材对齐),助力客户降低开发时间与成本。
135528 86
基于客户真实使用场景的云剪辑Timeline问题解答与代码实操
|
26天前
|
自然语言处理 iOS开发
海外短剧系统开发功能指南/案例设计/步骤方案/源码程序
The development of overseas short drama systems needs to consider the following main requirements
|
30天前
|
并行计算 Linux 异构计算
分享一款刚开源上线3天的音乐人声分离工具!无需联网!页面化操作!
分享一款刚开源上线3天的音乐人声分离工具!无需联网!页面化操作!
|
1月前
|
安全
哈希竞猜游戏系统开发玩法详情/功能步骤/需求设计/流程方案/源码程序
Developing a hash guessing game system can provide a fun gaming experience. The following are possible gameplay and rules for your reference:
|
1月前
|
安全 区块链
区块链游戏系统开发步骤需求丨功能逻辑丨规则玩法丨指南教程丨源码详细
Developing blockchain game systems has been a highly anticipated field in recent years. By combining blockchain technology and game mechanics, players can enjoy a brand new gaming experience and higher game credibility.
游戏对接广告看视频系统开发详细规则/方案逻辑/步骤逻辑/规则玩法/源码程序
Advertising location and display method: According to the characteristics of the game interface and scene, choose the appropriate advertising location and display method to ensure that the advertisement naturally integrates into the game and does not affect the player's game experience.
|
4月前
|
SQL 消息中间件 Java
想要流畅体验 TDengine 3.0 数据订阅功能?要点都在这里
在本文中,TDengine 资深研发将以 TDengine 3.0 为对象,为大家介绍数据订阅功能的正确打开方式,给到有需要的人作参考指南,避免走入应用误区。
156 0
|
7月前
|
存储 前端开发 安全
什么是盲盒游戏系统开发规则丨指南教程丨功能逻辑丨需求项目丨源码方案
确定盲盒游戏的目标受众、玩法要素和游戏规则。 - 确定游戏系统的核心功能,如盲盒的获取、开启、物品收集、交易等。 - 确定技术平台和开发语言,如移动端应用的开发是选择原生开发(如iOS的Swift或Android的Java/Kotlin)还是跨平台开发(如React Native或Flutter)。
|
8月前
|
安全
NFT卡牌游戏链游系统开发(开发方案)/详情规则/成熟技术/设计界面/案例项目/源码程序
NFT (Non Homogeneous Token) card chain game refers to a game based on blockchain technology where NFT is used as the card in the game. NFT is a unique and non interchangeable digital asset that can represent various virtual cards, props, or characters in the game.