diff --git a/docs/advanced/example/integrate-qingyunke-chatbot.md b/docs/advanced/example/integrate-qingyunke-chatbot.md index b59d92e6..a502e136 100644 --- a/docs/advanced/example/integrate-qingyunke-chatbot.md +++ b/docs/advanced/example/integrate-qingyunke-chatbot.md @@ -2,6 +2,10 @@ 作为一个群聊机器人,懂得聊天会让机器人增色不少,在大数据和 AI 热潮下,不少厂商都研发了自己的智能聊天 API,例如图灵机器人、腾讯智能闲聊等,大厂开发的 API 自然有着他人无可比拟的健壮性和可靠性,但是随之而来不菲的价格显然并不适合大众开发者。这时候一个免费、可用的智能聊天 API 便非常重要了,其中,青云客是少有的完全免费、无需注册的智能聊天 API,提供了包括智能聊天、歌词、天气查询、笑话等多种有用功能,且接入简单,非常适合新手开发者尝试。 +## 结果演示 +![圖片](https://user-images.githubusercontent.com/31698606/158875192-108698a3-b54e-4fc0-889a-0829ca328b13.png) + + ## 阅读接入指南 不管接入何种服务,阅读接入指南永远都是最优先、最重要的一步,所幸青云客的接入指南十分简单,简单来说归纳为以下: @@ -29,32 +33,29 @@ public function chat() { // 替换掉机器人前缀,并获取消息内容 - $msg = ctx()->getMessage(); - $msg = substr_replace($msg, ' ', 3, -strlen($msg)); - ctx()->setMessage($msg); - $msg = ctx()->getFullArg('怎么了?'); - - // 确认没有其他同名命令 - if (MessageUtil::matchCommand($msg, ctx()->getData())->status === false) { - Console::info('正在获取智能聊天回复:' . $msg); - // 请求 API 获取回复 - $raw_data = file_get_contents('https://api.qingyunke.com/api.php?key=free&appid=0&msg=' . urlencode($msg)); - try { - $data = json_decode($raw_data, true, 512, JSON_THROW_ON_ERROR); - } catch (\Exception $e) { - $data = ['content' => '机器人解析异常,请稍后再试']; - Console::warning('无法获取智能聊天回复:' . $e->getMessage()); - } - if ($data['result'] !== 0) { - $data = ['content' => '机器人服务异常,请稍后再试']; - Console::warning('无法获取智能聊天回复:' . $raw_data); - } - Console::info('获取智能聊天回复完成:' . $data['content']); - // 将 {br} 替换为换行 - $data['content'] = strtr($data['content'], ['{br}' => "\n"]); - return $data['content']; + $msg = $this->getContext()->getMessage(); + $msg = str_replace('机器人', '', $msg); + if (empty(trim($msg))) { + $msg = $this->getContext()->getFullArg('怎么了?'); } - return true; + + Console::info('正在获取智能聊天回复:' . $msg); + // 请求 API 获取回复 + $raw_data = file_get_contents('https://api.qingyunke.com/api.php?key=free&appid=0&msg=' . urlencode($msg)); + try { + $data = json_decode($raw_data, true, 512, JSON_THROW_ON_ERROR); + } catch (\Exception $e) { + $data = ['content' => '机器人解析异常,请稍后再试']; + Console::warning('无法获取智能聊天回复:' . $e->getMessage()); + } + if ($data['result'] !== 0) { + $data = ['content' => '机器人服务异常,请稍后再试']; + Console::warning('无法获取智能聊天回复:' . $raw_data); + } + Console::info('获取智能聊天回复完成:' . $data['content']); + // 将 {br} 替换为换行 + $data['content'] = strtr($data['content'], ['{br}' => "\n"]); + return $data['content']; } ``` @@ -71,12 +72,12 @@ public function chat() public function changeAt(): bool { // 判断此条消息是否 AT 了机器人 - if (MessageUtil::isAtMe(ctx()->getMessage(), ctx()->getRobotId())) { + if (MessageUtil::isAtMe($this->getContext()->getMessage(), $this->bot->getSelfId())) { // 将 AT 本身从消息中去掉 - $msg = str_replace(CQ::at($this->bot->getSelfId()), '', ctx()->getMessage()); - ctx()->setMessage($msg); + $msg = str_replace(CQ::at($this->bot->getSelfId()), '', $this->getContext()->getMessage()); + $this->getContext()->setMessage('机器人' . trim($msg)); // 调用智能聊天 - ctx()->reply($this->chat()); + $this->getContext()->reply($this->chat()); return false; } return true;