zhamao-framework/README.md

120 lines
6.7 KiB
Markdown
Raw Normal View History

2020-08-23 23:44:15 +08:00
<div align="center">
<img src="https://cdn.jsdelivr.net/gh/zhamao-robot/zhamao-framework/resources/images/logo_trans.png" width = "150" height = "150" alt="炸毛框架"><br>
2020-08-23 23:45:45 +08:00
<h2>炸毛框架</h2>
2020-12-26 21:04:48 +08:00
炸毛框架 (zhamao-framework) 是一个协程高性能的聊天机器人 + Web 服务器开发框架<br><br>
2020-08-23 23:49:05 +08:00
[![作者QQ](https://img.shields.io/badge/作者QQ-627577391-orange.svg)](http://wpa.qq.com/msgrd?v=3&uin=627577391&site=qq&menu=yes)
2020-03-11 11:59:20 +08:00
[![zhamao License](https://img.shields.io/hexpm/l/plug.svg?maxAge=2592000)](https://github.com/zhamao-robot/zhamao-framework/blob/master/LICENSE)
2020-06-13 17:45:29 +08:00
[![Latest Stable Version](http://img.shields.io/packagist/v/zhamao/framework.svg)](https://packagist.org/packages/zhamao/framework)
[![Banner](https://img.shields.io/badge/OneBot-v11-success)](https://github.com/howmanybots/onebot)
2021-08-31 13:40:29 +08:00
![Build Actions](https://github.com/zhamao-robot/zhamao-framework/actions/workflows/main.yml/badge.svg)
2018-11-28 20:12:05 +08:00
2021-02-09 10:54:05 +08:00
[![注解数量](https://img.shields.io/github/search/zhamao-robot/zhamao-framework/AnnotationBase.svg)](https://github.com/zhamao-robot/zhamao-framework/search?q=AnnotationBase)
2021-02-09 10:53:15 +08:00
[![TODO 数量](https://img.shields.io/github/search/zhamao-robot/zhamao-framework/TODO.svg)](https://github.com/zhamao-robot/zhamao-framework/search?q=TODO)
2018-11-28 20:12:05 +08:00
2020-12-23 10:21:48 +08:00
</div>
2020-08-23 23:45:45 +08:00
2021-02-22 01:07:35 +08:00
开发者 QQ 群:**670821194** [点击加入群聊](https://jq.qq.com/?_wv=1027&k=YkNI3AIr)
2020-12-23 10:28:20 +08:00
2021-05-26 16:56:55 +08:00
**如果有愿意一起开发框架本身的开发者,请提出 PR 或 Issue 参与开发!如果对框架本身的核心设计有更好的想法,可与作者成立开发组(目前仅作者 1 人),参与 OneBot V12 生态和框架本身的开发。**
**相关正在进行的版本任务见 Projects 一栏!**
2021-05-26 16:31:41 +08:00
2020-03-02 16:14:20 +08:00
## 简介
2020-12-23 10:21:48 +08:00
炸毛框架使用 PHP 编写,采用 Swoole 扩展为基础,主要面向 API 服务聊天机器人OneBot 兼容的 QQ 机器人对接),包含 Websocket、HTTP 等监听和请求库,用户代码采用模块化处理,使用注解可以方便地编写各类功能。
框架主要用途为 HTTP 服务器,机器人搭建框架。尤其对于 QQ 机器人消息处理较为方便和全面,提供了众多会话机制和内部调用机制,可以以各种方式设计你自己的模块。
```php
/**
* @CQCommand("你好")
*/
public function hello() {
ctx()->reply("你好,我是炸毛!"); // 简单的命令式回复
}
/**
* @RequestMapping("/index")
*/
public function index() {
return "<h1>hello!</h1>"; // 快速的 HTTP 服务开发
}
```
2019-02-11 15:43:33 +08:00
2020-04-19 10:19:48 +08:00
## 开始
2021-05-08 01:24:27 +08:00
如果你是初学者,可以直接使用以下脚本部署 PHP 环境和安装框架的脚手架:
```bash
2021-07-15 11:37:35 +08:00
# 新建一个自己喜欢名字的文件夹,运行一键安装脚本 (仅限 x86_64 和 aarch64 平台)
2021-05-08 01:24:27 +08:00
mkdir zhamao-app/
cd zhamao-app/
bash -c "$(curl -fsSL https://api.zhamao.xin/go.sh)"
# 启动
2021-07-10 15:55:15 +08:00
vendor/bin/start server
2021-05-08 01:24:27 +08:00
```
2020-04-19 10:19:48 +08:00
2020-12-23 10:21:48 +08:00
## 文档v2 版本)
2021-08-30 16:40:53 +08:00
查看文档(国内自建):<https://framework.zhamao.xin/>
2020-11-23 01:47:37 +08:00
2021-08-30 16:40:53 +08:00
备用链接(国外托管):<https://framework.zhamao.me/>
2020-03-12 20:43:58 +08:00
2020-11-22 19:26:35 +08:00
自行构建文档:`mkdocs build -d distribute`
2019-02-11 15:43:33 +08:00
2019-02-09 14:00:39 +08:00
## 特点
2021-02-09 10:47:40 +08:00
- 原生为多账号设计,支持多个机器人负载均衡
2020-12-23 10:21:48 +08:00
- 使用 Swoole 多工作进程机制和协程加持,尽可能简单的情况下提升了性能
2020-03-02 16:14:20 +08:00
- 灵活的注解事件绑定机制
2020-05-08 18:45:40 +08:00
- 易用的上下文,模块内随处可用
2021-02-09 10:47:40 +08:00
- 采用模块化编写,可自由搭配其他 composer 组件
- 常驻内存,全局缓存变量随处使用,提供多种缓存方案
2021-01-14 18:32:54 +08:00
- 自带 MySQL、Redis 等数据库连接池等数据库连接方案
2021-02-09 10:47:40 +08:00
- 本身为 HTTP 服务器、WebSocket 服务器,可以构建属于自己的 HTTP API 接口
- 静态文件服务器,可将前端合并到一起
2021-05-08 01:24:27 +08:00
- 自带 PHP + Swoole 环境无需手动编译安装by [crazywhalecc/static-php-cli](https://github.com/crazywhalecc/static-php-cli)
2020-12-23 10:21:48 +08:00
## 从 v1 升级
炸毛框架 v2 相对 v1 版本改动了不少内容,其中包括框架底层机制、注解事件分发、调试、命名空间等变化,详情可查看上方文档。
如果旧版框架使用过程中无问题且对新功能暂无需求,可以继续使用 v1 版本,后续也将维护安全类更新和修复致命 bug。
2018-11-28 20:12:05 +08:00
2021-03-12 19:45:53 +08:00
## 下载源码
框架源码可直接克隆本仓库进行编辑,如果你在国内,访问 GitHub 和 clone 仓库比较慢,可以将 `github.com` 替换为 `fgit.zhamao.me` 进行加速。
例如:`git clone https://fgit.zhamao.me/zhamao-robot/zhamao-framework.git --depth 1`
2021-03-12 19:45:53 +08:00
2020-03-19 18:27:55 +08:00
## 贡献和捐赠
2021-02-09 10:47:40 +08:00
如果你在使用过程中发现任何问题,可以提交 Issue 或自行 Fork 后修改并提交 Pull Request。
目前项目仅一人维护,耗费精力较大,所以非常欢迎对框架的贡献。
2019-01-31 23:19:53 +08:00
2020-03-19 18:27:55 +08:00
本项目为作者闲暇时间开发,如果觉得好用,不妨进行捐助~你的捐助会让我更加有动力完善插件,感谢你的支持!
2021-02-09 11:12:29 +08:00
我们会将捐赠的资金用于本项目驱动的炸毛机器人和框架文档的服务器开销上。[捐赠列表](https://github.com/zhamao-robot/thanks)
2020-03-19 18:27:55 +08:00
### 支付宝
![支付宝二维码](https://cdn.jsdelivr.net/gh/zhamao-robot/zhamao-framework/resources/images/alipay_img.jpg)
2020-03-19 18:27:55 +08:00
2020-12-23 10:21:48 +08:00
如果你对我们的周边感兴趣,我们还有炸毛机器人定制 logo 的雨伞,详情咨询作者 QQ我们会作为您捐助了本项目
2018-12-03 11:37:09 +08:00
## 关于
2020-08-05 09:09:03 +08:00
框架和 SDK 是 炸毛机器人 项目的核心框架开源部分。炸毛机器人是作者写的一个高性能机器人,曾获全国计算机设计大赛一等奖。
2018-12-03 11:37:09 +08:00
2021-10-15 09:38:07 +08:00
作者的炸毛机器人已从2018年初起稳定运行了**四年**,并且持续迭代。
2021-01-05 23:35:49 +08:00
欢迎随时在 HTTP-API 插件群里提问,当然更好的话可以加作者 QQ[627577391](http://wpa.qq.com/msgrd?v=3&uin=627577391&site=qq&menu=yes))或提交 Issue 进行疑难解答。
2019-01-31 23:19:53 +08:00
2020-06-05 16:02:13 +08:00
本项目在更新内容时,请及时关注 GitHub 动态,更新前请将自己的模块代码做好备份。
2020-03-11 11:50:10 +08:00
项目框架采用 Apache-2.0 协议开源,在分发或重写修改等操作时需遵守协议。项目模块部分(`Module` 文件夹) 在非借鉴框架内代码时可不遵守 Apache-2.0 协议进行分发和修改(声明版权)。
2020-12-23 10:21:48 +08:00
**注意**:在你使用 mirai 等 `AGPL-3.0` 协议的机器人软件与框架连接时,使用本框架需要将你编写或修改的部分使用 `AGPL-3.0` 协议重新分发。
2021-02-09 10:47:40 +08:00
在贡献代码时,请保管好自己的全局配置文件中的敏感信息,请勿将带有个人信息的配置文件上传 GitHub 等网站。
2021-11-17 00:28:54 +08:00
感谢 JetBrains 为此开源项目提供 PhpStorm 开发工具支持:
<img src="https://resources.jetbrains.com/storage/products/company/brand/logos/PhpStorm.svg" width="300">
2021-12-07 12:17:47 +08:00
感谢 [php-libonebot](https://github.com/botuniverse/php-libonebot) 开发者 @sunxyw 中为项目开发规范化提出的一些建议。
2021-11-17 00:28:54 +08:00
<!-- ![star](https://starchart.cc/zhamao-robot/zhamao-framework.svg) -->