代码拉取完成,页面将自动刷新
同步操作将从 凯撒李大爷/基于TP6.0+vue element平台管理系统 强制同步,此操作会覆盖自 Fork 仓库以来所做的任何修改,且无法恢复!!!
确定后同步将在后台操作,完成时将刷新页面,请耐心等待。
运行环境要求PHP7.1+,兼容PHP8.0。
官方应用服务市场 | ThinkAPI
——官方统一API服务
ThinkPHPV6.0版本由亿速云独家赞助发布
http://121.36.161.35:9528/dashboard
1、git拉取代码后可更新composer执行:composer update
2、创建.env文件,复制.example.env内容
3、开始使用啦
更新tp框架
composer update topthink/framework
vue目录在views目录下
1、如果npm i报错,可以先跑下以下命令
npm install --save-dev sass-loader
npm config set sass_binary_site=https://npm.taobao.org/mirrors/node-sass
2、调试模式:npm run dev
打包:npm run build:prod
基于TP6的一款前后端分离管理系统
https://docs.apipost.cn/preview/787d44633670a7e4/484894853cd84ede#001
很多配置项写在了.env文件里,参考文件.example.env部署
1、平台在调用service或者utils等只需要单例模式时;
提供了Kernel::single(SmsService::class);写法;
(ps:本来打算自己写,后发现tp自带有,直接封装使用了)
2、contro层在获取请求参数时进行了封装:
使用中间件RequestParam来获取请求参数;
继承了baseController的可直接$data = $this->dataParams;
3、在支付、短信、队列等这些扩展使用了工厂模式,在utils下都加了对应的工具类;
然后在service层去调用对应的工具类;
这样的目的:
一是为了保证扩展的独立性;
二是可以在工具类里做一些个性化操作;
1、日志问题:
拿支付扩展来说,我在基类里写了$this->log()用来给扩展记录支付日志。
但是造成了我每次写一个扩展就要手动在对应方法里调用日志方法.
比如aliAppPay里调起pay方法我要记录一遍,写wxAppPay我又要写一遍,再添加一个忘记写了就记不下来了。
如果在调用支付的util类里加,不过是换汤不换药,我payment还是要传处理数据回来我才能记录。
相应的问题还存在于队列里,记录下来等待有缘人告知。
2、权限管理实现跟前端问题:
简单的来说就是权限管理只适合本套前端代码。
拿出接口去对接其他前端可能很难一下接上。
又草率了...不过问题不大。。。
1、后台RBAC权限管理:【已完成】
本系统角色权限管理分开菜单管理跟功能权限
菜单权限负责前台侧边栏展示,功能权限负责角色是否能操作
菜单权限实现:
数据库存放了menu菜单表
然后通过角色关联对应菜单来实现前端菜单栏权限。
功能权限实现:
admin应用的路由的append加了个is_permission字段;
为true时表示必须走权限,不写或false表示不走权限。
功能权限检查在app\admin\middleware\CheckToken里
2、第三方支付扩展:【已完成】
提供服务类:app\portal\service\PaymentService
配置文件:config/pay.php
已配置【app端支付宝】
3、文件上传扩展:【已完成】
提供服务类:app\common\service\UploadService
配置文件:config/upload.php
已配置【本地、七牛云】
4、消息队列扩展:【草率了...】
提供服务类:app\common\service\TaskService
暂时实现了think_queue跟rabbitMq的延迟、正常发布队列两种.
配置文件:config/sys_task.php
开启消费者:php think task_consumer
PS:运行前php.ini将system()从禁用里去掉;
设计思路:在配置文件下配置好系统要使用的队列
然后就去开启消费者监听命令,php think task_consumer
PS:在开启task_consumer时,tp自带think_queue支持同时开启多个消费者;
其他自定义的mq开启多个消费者因为会阻塞,不能循环开启消费者;
我在task_consumer里循环执行:php think enable_queue 队列名来批量开启消费者;
使用方法代码:
#--------队列使用案例 start---------
$data = new QueueParamsDto();
$data->setData(['ts' => time(), 'bizId' => uniqid(), 'a' => 1]);
$data->setTaskClass(TestTask::class);
//lpc route主要在rabbit里用,queueName是tp自带的用,都有默认值
//$data->setRoutes(['cancel_order','notify']);
//$data->setQueueName('default_queue');
$res = Kernel::single(TaskService::class)->publish($data);//即时队列
$res = Kernel::single(TaskService::class)->publish($data,10);//延时队列,10秒后执行
#--------队列使用案例 end---------
5、短信扩展:【已完成】
提供服务类:app\common\service\SmsService
配置文件:config/sms.php
支持了可选短信发送类型【code码、自定义】
支持了短信直接发送、队列发送、队列延时发送
平台可查看短信发送状态,支持重发操作
6、请求缓存:【TP自带直接使用】
7、导入导出扩展:【已完成】
提供服务类:app\common\service\ExcelService
配置文件:config/excel.php
导出支持返回下载链接、直接输出文件流
导入支持url、本地文件读取
..........
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。