DAY4 基于 OpenClaw + 飞书开放平台实现 AI 新闻推送机器人

DAY4 基于 OpenClaw + 飞书开放平台实现 AI 新闻推送机器人

DAY4 基于 OpenClaw + 飞书开放平台实现 AI 新闻推送机器人

目录

DAY4 基于 OpenClaw + 飞书开放平台实现 AI 新闻推送机器人

前  言

1 环境准备

1.1 华为云开发环境

1.2 ModelArts 代金券与模型服务

1.3 启动 OpenClaw 网关

2 飞书开放平台配置

2.1 创建企业自建应用

2.2 添加机器人能力

2.3 配置应用权限

2.4 发布应用版本

3 OpenClaw 与飞书集成

3.1 配置 OpenClaw 的飞书凭证

3.2 创建 Python 项目与长连接

3.3 配置飞书事件订阅

4 功能测试

5 收尾工作

6 总结与扩展


前  言

        在日常工作中,我们常常需要关注科技领域的最新动态,但手动浏览多个网站效率低下。本文将详细介绍如何利用 OpenClaw(一个开源的 AI 自动化框架)结合 飞书开放平台,快速搭建一个 AI 新闻推送机器人。该机器人可以自动访问指定网站,抓取科技新闻摘要,并通过飞书机器人实时推送给用户,让你不错过任何重要资讯。

1 环境准备

1.1 华为云开发环境

我们选择华为云开发者空间作为开发环境,它提供了预装的开发工具和依赖,能极大简化配置流程。

  1. 登录华为云,进入 开发者空间,创建一个新的云开发环境(在华为开发者空间中,点击菜单开发平台 —— 云开发环境 —— 开发桌面,创建云开发环境 —— 开发桌面。)。
  2. 进入环境后,桌面会预装 CodeArts IDE for PythonGitCode 等工具,我们后续将使用这些工具进行开发。

创建完成后,操作开发桌面开机,然后进入远程桌面。

1.2 ModelArts 代金券与模型服务

为了使用 OpenClaw 的 AI 能力,我们需要先开通 ModelArts 的模型服务:

  1. 在华为云控制台,进入 ModelArts > 在线推理
  2. 在 “非计划权益” 中领取 ModelArts 代金券(如截图所示,本次领取了 7 元代金券)。
  3. 点击 预置服务,选择 DeepSeek-V3.2 等模型,勾选 “我已阅读并同意”,然后点击 一键开通

开通成功后,在 “调用说明” 中获取 API 地址模型参数,并点击 “API Key 管理” 创建一个新的 API Key。

⚠️ 注意:API Key 只会显示一次,请务必复制并妥善保存,后续配置 OpenClaw 时会用到。
⚠️ 注意:API Key 只会显示一次,请务必复制并妥善保存,后续配置 OpenClaw 时会用到。

