【Serverless版】企微群机器人开发

650 阅读5分钟

Dear,大家好,我是“前端小鑫同学”,😇长期从事前端开发,安卓开发,热衷技术,在编程路上越走越远~


背景介绍

  我们公司一直在用企业微信来做员工的沟通工具,不少群里面都有添加一下群聊机器人来做一下任务的提醒,那么做为群聊机器人的一个应用场景自然就是执行定义任务,如定时发送会议提醒,周报填写提醒等等,那往往我们就需要有一台不关机的个人PC或者云服务器来支持群聊机器人的长时间运行(Windows系统中的广告可以在任务计划程序中找到并关闭),个人自用的PC电脑其实不太适合长时间的运行(Windows谁用谁知道,没多久就会变卡),云服务器也需要花费不少的费用,所以我们就需要有一个Serverless的平台来解决这个问题(免费的额度也够用了,绝对超值)。

案例介绍

  我们通过采用腾讯云平台中Serverless产品下的云函数来做服务支撑完成一个企业微信群机器人定时每天早8点发送当天天气情况的一个案例,实现此案例你需要做如下准备工作:

  1. 注册腾讯云平台:cloud.tencent.com/
  2. 注册企业微信平台:work.weixin.qq.com/
  3. 使用VSCodeIDE并安装插件《Tencent Serverless Toolkit for VS Code》

企微群机器人如何发送消息:

  实现企微群机器人消息发送主要是通过向分配给机器人的Webhook地址发送请求来完成的,如果你是群主当你拉机器人进群后查看机器人信息就可以得到机器人对应的Webhook地址了,特别特别要注意:一定要保护好机器人的webhook地址,避免泄漏!不要分享到github、博客等可被公开查阅的地方,否则坏人就可以用你的机器人来发垃圾消息了。。

image.png

项目环境准备:

  1. 初始化项目:npm init -y
  2. 初始化Ts配置:tsc --init
  3. 安装axios来实现请求数据:yarn add axios

模块划分:

  1. model.ts:消息模型(对应API文档),创建消息模型函数;
/**
 * 消息类型
 */
export enum MsgType {
    /** markdown类型 */
    markdown = "markdown",
}

/**
 * markdow消息模型
 */
export type MarkdownContext = {
    /** markdown内容,最长不超过4096个字节,必须是utf8编码 */
    content: string,
}

/**
 * 消息模型基类
 */
export type Message<T> = {
    msgtype: MsgType & T,
    [type: string]: T,
}

/**
 * 创建待发送消息
 * @param type 
 * @param content 
 * @returns 
 */
function createMessage<T>(type: MsgType, content: T) {
    return {
        msgtype: type,
        [type]: content,
    } as Message<T>;
}

/**
 * 创建markdown类型的消息
 * @param content 
 * @returns 
 */
export function createFileMessage(content: FileContext) {
    return createMessage<FileContext>(MsgType.file, content);
}
  1. notice.ts:发送各类型通知函数;
import axios from 'axios';
import { createFileMessage, createImageMessage, createMarkdownMessage, createNewsMessage, createTextMessage, FileContext, ImageContext, MarkdownContext, Message, NewsContext, TextContext } from './model';

function request<T>(webhook: string, message: Message<T>) {
    if (!webhook) throw new Error("请设置正确机器人的webhook地址");
    axios.post(webhook, message).then(res => {
        const { status, data } = res;
        if (status === 200 && data) {
            console.log(data.errcode === 0 ? "发送成功" : data.errmsg);
        }
    }).catch(err => {
        console.log(err);
    })
}

/** 发起Markdown类型消息通知 */
export const requestMDNotice = (webhook: string, mdContext: MarkdownContext) => request<MarkdownContext>(webhook, createMarkdownMessage(mdContext));
  1. index.ts:入口执行天气信息获取和调用发送Markdown类型消息。
import { requestMDNotice } from "./notice";
import axios from 'axios';
import { AMAP_WEATHER_API, ENTERPRISE_WECHAT_ROBOT_WEB_HOOK } from "./config";
axios.get(AMAP_WEATHER_API).then(res => {
    const { status, data } = res;
    if (status === 200 && data) {
        if (data.status === '1' && data.infocode === '10000') {
            let message = ''
            data.lives.forEach((live: any) => {
                message += `
##### 今天${live.province}${live.city}天气情况
* 天气: ${live.weather}
* 气温: ${live.temperature} 摄氏度
* 风向: ${live.winddirection}
* 风力: ${live.windpower} 级
* 湿度: ${live.humidity}
* 数据发布的时间: ${live.reporttime}\n
                `
            });
            // 向企业微信群发送MD格式的通知
            requestMDNotice(ENTERPRISE_WECHAT_ROBOT_WEB_HOOK, {
                content: message
            })
        }
    }
})
  1. 高德天气查询API和机器人Webhook地址配置:
// 企业微信群机器人webhook地址
export const  ENTERPRISE_WECHAT_ROBOT_WEB_HOOK = "《请填写你自己机器人的webhook地址》";
// 高德天气查询API,城市地址在高德开发文档查询
export const  AMAP_WEATHER_API = "《请填写你自己申请天气查询地址》"

运行调试:

  • 通过ts-node直接执行我们的入口文件:ts-node .\src\index.ts,输出发送成功后就可以在企微群看到最新的消息了。

image.png

云函数执行定时发送天气情况任务:

安装并认识腾讯云函数开发插件《Tencent Serverless Toolkit for VS Code》:

  • 拉取云端的云函数列表,并触发云函数。​
  • 在本地快速创建云函数项目。
  • 使用模拟的 COS、CMQ、CKafka、API 网关等触发器事件来触发函数运行。
  • 上传函数代码到云端,更新函数配置。
  • 在云端运行、调试函数代码。

初始化并编写云函数:

  1. 通过VSCode打开一个空的文件夹;
  2. 认准腾讯云Logoimage.png打开插件,第一次使用需要绑定用户凭证,绑定地域;
  3. 在本地函数窗口创建函数=>选择Nodejs版本=>填写函数名,得到如下项目基础模板:

image.png

  1. 将我们ts编写的机器人发送通知的代码编译为js版本,直接运行tsc后将得到的内容覆盖云函数的src目录(index.js文件需要copy内容到main_handler函数中);
  2. 因为我们有实用axios模块来发送请求,所以云函数项目中也需要安装:进入云函数项目的**src**目录执行:npm init -y && yarn add axios

上传并在云端部署调试

  • 云函数的开发到此就完成了,通过本地函数窗口执行上传云函数(node_module如果内容过多建议先在控制台进行安装),并在控制台执行部署和测试;

image.png

配置触发管理(定时任务)

  • 在触发管理菜单中创建新的触发器来执行定时任务Cron表达式通过crontab.guru/every-day查询调整,提交后即可完成,期待明早的消息提醒吧。

image.pngimage.png

结语:

  本篇涉及到的内容点有:高德开发平台天气查询API使用,腾讯云Serverless云函数使用,企微群机器人配置及API,共同完成了今天的实战案例,你还有什么有趣的应用场景呢?说说看?😂


欢迎关注我的公众号“前端小鑫同学”,原创技术文章第一时间推送。