zx/README.md

339 lines
11 KiB
Markdown
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

CRMEB MER TP6+Swoole4
===============
> 运行环境要求PHP7.1、 7.2、7.3、7.4其他版本暂不推荐。不支持windows环境运行
## 开发规范
#### 命名规范
ThinkPHP6.0遵循PSR-2命名规范和PSR-4自动加载规范并且注意如下规范:
1. 目录和文件
2. 目录使用小写+下划线;
3. 类库、函数文件统一以.php为后缀
4. 类的文件名均以命名空间定义,并且命名空间的路径和类库文件所在路径一致;
5.包含接口和Trait文件采用驼峰法命名首字母大写其它文件采用小写+下划线命名;
6. 类名包括接口和Trait和文件名保持一致统一采用驼峰法命名首字母大写
#### 函数和类、属性命名
1. 类的命名采用驼峰法(首字母大写),例如 User、UserType
2. common函数的命名使用小写字母和下划线小写字母开头的方式例如 get_client_ip
3. 控制器里面的方法使用小写字母和下划线(小写字母开头)的方式,例如 get_client_ip
4. 方法的命名使用驼峰法(首字母小写),例如 getUserName
5. 属性的命名使用驼峰法(首字母小写),例如 tableName、instance
6. 特例以双下划线__打头的函数或方法作为魔术方法例如 __call 和 __autoload
#### 常量和配置
1. 常量以大写字母和下划线命名,例如 APP_PATH
2. 配置参数以小写字母和下划线命名,例如 url_route_on 和url_convert
3. 环境变量定义使用大写字母和下划线命名例如APP_DEBUG
#### 数据表和字段
1. 数据表和字段采用小写加下划线方式命名,并注意字段名不要以下划线开头,例如 think_user 表和 user_name字段不建议使用驼峰和中文作为数据表及字段命名
注意:请理解并尽量遵循以上命名规范,可以减少在开发过程中出现不必要的错误
#### 语法规范
1. 尽量使用php7新语法
2. 每个 namespace 命名空间声明语句和 use 声明语句块后面,必须 插入一个空白行
3. 类的开始花括号({ 必须 写在类声明后自成一行,结束花括号(})也 必须 写在类主体后自成一行
4. 方法的开始花括号({ 必须 写在函数声明后自成一行,结束花括号(})也 必须 写在函数主体后自成一行。
5. 类的属性和方法 必须 添加访问修饰符private、protected 以及 publicabstract 以及 final 必须 声明在访问修饰符之前,而 static 必须 声明在访问修饰符之后
6. 控制结构的关键字后 必须 要有一个空格符,而调用方法或函数时则 一定不可 有
7. 控制结构的开始花括号({ 必须 写在声明的同一行,而结束花括号(} 必须 写在主体后自成一行
8. 纯 PHP 代码文件 必须 省略最后的 ?> 结束标签
9. 所有方法,类,控制器类,都 必须 添加访问修饰符
~~~
/**
* 中文注释
* @param string $str 声明类型
* @param array $arr
* @return bool
*/
public function action(string $str, array $arr)
{
return true;
}
~~~
10. 参数列表中,每个逗号后面 必须 要有一个空格,而逗号前面 一定不可 有空格
~~~
function foo($arg1, &$arg2, $arg3 = [])
{
// method body
}
~~~
11. 参数 可以 分列成多行,此时包括第一个参数在内的每个参数都 尽量 单独成行。
~~~
<?php
$foo->bar(
$longArgument,
$longerArgument,
$muchLongerArgument
);
~~~
12. 标准的 if 结构如下代码所示,请留意「括号」、「空格」以及「花括号」的位置,
注意 else 和 elseif 都与前面的结束花括号在同一行
~~~
<?php
if ($expr1) {
// if body
} elseif ($expr2) {
// elseif body
} else {
// else body;
}
~~~
13. 赋值等号前后必须加空格符
~~~
<?php
$arr = [];
~~~
#### PHP 7.1+ 常用新语法
1. 三元运算符
~~~
<?php
$arr = ['crmeb'=>true];
之前
echo isset($arr['crmeb']) ? $arr['crmeb'] : '';
之后
echo $arr['crmeb'] ?? '';
~~~
2. define() 定义常量数组
~~~
<?php
define('ARR',['a','b']);
~~~
3. 命名空间优化
~~~
<?php
//PHP7之前语法
use FooLibrary\Bar\Baz\ClassA;
use FooLibrary\Bar\Baz\ClassB;
// PHP7新语法写法
use FooLibrary\Bar\Baz\{ ClassA, ClassB};
~~~
#### CRMEB规范
1. 所有数据验证放在模块下的 validates 目录下
2. JSON返回使用父级 AuthController类中的success 和 fail
3. 错误判断抛出异常,由一个错误类统一控制输出
~~~
<?php
throw new AuthException('错误信息',400);
~~~
4. 错误码和错误提示语应该统一管理,方便切换多语言
5. 数据库操作使用模型类不能使用Db::table()
6. 获取表单数据使用 app\Request
~~~
<?php
use app\Request;
public function index(Request $request) {
//获取提交的数据,并以二维数组形式返回
$arr = $request->getMore([
'name',
'nickname'
]);
//获取提交的数据,并以二维数组形式返回并附加默认值
$arr = $request->getMore([
['name','123'],
['nickname','0']
]);
//获取提交的数据,并以一维数组形式返回并附加默认值
[$name, $nickname] = $request->getMore([
['name','123'],
['nickname','0']
],true);
}
~~~
7. 所有控制器类命令和表名对应,按照大驼峰命名规范
8. 所有文件夹命名按照小写字母加下划线定义
9. 所有属性名,变量名尽量遵守小驼峰命名规范
10. 复杂逻辑,多状态应适当添加行内注释
## 主要特性
有详细的代码注释,有完整系统手册
### TP6框架
使用最新的 ThinkPHP 6.0 + Swoole4框架开发
### 前端采用Vue CLI框架
前端使用Vue CLI框架nodejs打包页面加载更流畅用户体验更好
### 标准接口
标准接口、前后端分离,二次开发更方便
### 支持队列
降低流量高峰,解除耦合,高可用
### 长连接
减少CPU及内存使用及网络堵塞减少请求响应时长
### 无缝事件机制
行为扩展更方便,方便二次开发
### 后台快速生成表单
后台应用form-builder 无需写页面快速增删改查
### 数据表格导出
PHPExcel数据导出,导出表格更加美观可视;
### 数据统计分析
后台使用ECharts图表统计实现用户、产品、订单、资金等统计分析
### 强大的后台权限管理
后台多种角色、多重身份权限管理,权限可以控制到每一步操作
### 一键安装
自动检查系统环境一键安装
# 安装
本安装教程针对的是宝塔面板安装 环境为 nginx1.18 mysql5.7 php7.3
## 站点配置
1. 创建站点 创建站点注意php版本选择纯静态
2. 上传你的代码到站点根目录下
3. 点开站点设置,网站目录标签下,配置运行目录为 /public
4. ssl标签中配置https证书
5. 反向代理标签下配置站点反向代理目标URL填写为 http://127.0.0.1:8324 ,点击提交,在列表中点击配置文件,将下方代码复制替换全部。
~~~
#PROXY-START/
location ~* \.(php|jsp|cgi|asp|aspx)$
{
proxy_pass http://127.0.0.1:8324;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header REMOTE-HOST $remote_addr;
}
location /
{
if (!-e $request_filename) {
proxy_pass http://127.0.0.1:8324;
}
proxy_http_version 1.1;
proxy_read_timeout 360s;
proxy_redirect off;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header REMOTE-HOST $remote_addr;
add_header X-Cache $upstream_cache_status;
#Set Nginx Cache
add_header Cache-Control no-cache;
expires 12h;
}
#PROXY-END/
~~~
## 环境配置
### php配置进入宝塔的软件商店进入php的设置
1. 将项目中 install/swoole-loader/swoole_loader73.so 复制到 /www/server/php/73/lib/php/extensions/no-debug-non-zts-20180731 目录下 (注:根据你安装的 php 版本选择扩展)
2. 点击安装扩展标签,安装 fileinforedisSwoole4 这三个扩展
3. 点击配置修改标签,将 memory_limit 脚本内存控制改为 256M
4. 点击配置文件标签,将 extension = swoole_loader73.so 代码添加在最下方,然后保存。
5. 点击服务标签,重启 php 服务。
### mysql配置进入宝塔的软件商店进入mysql的设置
1. 点击配置修改标签,找到 sql-mode ,将后面的值修改为 NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION
2. 点击服务标签,重启 mysql 服务。
## 启动swoole
1. 打开命令行执行命令: `php -v` 查看命令行版本是否为配置的 PHP 版本
2. 命令行切换到站点目录下执行启动命令: `php think swoole restart`
3. 在浏览器中输入你的域名例如www.yourdomain.com安装程序会自动执行安装。期间系统会提醒你输入数据库信息以完成安装。
4. 再次打开命令行换到站点目录下执行重启命令: `php think swoole restart`
5. 利用Supervisor进行守护进程`php think swoole restart`
## 访问地址
### 后台访问地址:
域名/admin
### 公众号和H5首页访问地址
域名/
### 安装过程中请牢记您的账号密码!
## 重新安装
1. 清除数据库
2. 删除 install/install.lock 文件
3. 执行重启命令: `php think swoole restart`
4. 执行完安装后再次执行重启命令: `php think swoole restart`
## 手动安装
1. 创建数据库,倒入数据库文件
数据库文件目录/public/install/crmeb_merchant.sql
2. 修改数据库连接文件
配置文件路径/.env
~~~
APP_DEBUG = true
INSTALLED = true
SHOW_PHONE = true
[APP]
DEFAULT_TIMEZONE = Asia/Shanghai
[DATABASE]
TYPE = mysql
HOSTNAME = 127.0.0.1 #数据库连接地址
DATABASE = test #数据库名称
USERNAME = username #数据库登录账号
PASSWORD = password #数据库登录密码
HOSTPORT = 3306 #数据库端口
CHARSET = utf8
DEBUG = true
[REDIS]
REDIS_HOSTNAME = 127.0.0.1 #redis地址
PORT = 6379 #redis端口
REDIS_PASSWORD = '' #redis密码
SELECT = 0 #redis数据库
~~~
3. 修改目录权限linux系统777
/public
/runtime
4. 启动swoole,需要使用Supervisor进行守护进程
~~~
php think swoole restart
~~~
## 启动命令
开启
```sh
php think swoole restart
```
## 文档
[使用手册](https://doc.crmeb.com/)
||
[TP6开发手册](https://www.kancloud.cn/manual/thinkphp6_0/content)
||
[Swoole开发手册](https://wiki.swoole.com/#/)
## 参与开发
请参阅 [CRMEB](https://github.com/crmeb/CRMEB)
## 版权信息
本项目包含的第三方源码和二进制文件之版权信息另行标注。
版权所有Copyright © 2017-2024 by [CRMEB](http://www.crmeb.com)
All rights reserved。
CRMEB® 商标和著作权所有者为西安众邦网络科技有限公司。
###开发团队:
##### 技术xaboy、Qinii、郭小萌、旺仔
##### 产品Amy
##### 设计xy-yyds, LXT
##### 测试:夏天、绵绵羊、王多鱼
注:排名不分前后