1.3 启动 OpenClaw 网关

  1. 在桌面双击运行 Moltbot(OpenClaw 的启动器)。
  2. 在弹出的终端中,输入之前创建的 API Key,然后回车。
  3. 系统会自动在后台启动 OpenClaw 网关,并在浏览器中打开控制面板(http://127.0.0.1:18789)。
  4. 在控制面板的 “Chat” 页面,你可以发送消息测试 OpenClaw 是否正常工作,例如:“请向我介绍下你自己?”。

2 飞书开放平台配置

首先,可以在华为云开发环境终端中安装飞书插件,实现OpenClaw与飞书的配置链接。

输入以下命令:

openclaw plugins install @m1heng-clawd/feishu

2.1 创建企业自建应用

  1. 访问 飞书开放平台,登录后点击 创建企业自建应用
  2. 填写应用名称(如 OpenClaw_test)和描述,选择图标后点击 创建

2.2 添加机器人能力

  1. 在应用左侧菜单,进入 应用能力 > 添加应用能力
  2. 选择 机器人 能力,点击 “添加”。

2.3 配置应用权限

为了让机器人能够接收和发送消息,我们需要配置相应的权限:

1. 进入 开发配置 > 权限管理

2. 点击 批量导入 / 导出权限,将以下 JSON 粘贴到输入框中:

{ "scopes": { "tenant": [ "contact:contact.base:readonly", "contact:user.base:readonly", "im:message", "im:message.group_at_msg:readonly", "im:message.p2p_msg:readonly", "im:message:send_as_bot", "im:resource" ], "user": [] } }

3. 点击 下一步,确认新增权限,然后点击 申请开通

4. 在弹出的 “应用身份权限可访问的数据范围” 窗口中,点击 确认

2.4 发布应用版本

1. 点击顶部创建版本,进入 应用发布 > 版本管理与发布

2. 进入 创建版本 界面,填写版本号(如 1.0.0)和更新说明,移动端和桌面端的默认能力都选择 “机器人”。

3. 点击 保存,然后 确认发布。发布成功后,应用状态会变为 “已启用”。

4. 进入 基础信息 > 凭证与基础信息,复制 App IDApp Secret,后续配置 OpenClaw 时会用到。

3 OpenClaw 与飞书集成

3.1 配置 OpenClaw 的飞书凭证

1. 在华为云环境的终端中,执行以下命令,将飞书的 App ID 和 App Secret 配置到 OpenClaw 中:

openclaw config set channels.feishu.appId "YOUR_APP_ID" openclaw config set channels.feishu.appSecret "YOUR_APP_SECRET"

2. 重启 OpenClaw 网关使配置生效:

openclaw gateway restart

3.2 创建 Python 项目与长连接

为了让飞书能实时接收 OpenClaw 的消息,我们需要建立一个长连接:

1. 打开桌面的 CodeArts IDE for Python,点击 新建工程,选择 Python,命名为 openClaw_test

2. 打开 IDE 底部的 “终端”,激活虚拟环境并安装飞书 Python SDK:

pip install lark-oapi -U

3. 验证安装:

pip show lark-oapi

4. main.py 文件中的代码替换为飞书官方提供的长连接示例代码,并将其中的 YOUR_APP_IDYOUR_APP_SECRET 替换为我们之前复制的值。

import lark_oapi as lark ## P2ImMessageReceiveV1 为接收消息 v2.0;CustomizedEvent 内的 message 为接收消息 v1.0。 def do_p2_im_message_receive_v1(data: lark.im.v1.P2ImMessageReceiveV1) -> None: print(f'[ do_p2_im_message_receive_v1 access ], data: {lark.JSON.marshal(data, indent=4)}') def do_message_event(data: lark.CustomizedEvent) -> None: print(f'[ do_customized_event access ], type: message, data: {lark.JSON.marshal(data, indent=4)}') event_handler = lark.EventDispatcherHandler.builder("", "") \ .register_p2_im_message_receive_v1(do_p2_im_message_receive_v1) \ .register_p1_customized_event("这里填入你要自定义订阅的 event 的 key,例如 out_approval", do_message_event) \ .build() def main(): cli = lark.ws.Client("YOUR_APP_ID", "YOUR_APP_SECRET", event_handler=event_handler, log_level=lark.LogLevel.DEBUG) cli.start() if __name__ == "__main__": main()

5. 点击右上角的 “运行” 按钮,启动长连接。控制台显示 connected to wss://... 即表示连接成功。

⚠️ 注意:长连接程序必须保持运行,否则飞书无法接收事件推送。

3.3 配置飞书事件订阅

1. 回到飞书开放平台,进入 开发配置 > 事件与回调

2. 在 “事件配置” 中,订阅方式选择 使用长连接接收事件,点击 保存

3. 点击 添加事件,在 “应用身份订阅” 下找到 “消息与群组”,勾选 接收消息 v2.0,然后点击 “确认添加”。

4. 再次进入 版本管理与发布,创建新版本(如 2.0.0)并发布,使事件订阅配置生效。

4 功能测试

一切配置就绪后,我们来测试新闻推送功能:

1. 打开飞书客户端,找到我们创建的机器人 OpenClaw_test

2. 发送指令:@OpenClaw_test 去访问以下两个网站 (https://www.leikeji.com/)、(https://tech.gmw.cn),有任何关于"科技"领域的新闻,立刻把最新的摘要推送给我。

3. 稍等片刻,机器人就会自动抓取新闻并推送回来,效果如下:

发送后可同时在华为云开发者空间OpenClaw客户端查看到返回信息。

5 收尾工作

测试完成后,你可以通过以下命令停止 OpenClaw 网关服务:

openclaw gateway stop

6 总结与扩展

        通过本文的实践,我们成功搭建了一个基于 OpenClaw 和飞书的 AI 新闻推送机器人。这个项目不仅展示了如何将 AI 自动化能力与企业 IM 工具无缝集成,也为我们提供了一个可扩展的框架。

Read more

Flutter for OpenHarmony:stream_transform 响应式编程的瑞士军刀(Dart Stream 扩展操作符) 深度解析与鸿蒙适配指南

Flutter for OpenHarmony:stream_transform 响应式编程的瑞士军刀(Dart Stream 扩展操作符) 深度解析与鸿蒙适配指南

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.ZEEKLOG.net 前言 Dart 的 Stream 是处理一步事件流的基石(类似于 RxJava 或 RxJS)。 虽然原生 SDK 提供了一些可以转换 Stream 的方法(如 map, where),但在处理复杂交互时(如:防抖、节流、合并流、自动关闭流)依然显得捉襟见肘。 stream_transform 是 Dart 官方维护的一个 Stream 操作符扩展库。它补全了 Stream API 中缺失的高级功能,让你在不引入庞大的 rxdart 的情况下,也能轻松应对复杂的异步流处理。 对于 OpenHarmony 开发者,UI 交互(点击、

By Ne0inhk
鸿蒙金融理财全栈项目——生态合作与用户运营优化

鸿蒙金融理财全栈项目——生态合作与用户运营优化

《鸿蒙APP开发从入门到精通》第27篇:鸿蒙金融理财全栈项目——生态合作与用户运营优化 🚀🤝📊 内容承接与核心价值 这是《鸿蒙APP开发从入门到精通》的第27篇——生态合作与用户运营优化篇,100%承接第26篇的安全合规与用户体验优化架构,并基于金融场景的生态合作与用户运营优化要求,设计并实现鸿蒙金融理财全栈项目的生态合作与用户运营优化功能。 学习目标: * 掌握鸿蒙金融理财项目的生态合作优化设计与实现; * 实现生态合作数据接入、生态合作接口对接、生态合作数据共享; * 理解用户运营优化在金融场景的核心设计与实现; * 实现用户分群优化、用户画像优化、用户留存优化; * 掌握生态合作与用户运营的协同优化策略; * 优化金融理财项目的用户体验与生态合作效果。 学习重点: * 鸿蒙金融理财项目的生态合作优化设计原则; * 用户运营优化在金融场景的应用; * 生态合作与用户运营的协同优化策略。 一、 生态合作优化基础 🎯 1.1 生态合作优化定义 生态合作优化是指对金融理财项目的生态合作进行优化,提升应用的生态合作效果,主要包括以下方面:

By Ne0inhk

OpenClaw 实战 #02-1:新手一把过(原Clawdbot )保姆级安装教程-Mac版

本文是上一篇《OpenClaw 是什么》的实操篇。 如果你已经了解 OpenClaw 的定位,这一篇只做一件事: 带你一步步把 OpenClaw在本地跑起来,并通过 Web UI 正常使用。 为了尽量降低上手门槛,本文 不配置任何聊天平台(Slack / WhatsApp 等), 所有操作都在 本地终端 + 浏览器 Web UI 中完成。 🧰 一、安装前准备 在开始之前,请先确认你的环境。 💻 支持的操作系统 * macOS(Intel / Apple Silicon) * Windows 10 / Windows 11(64 位)👉 Windows 安装 请根据你的系统,阅读对应的安装部分即可, 后续配置与使用步骤完全一致。 🎯 完成本文后你将得到什么? 完成本文所有步骤后,你将可以: * 在本地成功运行

By Ne0inhk
Flutter 组件 dart_chromecast 的鸿蒙化适配实战 - 驾驭极致多屏交互大坝、实现 OpenHarmony 分布式端高性能投屏控制、设备发现与工业级多媒体协同核方案

Flutter 组件 dart_chromecast 的鸿蒙化适配实战 - 驾驭极致多屏交互大坝、实现 OpenHarmony 分布式端高性能投屏控制、设备发现与工业级多媒体协同核方案

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.ZEEKLOG.net Flutter 组件 dart_chromecast 的鸿蒙化适配实战 - 驾驭极致多屏交互大坝、实现 OpenHarmony 分布式端高性能投屏控制、设备发现与工业级多媒体协同核方案 前言 在鸿蒙(OpenHarmony)生态的分布式全场景交互、智慧屏协同或者是对跨设备媒体流转有极其严苛要求的 0308 批次影音娱乐应用中。“跨终端的设备发现速度与指令下发的极速响应维度”是衡量整个系统多设备协同能力的最终质量门禁。面对包含数十台局域网内的智能终端、动态变化的 mDNS 宣告报文、甚至是由于网络抖动产生的 0308 批次 MDNS 发现波次。如果仅仅依靠简单的“硬编码 IP 连接”或者是干瘪的 HTTP 轮询。不仅会导致在处理多设备投屏时让系统如同在逻辑废墟中盲人摸象。更会因为协议握手耗时过长,令用户在多屏切换时瞬间陷入卡顿甚至掉线的盲区。 我们需要一种“逻辑自动发现、协议深度对齐”的分布式资产流转艺术。 dart_chromecast

By Ne0inhk