2020-11-10 23:16:55 +08:00
|
|
|
|
# 介绍
|
2020-11-23 01:47:37 +08:00
|
|
|
|
|
2021-02-20 16:57:19 +08:00
|
|
|
|
!!! tip "提示"
|
2021-09-11 11:59:02 +08:00
|
|
|
|
|
2021-02-20 16:57:19 +08:00
|
|
|
|
编写文档需要较大精力,你也可以参与到本文档的建设中来,比如找错字,增加或更正内容,每页文档可直接点击右上方铅笔图标直接跳转至 GitHub 进行编辑,编辑后自动 Fork 并生成 Pull Request,以此来贡献此文档!
|
|
|
|
|
|
|
2021-03-02 13:40:21 +08:00
|
|
|
|
炸毛框架使用 PHP 编写,采用 Swoole 扩展为基础,主要面向 API 服务,聊天机器人(OneBot 标准的机器人对接),包含 WebSocket、HTTP 等监听和请求库,用户代码采用模块化处理,使用注解可以方便地编写各类功能。
|
2021-02-20 16:57:19 +08:00
|
|
|
|
|
2021-09-01 14:14:00 +08:00
|
|
|
|
框架主要用途为 HTTP/WebSocket 服务器,机器人搭建框架。尤其对于聊天机器人消息处理较为方便和全面,提供了众多会话机制和内部调用机制,可以以各种方式设计你自己的模块。
|
2020-11-10 23:16:55 +08:00
|
|
|
|
|
2021-03-02 13:40:21 +08:00
|
|
|
|
此外,QQ 机器人方面此框架基于 OneBot 标准的反向 WebSocket 连接,比传统 HTTP 通信更快。
|
2020-11-22 19:18:23 +08:00
|
|
|
|
|
|
|
|
|
|
```php
|
|
|
|
|
|
/**
|
|
|
|
|
|
* @CQCommand("你好")
|
|
|
|
|
|
*/
|
|
|
|
|
|
public function hello() {
|
|
|
|
|
|
ctx()->reply("你好,我是炸毛!");
|
|
|
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
|
|
|
* @RequestMapping("/index")
|
|
|
|
|
|
*/
|
|
|
|
|
|
public function index() {
|
|
|
|
|
|
return "<h1>hello!</h1>";
|
|
|
|
|
|
}
|
|
|
|
|
|
```
|
2020-11-10 23:16:55 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2020-11-22 19:18:23 +08:00
|
|
|
|
## 开始前
|
|
|
|
|
|
|
|
|
|
|
|
首先,你需要了解你需要知道哪些事情才能开始着手使用框架:
|
2020-11-10 23:16:55 +08:00
|
|
|
|
|
2021-01-29 21:30:19 +08:00
|
|
|
|
1. Linux 命令行(会跑 Linux 程序)
|
2021-08-30 16:17:13 +08:00
|
|
|
|
2. php >=7.2 开发环境(项目会持续支持最新的 PHP 版本)
|
2021-03-02 13:40:21 +08:00
|
|
|
|
4. OneBot 机器人聊天接口标准
|
2020-11-10 23:16:55 +08:00
|
|
|
|
|
2020-11-22 19:18:23 +08:00
|
|
|
|
需要值得注意的是,本教程中所涉及的内容均为尽可能翻译为白话的方式进行描述,但对于框架的组件或事件等需要单独拆分说明文档的部分则需要足够详细,所以本教程提供一个快速上手的教程,并且会将最典型的安装方式写到快速教程篇。
|
2020-11-10 23:16:55 +08:00
|
|
|
|
|
2020-11-23 01:47:37 +08:00
|
|
|
|
!!! bug "文档提示"
|
|
|
|
|
|
|
2021-07-04 15:45:30 +08:00
|
|
|
|
此文档采用 MkDocs 驱动,文档的搜索组件原生不支持中文搜索,且分词很难控制,所以搜索体验会大打折扣,敬请谅解!搜不到不是没这个东西,建议这种情况可以自行翻阅目录查看!
|
2020-11-23 01:47:37 +08:00
|
|
|
|
|
2020-11-10 23:16:55 +08:00
|
|
|
|
|
|
|
|
|
|
## 框架特色
|
2021-07-04 15:45:30 +08:00
|
|
|
|
|
2020-11-10 23:16:55 +08:00
|
|
|
|
- 支持MySQL数据库(连接池),自带查询缓存提高多查询时的效率
|
|
|
|
|
|
- Websocket 服务器、HTTP 服务器兼容运行,一个框架多个用处
|
|
|
|
|
|
- 支持命令、自然语言处理等多种插件形式
|
|
|
|
|
|
- 支持多个机器人账号负载均衡
|
|
|
|
|
|
- 协程 + TaskWorker 进程重度任务处理机制,保证高效,单个请求响应时间为 0.1 ms 左右
|
|
|
|
|
|
- 模块分离和自由组合,可根据自身需求自己建立模块内的目录结构和代码结构
|
2020-11-23 01:09:57 +08:00
|
|
|
|
- 灵活的注释注解注册事件方式,弥补 PHP 语言缺少注解的遗憾
|
|
|
|
|
|
|
|
|
|
|
|
## 文档主题
|
|
|
|
|
|
|
2020-12-22 16:28:34 +08:00
|
|
|
|
### 主题
|
2021-07-04 15:45:30 +08:00
|
|
|
|
|
2020-11-23 01:09:57 +08:00
|
|
|
|
<div class="tx-switch">
|
|
|
|
|
|
<button data-md-color-scheme="default"><code>默认模式</code></button>
|
|
|
|
|
|
<button data-md-color-scheme="slate"><code>暗黑模式</code></button>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
|
|
<script>
|
|
|
|
|
|
var buttons = document.querySelectorAll("button[data-md-color-scheme]");
|
|
|
|
|
|
buttons.forEach(function(button) {
|
|
|
|
|
|
button.addEventListener("click", function() {
|
|
|
|
|
|
var attr = this.getAttribute("data-md-color-scheme");
|
|
|
|
|
|
setCookie("_theme", attr);
|
|
|
|
|
|
document.body.setAttribute("data-md-color-scheme", attr);
|
|
|
|
|
|
var name = document.querySelector("#__code_0 code span:nth-child(7)");
|
|
|
|
|
|
name.textContent = attr;
|
|
|
|
|
|
})
|
|
|
|
|
|
})
|
|
|
|
|
|
</script>
|
|
|
|
|
|
|
2020-12-22 16:28:34 +08:00
|
|
|
|
### 主色调
|
2021-07-04 15:45:30 +08:00
|
|
|
|
|
2020-11-23 01:09:57 +08:00
|
|
|
|
<div class="tx-switch">
|
|
|
|
|
|
<button data-md-color-primary="red"><code>red</code></button>
|
|
|
|
|
|
<button data-md-color-primary="pink"><code>pink</code></button>
|
|
|
|
|
|
<button data-md-color-primary="purple"><code>purple</code></button>
|
|
|
|
|
|
<button data-md-color-primary="deep-purple"><code>deep purple</code></button>
|
|
|
|
|
|
<button data-md-color-primary="indigo"><code>indigo</code></button>
|
|
|
|
|
|
<button data-md-color-primary="blue"><code>blue</code></button>
|
|
|
|
|
|
<button data-md-color-primary="light-blue"><code>light blue</code></button>
|
|
|
|
|
|
<button data-md-color-primary="cyan"><code>cyan</code></button>
|
|
|
|
|
|
<button data-md-color-primary="teal"><code>teal</code></button>
|
|
|
|
|
|
<button data-md-color-primary="green"><code>green</code></button>
|
|
|
|
|
|
<button data-md-color-primary="light-green"><code>light green</code></button>
|
|
|
|
|
|
<button data-md-color-primary="lime"><code>lime</code></button>
|
|
|
|
|
|
<button data-md-color-primary="yellow"><code>yellow</code></button>
|
|
|
|
|
|
<button data-md-color-primary="amber"><code>amber</code></button>
|
|
|
|
|
|
<button data-md-color-primary="orange"><code>orange</code></button>
|
|
|
|
|
|
<button data-md-color-primary="deep-orange"><code>deep orange</code></button>
|
|
|
|
|
|
<button data-md-color-primary="brown"><code>brown</code></button>
|
|
|
|
|
|
<button data-md-color-primary="grey"><code>grey</code></button>
|
|
|
|
|
|
<button data-md-color-primary="blue-grey"><code>blue grey</code></button>
|
|
|
|
|
|
<button data-md-color-primary="black"><code>black</code></button>
|
|
|
|
|
|
<button data-md-color-primary="white"><code>white</code></button>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
|
2020-12-22 16:28:34 +08:00
|
|
|
|
### 辅色调
|
2021-07-04 15:45:30 +08:00
|
|
|
|
|
2020-12-22 16:28:34 +08:00
|
|
|
|
<div class="tx-switch"> <button data-md-color-accent="red"><code>red</code></button> <button data-md-color-accent="pink"><code>pink</code></button> <button data-md-color-accent="purple"><code>purple</code></button> <button data-md-color-accent="deep-purple"><code>deep purple</code></button> <button data-md-color-accent="indigo"><code>indigo</code></button> <button data-md-color-accent="blue"><code>blue</code></button> <button data-md-color-accent="light-blue"><code>light blue</code></button> <button data-md-color-accent="cyan"><code>cyan</code></button> <button data-md-color-accent="teal"><code>teal</code></button> <button data-md-color-accent="green"><code>green</code></button> <button data-md-color-accent="light-green"><code>light green</code></button> <button data-md-color-accent="lime"><code>lime</code></button> <button data-md-color-accent="yellow"><code>yellow</code></button> <button data-md-color-accent="amber"><code>amber</code></button> <button data-md-color-accent="orange"><code>orange</code></button> <button data-md-color-accent="deep-orange"><code>deep orange</code></button> </div>
|
|
|
|
|
|
|
2020-11-23 01:09:57 +08:00
|
|
|
|
<script>
|
|
|
|
|
|
var buttons = document.querySelectorAll("button[data-md-color-primary]")
|
|
|
|
|
|
buttons.forEach(function(button) {
|
|
|
|
|
|
button.addEventListener("click", function() {
|
|
|
|
|
|
var attr = this.getAttribute("data-md-color-primary")
|
|
|
|
|
|
setCookie("_primary_color", attr)
|
|
|
|
|
|
document.body.setAttribute("data-md-color-primary", attr)
|
|
|
|
|
|
var name = document.querySelector("#__code_2 code span:nth-child(7)")
|
|
|
|
|
|
name.textContent = attr.replace("-", " ")
|
|
|
|
|
|
})
|
|
|
|
|
|
})
|
|
|
|
|
|
</script>
|
2020-12-22 16:28:34 +08:00
|
|
|
|
|
|
|
|
|
|
<script>
|
|
|
|
|
|
var buttons2 = document.querySelectorAll("button[data-md-color-accent]")
|
|
|
|
|
|
buttons2.forEach(function(button) {
|
|
|
|
|
|
button.addEventListener("click", function() {
|
|
|
|
|
|
var attr = this.getAttribute("data-md-color-accent")
|
|
|
|
|
|
setCookie("_accent_color", attr)
|
|
|
|
|
|
document.body.setAttribute("data-md-color-accent", attr)
|
|
|
|
|
|
var name = document.querySelector("#__code_3 code span:nth-child(7)")
|
|
|
|
|
|
name.textContent = attr.replace("-", " ")
|
|
|
|
|
|
})
|
|
|
|
|
|
})
|
|
|
|
|
|
</script>
|