简介
Serverless 是一种云计算服务模式,用户无需关心底层基础设施的维护,只需关注业务逻辑的实现,飞书是一款企业级即时通讯和协作平台,提供了丰富的 API 接口,方便开发者进行二次开发,本文将介绍如何使用 Serverless 飞书打造个性化消息提醒系统,包括系统架构设计、技术选型、代码实现等方面。
系统架构设计
1、前端:使用 React 或 Vue 等框架搭建 Web 应用,通过调用飞书 API 实现消息的发送和接收。
2、后端:采用 Serverless 架构,可以使用云函数(如 AWS Lambda、阿里云函数计算等)或无服务器数据库(如腾讯云 CDB、阿里云 RDS 等)作为计算资源。
3、存储:使用云存储服务(如阿里云 OSS、腾讯云 COS 等)存储用户的基本信息和消息记录。
4、通知中心:使用第三方通知服务(如极光推送、友盟推送等)实现跨平台的消息推送。
技术选型
1、前端框架:React 或 Vue,根据项目需求选择合适的框架。
2、后端框架:Serverless Framework,支持多种云服务商的函数计算服务。
3、API 调用:使用飞书官方提供的 JavaScript SDK,遵循官方文档规范进行开发。
4、云存储:阿里云 OSS,具有高可用、低延迟、大容量的特点。
5、通知服务:极光推送,支持 iOS、Android、H5、Web等多个平台的消息推送。
代码实现
1、前端实现:
import * as fk from '@alifd/plugin-sdk'; // 初始化飞书 SDK const app = fk.createApp({ appKey: 'your_app_key', masterSecret: 'your_master_secret', }); // 获取飞书用户 ID async function getUserId() { const res = await app.user.getUserInfo(); return res.userId; } // 发送消息到指定用户 async function sendMessageToUser(userId, content) { const message = { userIds: [userId], content: content, }; const res = await app.message.send(message); return res; }
2、后端实现:
// 导入依赖库和组件 const serverless = require('serverless-http'); const axios = require('axios'); const ossClient = new AWS.S3({ accessKeyId: 'your_access_key', secretAccessKey: 'your_secret_key' }); const push = require('@alifd/push'); const PushManager = push.PushManager; const Message = push.models.Message; const Target = push.models.Target; const Payload = push.models.Payload; const config = {}; // 根据实际情况配置推送服务的相关参数,如别名、模板ID等 const targetType = 'all'; // all、tag、alias、uid四种类型之一,根据实际需求选择 const targetValue = ''; // 标签值、别名值或用户 ID,根据实际需求设置 const title = ''; // 通知栏标题,可选参数,默认为应用名称或消息内容前缀 const body = ''; // 通知栏内容,可选参数,默认为消息内容本身 const contentAvailable = false; // 是否启用后台推流功能,可选参数,默认为 false,不启用时需设置 autoplay=true 在 AndroidManifest.xml 中配置相应字段以开启自动播放功能 const notificationChannelId = ''; // Android 需要单独设置的通知渠道 ID,可选参数,默认为空字符串,不设置时仅在 iOS 上生效,需在 iOSManifest.xml 中配置相应的字段以控制通知展示方式和行为 const badge = ''; // iOS 需要单独设置的应用图标上显示的数字角标数,可选参数,默认为空字符串,不设置时仅在 iOS 上生效,需在 iOSManifest.xml 中配置相应的字段以控制角标显示数量和样式 const sound = ''; // iOS 需要单独设置的应用启动时播放的声音文件名,可选参数,默认为空字符串,不设置时仅在 iOS 上生效,需在 iOSManifest.xml 中配置相应的字段以控制声音文件名及音量大小等属性值 const openUrlActions = []; // 点击通知后需要打开的 URL,可选参数,默认为空数组,不设置时仅在 Android 上生效,需在 AndroidManifest.xml 中配置相应的字段以控制点击通知后的跳转行为和效果 const interactiveNotificationActions = []; // 点击通知后需要执行的操作列表,可选参数,默认为空数组,不设置时仅在 Android 上生效,需在 AndroidManifest.xml 中配置相应的字段以控制点击通知后的交互行为和效果 const data = {}; // 需要传递给应用程序的数据对象,可选参数,默认为空对象,不设置时仅在 Android 上生效,需在 AndroidManifest.xml 中配置相应的字段以传递数据给应用程序处理层进行后续操作或验证等场景的需求处理 let payload = {}; // 最终构建的推送消息负载体对象,包含多个子对象用于描述推送消息的各种属性值和格式信息等细节问题,具体可参考飞书官方文档说明或示例代码中的注释说明部分即可快速掌握其用法和技巧要点,payload = Object.assign(payload, ...data); // 将自定义数据对象中的属性值复制到负载体对象中去,确保所有需要传递的数据都能正确地被传输到目标设备上并得到有效处理,payload = Object.assign(payload, ...interactiveNotificationActions); // 将交互式操作所需的额外属性值也加入到负载体对象中去,payload['notification']['title'] = title || content || '自定义消息标题'; // 根据实际需求设置通知栏标题或消息内容前缀,payload['notification']['body'] = body || content || '自定义消息内容'; // 根据实际需求设置通知栏内容或消息内容本身,payload['notification']['contentAvailable'] = contentAvailable; // 根据实际需求设置是否启用后台推流功能,payload['notification']['badge'] = badge || ''; // 根据实际需求设置应用图标上显示的数字角标数,payload['notification']['sound'] = sound || ''; // 根据实际需求设置应用启动时播放的声音文件名,payload['notification']['openUrlActions'] = openUrlActions || []; // 根据实际需求设置点击通知后需要打开的 URL,payload['notification']['interactiveNotificationActions'] = interactiveNotificationActions || []; // 根据实际需求设置点击通知后需要执行的操作列表,payload['notification']['targetIdentifier'] = targetValue || ''; // 根据实际需求设置目标设备的标识符(标签值、别名值或用户 ID),payload['notification']['targetType'] = targetType || 'all'; // 根据实际需求设置目标设备的类型(all、tag、alias、uid四种类型之一),config['region'] = 'ap-guangzhou'; // 根据实际情况配置推送服务的地域属性值(如华南区、华东区等),config['project'] = 'your_project_id'; // 根据实际情况配置推送服务的项目管理编号,config['appkey'] = 'your_appkey'; // 根据实际情况配置推送服务的 App Key,config['secretKey'] = 'your_secret_key'; // 根据实际情况配置推送服务的 Secret Key,PushManager.initWithConfig(config); // 根据上述配置项初始化推送管理器实例对象,PushManager.subscribe(targetValue || '', (err) => err && console.error('订阅失败' + err)); // 根据目标设备标识符和相关配置项创建并启动一次推送订阅请求(如果已存在则会更新当前订阅状态),成功返回 true 否则返回 false,pushManagerPromiseResolved = PushManager.promiseResolved; // 为便于调试和测试可以在此处添加一些日志输出语句或其他辅助工具来帮助我们更好地了解推送订阅请求的状态和结果情况,pushManagerPromiseRejected = PushManager.promiseRejected; // 为便于调试和测试可以在此处添加一些日志输出语句或其他辅助工具来帮助我们更好地了解推送订阅请求的状态和结果情况,pushManagerPromisePending = PushManager.promisePending; // 为便于调试和测试可以在此处添加一些日志输出语句或其他辅助工具来帮助我们更好地了解推送订阅请求的状态和结果情况,pushManagerStateChangeCallback = function (state) {}; // 当推送管理器状态发生变化时的回调函数(如成功订阅、取消订阅等),可根据实际需求进行相应的处理逻辑,pushManagerErrorCallback = function (error) => console.error('推送管理器错误' + error); // 当推送管理器发生错误时的回调函数(如网络异常、权限不足等),可根据实际需求进行相应的处理逻辑,pushManagerOpenNotificationCallback = function (event) {}; // 当收到新的通知时触发的回调函数(如用户点击了通知栏上的按钮或链接等),可根据实际需求进行相应的处理逻辑,pushManagerCloseNotificationCallback = function (event) {}; // 当收到关闭通知时触发的回调函数(如用户手动关闭了通知栏上的按钮或链接等),可根据实际需求进行相应的
最新评论
本站CDN与莫名CDN同款、亚太CDN、速度还不错,值得推荐。
感谢推荐我们公司产品、有什么活动会第一时间公布!
我在用这类站群服务器、还可以. 用很多年了。