后台优化
This commit is contained in:
133
(红头)数据库配置.md
Normal file
133
(红头)数据库配置.md
Normal file
@@ -0,0 +1,133 @@
|
|||||||
|
# 数据库配置文档
|
||||||
|
|
||||||
|
**项目路径:** `/www/wwwroot/code`
|
||||||
|
**配置文件:** `application/database.php`
|
||||||
|
**框架版本:** ThinkPHP 5.0
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 数据库连接信息
|
||||||
|
|
||||||
|
| 配置项 | 值 | 说明 |
|
||||||
|
|--------|-----|------|
|
||||||
|
| **数据库类型** | `mysql` | MySQL数据库 |
|
||||||
|
| **服务器地址** | `127.0.0.1` | 本地MySQL服务器 |
|
||||||
|
| **数据库名** | `ruilai` | 数据库名称 |
|
||||||
|
| **用户名** | `rootrui` | 数据库用户名 |
|
||||||
|
| **密码** | `X2)jB+k%YH.p` | 数据库密码 |
|
||||||
|
| **端口** | `` | 默认3306端口 |
|
||||||
|
| **字符集** | `utf8` | 数据库编码 |
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 数据库高级配置
|
||||||
|
|
||||||
|
| 配置项 | 值 | 说明 |
|
||||||
|
|--------|-----|------|
|
||||||
|
| **表前缀** | `t_sys_` | 数据库表前缀 |
|
||||||
|
| **调试模式** | `true` | 已开启数据库调试 |
|
||||||
|
| **部署方式** | `0` | 集中式(单一服务器) |
|
||||||
|
| **读写分离** | `false` | 未启用读写分离 |
|
||||||
|
| **主服务器数量** | `1` | 主服务器数量 |
|
||||||
|
| **字段严格检查** | `true` | 严格检查字段是否存在 |
|
||||||
|
| **数据集返回类型** | `array` | 返回数组格式 |
|
||||||
|
| **自动时间戳** | `false` | 未启用自动时间戳 |
|
||||||
|
| **时间格式** | `Y-m-d H:i:s` | 默认时间格式 |
|
||||||
|
| **SQL性能分析** | `false` | 未启用SQL性能分析 |
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 完整配置文件内容
|
||||||
|
|
||||||
|
```php
|
||||||
|
<?php
|
||||||
|
// +----------------------------------------------------------------------
|
||||||
|
// | ThinkPHP [ WE CAN DO IT JUST THINK ]
|
||||||
|
// +----------------------------------------------------------------------
|
||||||
|
// | Copyright (c) 2006~2016 http://thinkphp.cn All rights reserved.
|
||||||
|
// +----------------------------------------------------------------------
|
||||||
|
// | Licensed ( http://www.apache.org/licenses/LICENSE-2.0 )
|
||||||
|
// +----------------------------------------------------------------------
|
||||||
|
// | Author: liu21st <liu21st@gmail.com>
|
||||||
|
// +----------------------------------------------------------------------
|
||||||
|
|
||||||
|
return [
|
||||||
|
// 数据库类型
|
||||||
|
'type' => 'mysql',
|
||||||
|
// 服务器地址
|
||||||
|
'hostname' => '127.0.0.1',
|
||||||
|
// 数据库名
|
||||||
|
'database' => 'ruilai',
|
||||||
|
// 用户名
|
||||||
|
'username' => 'rootrui',
|
||||||
|
// 密码
|
||||||
|
'password' => 'X2)jB+k%YH.p',
|
||||||
|
// 端口
|
||||||
|
'hostport' => '',
|
||||||
|
// 连接dsn
|
||||||
|
'dsn' => '',
|
||||||
|
// 数据库连接参数
|
||||||
|
'params' => [],
|
||||||
|
// 数据库编码默认采用utf8
|
||||||
|
'charset' => 'utf8',
|
||||||
|
// 数据库表前缀
|
||||||
|
'prefix' => 't_sys_',
|
||||||
|
// 数据库调试模式
|
||||||
|
'debug' => true,
|
||||||
|
// 数据库部署方式:0 集中式(单一服务器),1 分布式(主从服务器)
|
||||||
|
'deploy' => 0,
|
||||||
|
// 数据库读写是否分离 主从式有效
|
||||||
|
'rw_separate' => false,
|
||||||
|
// 读写分离后 主服务器数量
|
||||||
|
'master_num' => 1,
|
||||||
|
// 指定从服务器序号
|
||||||
|
'slave_no' => '',
|
||||||
|
// 是否严格检查字段是否存在
|
||||||
|
'fields_strict' => true,
|
||||||
|
// 数据集返回类型
|
||||||
|
'resultset_type' => 'array',
|
||||||
|
// 自动写入时间戳字段
|
||||||
|
'auto_timestamp' => false,
|
||||||
|
// 时间字段取出后的默认时间格式
|
||||||
|
'datetime_format' => 'Y-m-d H:i:s',
|
||||||
|
// 是否需要进行SQL性能分析
|
||||||
|
'sql_explain' => false,
|
||||||
|
];
|
||||||
|
```
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 连接字符串示例
|
||||||
|
|
||||||
|
### MySQL命令行连接
|
||||||
|
```bash
|
||||||
|
mysql -h 127.0.0.1 -u rootrui -p'X2)jB+k%YH.p' ruilai
|
||||||
|
```
|
||||||
|
|
||||||
|
### PDO连接字符串
|
||||||
|
```
|
||||||
|
mysql:host=127.0.0.1;dbname=ruilai;charset=utf8
|
||||||
|
```
|
||||||
|
|
||||||
|
### 连接信息摘要
|
||||||
|
- **Host:** 127.0.0.1
|
||||||
|
- **Database:** ruilai
|
||||||
|
- **User:** rootrui
|
||||||
|
- **Password:** X2)jB+k%YH.p
|
||||||
|
- **Charset:** utf8
|
||||||
|
- **Table Prefix:** t_sys_
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 注意事项
|
||||||
|
|
||||||
|
1. ⚠️ **数据库调试模式已开启** (`debug => true`),生产环境建议关闭
|
||||||
|
2. 📝 **表前缀为** `t_sys_`,查询时需注意表名格式
|
||||||
|
3. 🔒 **密码包含特殊字符**,使用命令行连接时需用引号包裹
|
||||||
|
4. 🌐 **字符集为utf8**,支持中文存储
|
||||||
|
5. 📊 **未启用读写分离**,适合单服务器部署
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**生成时间:** 2025年1月26日
|
||||||
|
**配置文件位置:** `/www/wwwroot/code/application/database.php`
|
||||||
926
(红头)生长激素缺乏预测模型项目需求文档.md
Normal file
926
(红头)生长激素缺乏预测模型项目需求文档.md
Normal file
@@ -0,0 +1,926 @@
|
|||||||
|
# 生长激素缺乏预测模型项目需求文档
|
||||||
|
|
||||||
|
**项目名称:** 生长激素缺乏(GHD)预测模型系统
|
||||||
|
**项目类型:** 医疗健康小程序 + 后台管理系统
|
||||||
|
**技术架构:** 微信小程序(前端)+ ThinkPHP 5.0(后端)
|
||||||
|
**数据库:** MySQL
|
||||||
|
**文档版本:** v1.0
|
||||||
|
**创建日期:** 2025年1月28日
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 一、项目概述
|
||||||
|
|
||||||
|
### 1.1 项目背景
|
||||||
|
|
||||||
|
生长激素缺乏(Growth Hormone Deficiency, GHD)是儿童内分泌疾病中的常见问题,早期诊断和预测对患者的治疗和预后具有重要意义。本项目旨在开发一个基于多因素分析的GHD预测模型系统,通过微信小程序为医生和患者提供便捷的预测工具,并通过后台管理系统进行数据管理和内容维护。
|
||||||
|
|
||||||
|
### 1.2 项目目标
|
||||||
|
|
||||||
|
1. **提供GHD预测功能**:基于骨龄、实际年龄、IGF-1、IGFBP-3等指标,计算GHD患病概率
|
||||||
|
2. **数据管理**:记录用户计算历史,便于医生和患者追踪
|
||||||
|
3. **资讯管理**:提供相关医疗资讯的发布和管理功能
|
||||||
|
4. **用户管理**:管理小程序注册用户信息
|
||||||
|
|
||||||
|
### 1.3 用户群体
|
||||||
|
|
||||||
|
- **主要用户**:医生、患者及其家属
|
||||||
|
- **管理员**:医疗机构的系统管理员
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 二、系统架构
|
||||||
|
|
||||||
|
### 2.1 技术架构
|
||||||
|
|
||||||
|
```
|
||||||
|
┌─────────────────┐
|
||||||
|
│ 微信小程序前端 │
|
||||||
|
│ (WeChat Mini │
|
||||||
|
│ Program) │
|
||||||
|
└────────┬────────┘
|
||||||
|
│ HTTP/HTTPS
|
||||||
|
│ API调用
|
||||||
|
┌────────▼────────┐
|
||||||
|
│ ThinkPHP 5.0 │
|
||||||
|
│ 后端服务 │
|
||||||
|
└────────┬────────┘
|
||||||
|
│
|
||||||
|
┌────────▼────────┐
|
||||||
|
│ MySQL数据库 │
|
||||||
|
└─────────────────┘
|
||||||
|
```
|
||||||
|
|
||||||
|
### 2.2 目录结构
|
||||||
|
|
||||||
|
```
|
||||||
|
/www/wwwroot/code/
|
||||||
|
├── application/ # 应用目录
|
||||||
|
│ ├── adminghd/ # 后台管理模块
|
||||||
|
│ │ ├── controller/ # 控制器
|
||||||
|
│ │ │ ├── Login.php # 登录控制器
|
||||||
|
│ │ │ ├── Menu.php # 菜单管理
|
||||||
|
│ │ │ ├── Wechatinfro.php # 微信用户信息管理
|
||||||
|
│ │ │ └── Wechatset.php # 微信设置管理
|
||||||
|
│ │ ├── model/ # 模型
|
||||||
|
│ │ └── view/ # 视图
|
||||||
|
│ ├── app/ # 小程序API模块
|
||||||
|
│ │ └── controller/
|
||||||
|
│ │ ├── Ghdwechat.php # GHD相关API
|
||||||
|
│ │ └── Ruilaiwechat.php # 瑞来相关API
|
||||||
|
│ └── database.php # 数据库配置
|
||||||
|
├── public/ # 公共访问目录
|
||||||
|
│ ├── index.php # 入口文件
|
||||||
|
│ └── static/ # 静态资源
|
||||||
|
├── szjs/ # 微信小程序源码
|
||||||
|
│ ├── pages/ # 小程序页面
|
||||||
|
│ │ ├── ghdCalculator/ # GHD计算器页面
|
||||||
|
│ │ ├── home/ # 首页
|
||||||
|
│ │ ├── my/ # 个人中心
|
||||||
|
│ │ └── ...
|
||||||
|
│ ├── app.js # 小程序入口
|
||||||
|
│ └── app.json # 小程序配置
|
||||||
|
└── thinkphp/ # ThinkPHP框架核心
|
||||||
|
```
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 三、功能需求
|
||||||
|
|
||||||
|
### 3.1 微信小程序功能
|
||||||
|
|
||||||
|
#### 3.1.1 GHD预测计算器
|
||||||
|
|
||||||
|
**功能描述:** 用户输入相关指标,系统自动计算GHD患病概率
|
||||||
|
|
||||||
|
**前端计算器输入参数:**
|
||||||
|
- **骨龄(BA)**:单位:年,支持小数
|
||||||
|
- **实际年龄(CA)**:单位:年,支持小数
|
||||||
|
- **IGF-1值**:单位:ng/ml,支持小数
|
||||||
|
- **IGFBP-3值**:单位:mg/L,支持小数
|
||||||
|
|
||||||
|
**后端API计算输入参数:**
|
||||||
|
- **用户ID(uid)**:必填
|
||||||
|
- **患者姓名(name)**:必填
|
||||||
|
- **年龄(age)**:必填,数字
|
||||||
|
- **身高(height)**:必填,数字
|
||||||
|
- **骨龄(bone_age)**:必填,数字
|
||||||
|
- **父亲身高(father_height)**:必填,数字
|
||||||
|
- **母亲身高(mother_height)**:必填,数字
|
||||||
|
- **IGF-1值(IGF)**:必填,数字,单位:ng/ml
|
||||||
|
- **LH值(LH)**:必填,数字,单位:mIU/ml
|
||||||
|
- **子宫厚度(uterus_thickness)**:必填,数字,单位:mm
|
||||||
|
|
||||||
|
**前端计算公式:**
|
||||||
|
```
|
||||||
|
Y = 3.726 - 0.876×(BA-CA) - 0.058×(IGF-1) + 0.229×(IGFBP-3)
|
||||||
|
P = e^Y / (1 + e^Y)
|
||||||
|
```
|
||||||
|
|
||||||
|
其中:
|
||||||
|
- Y:中间变量
|
||||||
|
- P:GHD预测概率(0-1之间)
|
||||||
|
- BA-CA:骨龄与实际年龄的差值
|
||||||
|
|
||||||
|
**后端API计算公式:**
|
||||||
|
```
|
||||||
|
P = exp(-5.908 + 0.008×IGF-1 + 2.146×LH + 0.286×子宫厚度) /
|
||||||
|
(1 + exp(-5.908 + 0.008×IGF-1 + 2.146×LH + 0.286×子宫厚度))
|
||||||
|
```
|
||||||
|
|
||||||
|
其中:
|
||||||
|
- P:GHD预测概率(0-1之间),保留3位小数
|
||||||
|
|
||||||
|
**输出结果:**
|
||||||
|
- GHD预测概率(百分比形式)
|
||||||
|
- 计算过程详情(分步骤展示)
|
||||||
|
- 结果解释和建议
|
||||||
|
|
||||||
|
**结果分级:**
|
||||||
|
- **P ≥ 0.8**:GHD可能性较大,建议进一步进行相关检查
|
||||||
|
- **0.5 ≤ P < 0.8**:存在GHD可能,建议进行相关检查
|
||||||
|
- **P < 0.5**:GHD可能性较小,但仍需结合临床表现进行综合判断
|
||||||
|
|
||||||
|
**参考范围:**
|
||||||
|
系统内置IGF-1和IGFBP-3的参考范围(按性别和年龄段):
|
||||||
|
- IGF-1参考范围(男性/女性,0-17岁,分9个年龄段)
|
||||||
|
- IGFBP-3参考范围(男性/女性,0-17岁,分9个年龄段)
|
||||||
|
|
||||||
|
#### 3.1.2 其他工具页面
|
||||||
|
|
||||||
|
根据小程序配置,还包含以下页面:
|
||||||
|
- **首页(home)**:展示资讯和功能入口
|
||||||
|
- **个人中心(my)**:用户信息、历史记录
|
||||||
|
- **IGF参考值(igfrefer)**:IGF-1和IGFBP-3参考范围查询
|
||||||
|
- **身高SDS计算器(heightSdsCalculator)**:身高标准差评分计算
|
||||||
|
- **工具集合(tool)**:其他医疗工具
|
||||||
|
- **性发育图表(sexChart)**:性发育相关图表
|
||||||
|
- **关于(guanyu)**:关于小程序的信息
|
||||||
|
|
||||||
|
#### 3.1.3 用户功能
|
||||||
|
|
||||||
|
- **微信授权登录**:
|
||||||
|
- 通过微信授权获取用户信息
|
||||||
|
- 接口:`/app/Ghdwechat/wechatLogin` 或 `/app/Ruilaiwechat/wechatLogin`
|
||||||
|
- 参数:`code`(微信登录code)、`encryptedData`(加密数据)、`iv`(初始向量)
|
||||||
|
- 返回:用户ID(uid)和登录状态
|
||||||
|
|
||||||
|
- **计算历史记录**:
|
||||||
|
- 查看历史计算记录:`/app/Ghdwechat/selectRecordList` 或 `/app/Ruilaiwechat/selectRecordList`
|
||||||
|
- 删除历史记录:`/app/Ghdwechat/deleteRecord` 或 `/app/Ruilaiwechat/deleteRecord`
|
||||||
|
- 支持分页查询(默认每页30条)
|
||||||
|
|
||||||
|
- **资讯浏览**:
|
||||||
|
- 获取资讯列表:`/app/Ghdwechat/selectRealtimeInfoList` 或 `/app/Ruilaiwechat/selectRealtimeInfoList`
|
||||||
|
- 支持分页查询(默认每页20条)
|
||||||
|
|
||||||
|
### 3.2 后台管理系统功能
|
||||||
|
|
||||||
|
#### 3.2.1 用户登录
|
||||||
|
|
||||||
|
**功能描述:** 管理员登录后台管理系统
|
||||||
|
|
||||||
|
**登录方式:**
|
||||||
|
- 用户名/手机号 + 密码登录
|
||||||
|
- Session会话管理(1小时有效期)
|
||||||
|
|
||||||
|
**权限控制:**
|
||||||
|
- 基于Session的用户身份验证
|
||||||
|
- 不同用户类型可能有不同权限(当前代码中部分权限检查被注释)
|
||||||
|
|
||||||
|
#### 3.2.2 微信用户管理
|
||||||
|
|
||||||
|
**功能描述:** 查看和管理小程序注册用户
|
||||||
|
|
||||||
|
**功能列表:**
|
||||||
|
- **用户列表查询**:
|
||||||
|
- 支持按昵称搜索
|
||||||
|
- 分页显示(默认每页30条)
|
||||||
|
- 显示字段:用户ID、昵称、头像、注册时间
|
||||||
|
- **用户信息查看**:查看用户详细信息
|
||||||
|
|
||||||
|
**数据表:** `ghd_wechat_user`
|
||||||
|
- `uid`:用户ID
|
||||||
|
- `nickname`:昵称
|
||||||
|
- `headimg`:头像
|
||||||
|
- `create_time`:注册时间
|
||||||
|
|
||||||
|
#### 3.2.3 计算记录管理
|
||||||
|
|
||||||
|
**功能描述:** 查看和管理用户的GHD预测计算记录
|
||||||
|
|
||||||
|
**功能列表:**
|
||||||
|
- **记录列表查询**:
|
||||||
|
- 支持按姓名搜索
|
||||||
|
- 分页显示(默认每页30条)
|
||||||
|
- 显示字段:序号、姓名、年龄、身高、骨龄、父亲身高、母亲身高、IGF、LH、子宫厚度、计算结果、创建时间
|
||||||
|
- **记录详情查看**:查看完整的计算记录详情
|
||||||
|
|
||||||
|
**数据表:** `wechat_calculate_record`
|
||||||
|
- `id`:记录ID
|
||||||
|
- `name`:姓名
|
||||||
|
- `age`:年龄
|
||||||
|
- `height`:身高
|
||||||
|
- `bone_age`:骨龄
|
||||||
|
- `father_height`:父亲身高
|
||||||
|
- `mother_height`:母亲身高
|
||||||
|
- `IGF`:IGF-1值
|
||||||
|
- `LH`:LH值
|
||||||
|
- `uterus_thickness`:子宫厚度
|
||||||
|
- `calculate_resutlt`:计算结果
|
||||||
|
- `create_time`:创建时间
|
||||||
|
|
||||||
|
#### 3.2.4 资讯管理
|
||||||
|
|
||||||
|
**功能描述:** 管理小程序中展示的医疗资讯
|
||||||
|
|
||||||
|
**功能列表:**
|
||||||
|
- **资讯列表**:
|
||||||
|
- 支持按标题搜索
|
||||||
|
- 分页显示(默认每页30条)
|
||||||
|
- 显示字段:标题、缩略图、简介、跳转链接、创建时间
|
||||||
|
- **添加资讯**:
|
||||||
|
- 标题(必填)
|
||||||
|
- 缩略图(必填)
|
||||||
|
- 简介(必填)
|
||||||
|
- 跳转链接(必填)
|
||||||
|
- **编辑资讯**:修改已有资讯信息
|
||||||
|
- **删除资讯**:删除不需要的资讯
|
||||||
|
|
||||||
|
**数据表:** `wechat_real_time_info`
|
||||||
|
- `id`:资讯ID
|
||||||
|
- `title_plain`:标题
|
||||||
|
- `thumbnail`:缩略图
|
||||||
|
- `excerpt_plain`:简介
|
||||||
|
- `url`:跳转链接
|
||||||
|
- `create_time`:创建时间
|
||||||
|
|
||||||
|
#### 3.2.5 菜单管理
|
||||||
|
|
||||||
|
**功能描述:** 管理系统菜单(当前部分功能被注释)
|
||||||
|
|
||||||
|
**功能列表:**
|
||||||
|
- 获取菜单列表
|
||||||
|
- 添加菜单
|
||||||
|
- 修改菜单
|
||||||
|
- 删除菜单
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 四、数据库设计
|
||||||
|
|
||||||
|
### 4.1 核心数据表
|
||||||
|
|
||||||
|
#### 4.1.1 用户表(t_sys_user)
|
||||||
|
|
||||||
|
**用途:** 存储后台管理员用户信息
|
||||||
|
|
||||||
|
**主要字段:**
|
||||||
|
- `id`:用户ID(主键)
|
||||||
|
- `user_name`:用户名
|
||||||
|
- `phone`:手机号(登录账号)
|
||||||
|
- `password`:密码(MD5加密)
|
||||||
|
- `user_head`:头像
|
||||||
|
- `status`:状态(1:启用,0:禁用)
|
||||||
|
- `type`:用户类型(1:管理员)
|
||||||
|
|
||||||
|
#### 4.1.2 微信用户表(ghd_wechat_user / wechat_user)
|
||||||
|
|
||||||
|
**用途:** 存储小程序注册用户信息
|
||||||
|
|
||||||
|
**主要字段:**
|
||||||
|
- `uid`:用户ID(主键,自增)
|
||||||
|
- `openid`:微信OpenID(唯一标识)
|
||||||
|
- `nickname`:昵称
|
||||||
|
- `headimg`:头像URL
|
||||||
|
- `create_time`:注册时间
|
||||||
|
|
||||||
|
**注意:** 代码中同时使用了 `ghd_wechat_user` 和 `wechat_user` 两个表名,需要确认实际使用的表名
|
||||||
|
|
||||||
|
#### 4.1.3 计算记录表(wechat_calculate_record)
|
||||||
|
|
||||||
|
**用途:** 存储用户的GHD预测计算记录
|
||||||
|
|
||||||
|
**主要字段:**
|
||||||
|
- `id`:记录ID(主键)
|
||||||
|
- `name`:姓名
|
||||||
|
- `age`:年龄
|
||||||
|
- `height`:身高
|
||||||
|
- `bone_age`:骨龄
|
||||||
|
- `father_height`:父亲身高
|
||||||
|
- `mother_height`:母亲身高
|
||||||
|
- `IGF`:IGF-1值
|
||||||
|
- `uid`:用户ID(关联微信用户)
|
||||||
|
- `LH`:LH值(促黄体生成素),单位:mIU/ml
|
||||||
|
- `uterus_thickness`:子宫厚度,单位:mm
|
||||||
|
- `calculate_resutlt`:计算结果(GHD概率,0-1之间,保留3位小数)
|
||||||
|
- `create_time`:创建时间
|
||||||
|
|
||||||
|
#### 4.1.4 资讯表(wechat_real_time_info)
|
||||||
|
|
||||||
|
**用途:** 存储小程序展示的医疗资讯
|
||||||
|
|
||||||
|
**主要字段:**
|
||||||
|
- `id`:资讯ID(主键,MD5生成)
|
||||||
|
- `title_plain`:标题
|
||||||
|
- `thumbnail`:缩略图URL
|
||||||
|
- `excerpt_plain`:简介
|
||||||
|
- `url`:跳转链接
|
||||||
|
- `create_time`:创建时间
|
||||||
|
|
||||||
|
#### 4.1.5 菜单表(t_sys_menu)
|
||||||
|
|
||||||
|
**用途:** 存储后台管理系统菜单
|
||||||
|
|
||||||
|
**主要字段:**
|
||||||
|
- `id`:菜单ID(主键)
|
||||||
|
- `pid`:父菜单ID
|
||||||
|
- `menu_name`:菜单名称
|
||||||
|
- `url`:菜单链接
|
||||||
|
- `menu_icon`:菜单图标
|
||||||
|
- `seq_on`:排序序号
|
||||||
|
- `create_time`:创建时间
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 五、API接口设计
|
||||||
|
|
||||||
|
### 5.1 小程序API接口
|
||||||
|
|
||||||
|
#### 5.1.1 用户相关接口
|
||||||
|
|
||||||
|
**接口路径:** `/app/Ghdwechat/xxx` 或 `/app/Ruilaiwechat/xxx`
|
||||||
|
|
||||||
|
**主要接口:**
|
||||||
|
- 用户登录/注册
|
||||||
|
- 获取用户信息
|
||||||
|
- 更新用户信息
|
||||||
|
|
||||||
|
#### 5.1.2 计算相关接口
|
||||||
|
|
||||||
|
**计算接口:**
|
||||||
|
- **接口路径:** `/app/Ghdwechat/calculate` 或 `/app/Ruilaiwechat/calculate`
|
||||||
|
- **请求方式:** POST
|
||||||
|
- **功能:** 提交计算参数,返回计算结果并保存记录
|
||||||
|
|
||||||
|
**请求参数:**
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"uid": "用户ID",
|
||||||
|
"name": "患者姓名",
|
||||||
|
"age": 10.5,
|
||||||
|
"height": 140,
|
||||||
|
"bone_age": 9.5,
|
||||||
|
"father_height": 175,
|
||||||
|
"mother_height": 160,
|
||||||
|
"IGF": 250,
|
||||||
|
"LH": 0.8,
|
||||||
|
"uterus_thickness": 10
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
**响应数据:**
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"erro": 0,
|
||||||
|
"msg": "计算成功",
|
||||||
|
"calculate_resutlt": 0.661
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
**错误响应:**
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"erro": -1,
|
||||||
|
"msg": "错误信息(如:未传入用户id、未传入姓名等)"
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
**历史记录查询接口:**
|
||||||
|
- **接口路径:** `/app/Ghdwechat/selectRecordList` 或 `/app/Ruilaiwechat/selectRecordList`
|
||||||
|
- **请求方式:** POST
|
||||||
|
- **请求参数:**
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"uid": "用户ID",
|
||||||
|
"page": 1,
|
||||||
|
"page_size": 30
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
**响应数据:**
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"erro": 0,
|
||||||
|
"msg": "查询成功",
|
||||||
|
"lists": [
|
||||||
|
{
|
||||||
|
"id": "记录ID",
|
||||||
|
"name": "患者姓名",
|
||||||
|
"age": 10.5,
|
||||||
|
"height": 140,
|
||||||
|
"bone_age": 9.5,
|
||||||
|
"father_height": 175,
|
||||||
|
"mother_height": 160,
|
||||||
|
"IGF": 250,
|
||||||
|
"LH": 0.8,
|
||||||
|
"uterus_thickness": 10,
|
||||||
|
"calculate_resutlt": 0.661,
|
||||||
|
"create_time": "2024-05-19 17:47:17"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"lastPage": 10,
|
||||||
|
"currentPage": 1
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
**删除记录接口:**
|
||||||
|
- **接口路径:** `/app/Ghdwechat/deleteRecord` 或 `/app/Ruilaiwechat/deleteRecord`
|
||||||
|
- **请求方式:** POST
|
||||||
|
- **请求参数:**
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"uid": "用户ID",
|
||||||
|
"id": "记录ID"
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
#### 5.1.3 资讯相关接口
|
||||||
|
|
||||||
|
**获取资讯列表:**
|
||||||
|
- **接口路径:** `/app/Ghdwechat/selectRealtimeInfoList` 或 `/app/Ruilaiwechat/selectRealtimeInfoList`
|
||||||
|
- **请求方式:** POST
|
||||||
|
- **请求参数:**
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"page": 1,
|
||||||
|
"page_size": 20
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
**响应数据:**
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"erro": 0,
|
||||||
|
"msg": "查询成功",
|
||||||
|
"lists": [
|
||||||
|
{
|
||||||
|
"title_plain": "资讯标题",
|
||||||
|
"thumbnail": "图片URL",
|
||||||
|
"excerpt_plain": "简介",
|
||||||
|
"url": "跳转链接"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"lastPage": 10,
|
||||||
|
"currentPage": 1
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
#### 5.1.4 用户登录接口
|
||||||
|
|
||||||
|
**微信授权登录:**
|
||||||
|
- **接口路径:** `/app/Ghdwechat/wechatLogin` 或 `/app/Ruilaiwechat/wechatLogin`
|
||||||
|
- **请求方式:** POST
|
||||||
|
- **请求参数:**
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"code": "微信登录code",
|
||||||
|
"encryptedData": "加密的用户数据",
|
||||||
|
"iv": "初始向量"
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
**响应数据:**
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"erro": 0,
|
||||||
|
"msg": "登录成功",
|
||||||
|
"uid": "用户ID"
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
**错误响应:**
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"erro": -1,
|
||||||
|
"msg": "错误信息(如:未传入code、解析数据失败等)"
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
### 5.2 后台管理API接口
|
||||||
|
|
||||||
|
#### 5.2.1 登录接口
|
||||||
|
|
||||||
|
**接口路径:** `/adminghd/Login/login`
|
||||||
|
|
||||||
|
**请求方式:** POST
|
||||||
|
|
||||||
|
**请求参数:**
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"username": "13212345678",
|
||||||
|
"password": "123456",
|
||||||
|
"loginsubmit": "true"
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
**响应数据:**
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"status": 1,
|
||||||
|
"msg": "登录成功",
|
||||||
|
"token": 1
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
#### 5.2.2 用户信息接口
|
||||||
|
|
||||||
|
**接口路径:** `/adminghd/Menu/getUserInfor`
|
||||||
|
|
||||||
|
**请求方式:** GET/POST
|
||||||
|
|
||||||
|
**响应数据:**
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"status": 1,
|
||||||
|
"msg": "查询成功",
|
||||||
|
"infro": {
|
||||||
|
"user_name": "管理员",
|
||||||
|
"user_head": null
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
#### 5.2.3 微信用户列表接口
|
||||||
|
|
||||||
|
**接口路径:** `/adminghd/Wechatinfro/getWechatUserList`
|
||||||
|
|
||||||
|
**请求方式:** POST
|
||||||
|
|
||||||
|
**请求参数:**
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"page": 1,
|
||||||
|
"page_size": 30,
|
||||||
|
"title": "搜索关键词(可选)"
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
**响应数据:**
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"erro": 0,
|
||||||
|
"msg": "查询成功",
|
||||||
|
"lists": [
|
||||||
|
{
|
||||||
|
"uid": "xxx",
|
||||||
|
"nickname": "用户昵称",
|
||||||
|
"headimg": "头像URL",
|
||||||
|
"create_time": "2024-05-19 17:47:17",
|
||||||
|
"no_id": 1
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"lastPage": 10,
|
||||||
|
"currentPage": 1
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
#### 5.2.4 计算记录列表接口
|
||||||
|
|
||||||
|
**接口路径:** `/adminghd/Wechatinfro/getWechatRecordList`
|
||||||
|
|
||||||
|
**请求方式:** POST
|
||||||
|
|
||||||
|
**请求参数:**
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"page": 1,
|
||||||
|
"page_size": 30,
|
||||||
|
"title": "搜索关键词(可选)"
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
**响应数据:**
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"erro": 0,
|
||||||
|
"msg": "查询成功",
|
||||||
|
"lists": [
|
||||||
|
{
|
||||||
|
"id": "xxx",
|
||||||
|
"name": "患者姓名",
|
||||||
|
"age": 10.5,
|
||||||
|
"height": 140,
|
||||||
|
"bone_age": 9.5,
|
||||||
|
"father_height": 175,
|
||||||
|
"mother_height": 160,
|
||||||
|
"IGF": 250,
|
||||||
|
"LH": 0.8,
|
||||||
|
"uterus_thickness": 10,
|
||||||
|
"calculate_resutlt": 0.661,
|
||||||
|
"create_time": "2024-05-19 17:47:17",
|
||||||
|
"no_id": 1
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"lastPage": 10,
|
||||||
|
"currentPage": 1
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
#### 5.2.5 资讯管理接口
|
||||||
|
|
||||||
|
**获取资讯列表:**
|
||||||
|
- **接口路径:** `/adminghd/Wechatset/getWechatRealTimeInfoList`
|
||||||
|
- **请求方式:** POST
|
||||||
|
|
||||||
|
**添加/更新资讯:**
|
||||||
|
- **接口路径:** `/adminghd/Wechatset/saveWechatRealTimeInfo`
|
||||||
|
- **请求方式:** POST
|
||||||
|
- **请求参数:**
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"id": "资讯ID(更新时必填)",
|
||||||
|
"title_plain": "标题",
|
||||||
|
"thumbnail": "缩略图URL",
|
||||||
|
"excerpt_plain": "简介",
|
||||||
|
"url": "跳转链接"
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
**删除资讯:**
|
||||||
|
- **接口路径:** `/adminghd/Wechatset/delWechatRealTimeInfo`
|
||||||
|
- **请求方式:** POST
|
||||||
|
- **请求参数:**
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"id": "资讯ID"
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 六、预测模型算法
|
||||||
|
|
||||||
|
### 6.1 GHD预测模型(小程序前端模型 - 基于骨龄和IGF指标)
|
||||||
|
|
||||||
|
**模型公式:**
|
||||||
|
```
|
||||||
|
Y = 3.726 - 0.876×(BA-CA) - 0.058×(IGF-1) + 0.229×(IGFBP-3)
|
||||||
|
P = e^Y / (1 + e^Y)
|
||||||
|
```
|
||||||
|
|
||||||
|
**参数说明:**
|
||||||
|
- **BA**:骨龄(Bone Age),单位:年
|
||||||
|
- **CA**:实际年龄(Chronological Age),单位:年
|
||||||
|
- **IGF-1**:胰岛素样生长因子-1,单位:ng/ml
|
||||||
|
- **IGFBP-3**:胰岛素样生长因子结合蛋白-3,单位:mg/L
|
||||||
|
- **Y**:中间变量(对数几率)
|
||||||
|
- **P**:GHD预测概率(0-1之间)
|
||||||
|
|
||||||
|
**计算步骤:**
|
||||||
|
1. 计算骨龄差值:BA-CA
|
||||||
|
2. 代入公式计算Y值
|
||||||
|
3. 通过Logistic函数计算概率P
|
||||||
|
4. 将P转换为百分比形式
|
||||||
|
|
||||||
|
**使用场景:** 小程序前端计算器页面(`ghdCalculator`),用于前端实时计算展示
|
||||||
|
|
||||||
|
### 6.2 GHD预测模型(后端API模型 - 基于IGF、LH和子宫厚度)
|
||||||
|
|
||||||
|
**模型公式:**
|
||||||
|
```
|
||||||
|
P = exp(-5.908 + 0.008×IGF-1 + 2.146×LH + 0.286×子宫厚度) /
|
||||||
|
(1 + exp(-5.908 + 0.008×IGF-1 + 2.146×LH + 0.286×子宫厚度))
|
||||||
|
```
|
||||||
|
|
||||||
|
**参数说明:**
|
||||||
|
- **IGF-1**:胰岛素样生长因子-1,单位:ng/ml
|
||||||
|
- **LH**:促黄体生成素(Luteinizing Hormone),单位:mIU/ml
|
||||||
|
- **子宫厚度**:单位:mm
|
||||||
|
- **P**:预测概率(0-1之间),保留3位小数
|
||||||
|
|
||||||
|
**计算步骤:**
|
||||||
|
1. 计算指数部分:exp(-5.908 + 0.008×IGF-1 + 2.146×LH + 0.286×子宫厚度)
|
||||||
|
2. 通过Logistic函数计算概率P
|
||||||
|
3. 将P四舍五入保留3位小数
|
||||||
|
|
||||||
|
**使用场景:** 后端API接口(`/app/Ghdwechat/calculate` 和 `/app/Ruilaiwechat/calculate`),用于服务器端计算并保存记录
|
||||||
|
|
||||||
|
**输入参数(后端API):**
|
||||||
|
- `uid`:用户ID(必填)
|
||||||
|
- `name`:患者姓名(必填)
|
||||||
|
- `age`:年龄(必填,数字)
|
||||||
|
- `height`:身高(必填,数字)
|
||||||
|
- `bone_age`:骨龄(必填,数字)
|
||||||
|
- `father_height`:父亲身高(必填,数字)
|
||||||
|
- `mother_height`:母亲身高(必填,数字)
|
||||||
|
- `IGF`:IGF-1值(必填,数字)
|
||||||
|
- `LH`:LH值(必填,数字)
|
||||||
|
- `uterus_thickness`:子宫厚度(必填,数字)
|
||||||
|
|
||||||
|
**输出结果:**
|
||||||
|
- `calculate_resutlt`:计算结果(概率值,0-1之间)
|
||||||
|
- 计算结果自动保存到数据库表 `wechat_calculate_record`
|
||||||
|
|
||||||
|
**注意:**
|
||||||
|
- 小程序前端和后端API使用不同的预测模型公式
|
||||||
|
- 前端模型基于骨龄和IGF指标,后端模型基于IGF、LH和子宫厚度
|
||||||
|
- 两个模型可能适用于不同的预测场景或患者群体
|
||||||
|
- 建议统一模型或明确说明两个模型的适用场景
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 七、非功能性需求
|
||||||
|
|
||||||
|
### 7.1 性能需求
|
||||||
|
|
||||||
|
- **响应时间**:API接口响应时间 < 500ms
|
||||||
|
- **并发支持**:支持至少100个并发用户
|
||||||
|
- **数据库查询**:优化查询性能,使用索引
|
||||||
|
|
||||||
|
### 7.2 安全需求
|
||||||
|
|
||||||
|
- **数据加密**:用户密码使用MD5加密存储
|
||||||
|
- **Session管理**:使用Session进行用户身份验证
|
||||||
|
- **HTTPS支持**:生产环境使用HTTPS协议
|
||||||
|
- **SQL注入防护**:使用ThinkPHP的ORM防止SQL注入
|
||||||
|
- **XSS防护**:对用户输入进行过滤和转义
|
||||||
|
|
||||||
|
### 7.3 可用性需求
|
||||||
|
|
||||||
|
- **系统可用性**:99%以上
|
||||||
|
- **数据备份**:定期备份数据库
|
||||||
|
- **错误处理**:友好的错误提示信息
|
||||||
|
|
||||||
|
### 7.4 兼容性需求
|
||||||
|
|
||||||
|
- **微信小程序**:支持微信小程序最新版本
|
||||||
|
- **浏览器**:后台管理系统支持主流浏览器(Chrome、Firefox、Safari、Edge)
|
||||||
|
- **移动端**:后台管理系统支持移动端访问
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 八、部署要求
|
||||||
|
|
||||||
|
### 8.1 服务器环境
|
||||||
|
|
||||||
|
- **操作系统**:Linux(CentOS 7+)
|
||||||
|
- **Web服务器**:Nginx 1.20+
|
||||||
|
- **PHP版本**:PHP 5.6+(推荐PHP 7.3+)
|
||||||
|
- **数据库**:MySQL 5.7+
|
||||||
|
- **PHP扩展**:mysqli、pdo_mysql、mbstring、openssl
|
||||||
|
|
||||||
|
### 8.2 目录权限
|
||||||
|
|
||||||
|
- `runtime/`:可写权限(日志、缓存)
|
||||||
|
- `public/uploads/`:可写权限(文件上传)
|
||||||
|
- `public/static/`:可读权限(静态资源)
|
||||||
|
|
||||||
|
### 8.3 配置文件
|
||||||
|
|
||||||
|
- **数据库配置**:`/www/wwwroot/code/application/database.php`
|
||||||
|
- **应用配置**:`/www/wwwroot/code/application/config.php`
|
||||||
|
- **Nginx配置**:`/etc/nginx/conf.d/default.conf` 或宝塔面板配置
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 九、项目现状
|
||||||
|
|
||||||
|
### 9.1 已完成功能
|
||||||
|
|
||||||
|
✅ **后台管理系统:**
|
||||||
|
- 用户登录功能
|
||||||
|
- 微信用户管理
|
||||||
|
- 计算记录管理
|
||||||
|
- 资讯管理
|
||||||
|
- 菜单管理(部分功能)
|
||||||
|
|
||||||
|
✅ **小程序前端:**
|
||||||
|
- GHD计算器页面
|
||||||
|
- 首页、个人中心等基础页面
|
||||||
|
- 计算逻辑实现
|
||||||
|
|
||||||
|
✅ **后端API:**
|
||||||
|
- 用户相关接口
|
||||||
|
- 计算记录接口
|
||||||
|
- 资讯接口
|
||||||
|
|
||||||
|
### 9.2 待完善功能
|
||||||
|
|
||||||
|
⏳ **数据验证:**
|
||||||
|
- 输入参数的范围验证
|
||||||
|
- 计算结果合理性检查
|
||||||
|
|
||||||
|
⏳ **用户体验:**
|
||||||
|
- 错误提示优化
|
||||||
|
- 加载状态提示
|
||||||
|
- 结果可视化展示
|
||||||
|
|
||||||
|
⏳ **功能扩展:**
|
||||||
|
- 计算历史记录查看(小程序端)
|
||||||
|
- 数据导出功能
|
||||||
|
- 统计分析功能
|
||||||
|
|
||||||
|
⏳ **文档完善:**
|
||||||
|
- API接口文档
|
||||||
|
- 用户使用手册
|
||||||
|
- 管理员操作手册
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 十、风险评估
|
||||||
|
|
||||||
|
### 10.1 技术风险
|
||||||
|
|
||||||
|
- **PHP版本兼容性**:当前使用PHP 5.6,建议升级到PHP 7.3+
|
||||||
|
- **数据库连接**:需要确保MySQL服务稳定运行
|
||||||
|
- **Session管理**:需要确保Session配置正确
|
||||||
|
|
||||||
|
### 10.2 业务风险
|
||||||
|
|
||||||
|
- **数据准确性**:预测模型需要定期验证和优化
|
||||||
|
- **医疗责任**:系统仅作为辅助工具,不能替代专业医疗诊断
|
||||||
|
- **数据隐私**:需要保护患者隐私信息
|
||||||
|
|
||||||
|
### 10.3 运维风险
|
||||||
|
|
||||||
|
- **数据备份**:需要建立定期备份机制
|
||||||
|
- **系统监控**:需要监控系统运行状态
|
||||||
|
- **安全更新**:需要及时更新安全补丁
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 十一、后续规划
|
||||||
|
|
||||||
|
### 11.1 短期规划(1-3个月)
|
||||||
|
|
||||||
|
1. **功能优化**:
|
||||||
|
- 完善输入验证
|
||||||
|
- 优化用户界面
|
||||||
|
- 添加计算历史功能
|
||||||
|
|
||||||
|
2. **性能优化**:
|
||||||
|
- 数据库查询优化
|
||||||
|
- 缓存机制引入
|
||||||
|
- 接口响应时间优化
|
||||||
|
|
||||||
|
3. **文档完善**:
|
||||||
|
- 编写API文档
|
||||||
|
- 编写用户手册
|
||||||
|
|
||||||
|
### 11.2 中期规划(3-6个月)
|
||||||
|
|
||||||
|
1. **功能扩展**:
|
||||||
|
- 多模型支持
|
||||||
|
- 数据统计分析
|
||||||
|
- 报告生成功能
|
||||||
|
|
||||||
|
2. **技术升级**:
|
||||||
|
- PHP版本升级
|
||||||
|
- 框架版本升级
|
||||||
|
- 前端框架优化
|
||||||
|
|
||||||
|
### 11.3 长期规划(6-12个月)
|
||||||
|
|
||||||
|
1. **智能化**:
|
||||||
|
- 机器学习模型集成
|
||||||
|
- 个性化推荐
|
||||||
|
- 智能诊断辅助
|
||||||
|
|
||||||
|
2. **平台化**:
|
||||||
|
- 多租户支持
|
||||||
|
- 开放API平台
|
||||||
|
- 第三方集成
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 十二、附录
|
||||||
|
|
||||||
|
### 12.1 术语表
|
||||||
|
|
||||||
|
- **GHD**:Growth Hormone Deficiency,生长激素缺乏
|
||||||
|
- **IGF-1**:Insulin-like Growth Factor-1,胰岛素样生长因子-1
|
||||||
|
- **IGFBP-3**:Insulin-like Growth Factor Binding Protein-3,胰岛素样生长因子结合蛋白-3
|
||||||
|
- **BA**:Bone Age,骨龄
|
||||||
|
- **CA**:Chronological Age,实际年龄
|
||||||
|
- **LH**:Luteinizing Hormone,促黄体生成素
|
||||||
|
|
||||||
|
### 12.2 参考文档
|
||||||
|
|
||||||
|
- ThinkPHP 5.0 官方文档:http://www.kancloud.cn/manual/thinkphp5
|
||||||
|
- 微信小程序开发文档:https://developers.weixin.qq.com/miniprogram/dev/framework/
|
||||||
|
- MySQL官方文档:https://dev.mysql.com/doc/
|
||||||
|
|
||||||
|
### 12.3 联系方式
|
||||||
|
|
||||||
|
- **项目地址**:`/www/wwwroot/code`
|
||||||
|
- **后台管理地址**:`https://www.ruilaizipj.com/adminghd/login`
|
||||||
|
- **数据库**:MySQL (`ruilai`)
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**文档结束**
|
||||||
|
|
||||||
|
**创建时间:** 2025年1月28日
|
||||||
|
**最后更新:** 2025年1月28日
|
||||||
|
**文档版本:** v1.0
|
||||||
BIN
admin_pic.png
Normal file
BIN
admin_pic.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 1.6 MiB |
77
application/admin/controller/Dashboard.php
Normal file
77
application/admin/controller/Dashboard.php
Normal file
@@ -0,0 +1,77 @@
|
|||||||
|
<?php
|
||||||
|
namespace app\admin\controller;
|
||||||
|
|
||||||
|
use app\admin\common\Base;
|
||||||
|
use think\Db;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 系统概览控制器
|
||||||
|
* 早熟预测后台独立实现,不再依赖common模块
|
||||||
|
*/
|
||||||
|
class Dashboard extends Base
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* 后台首页概览
|
||||||
|
*/
|
||||||
|
public function index()
|
||||||
|
{
|
||||||
|
return $this->view->fetch('dashboard/index');
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 获取统计数据
|
||||||
|
* admin模块独立实现,使用wechat_user表
|
||||||
|
*/
|
||||||
|
public function getStatistics()
|
||||||
|
{
|
||||||
|
try {
|
||||||
|
// admin模块使用的表名(固定)
|
||||||
|
$userTable = 'wechat_user';
|
||||||
|
$infoTable = 'wechat_real_time_info';
|
||||||
|
$recordTable = 'wechat_calculate_record';
|
||||||
|
|
||||||
|
// 小程序注册用户数量
|
||||||
|
$userCount = Db::name($userTable)->count();
|
||||||
|
|
||||||
|
// 首页资讯数量
|
||||||
|
$infoCount = Db::name($infoTable)->count();
|
||||||
|
|
||||||
|
// 最近一次计算时间
|
||||||
|
$lastCalculate = Db::name($recordTable)
|
||||||
|
->order('create_time desc')
|
||||||
|
->value('create_time');
|
||||||
|
|
||||||
|
// 今日新增用户
|
||||||
|
$todayUserCount = Db::name($userTable)
|
||||||
|
->whereTime('create_time', 'today')
|
||||||
|
->count();
|
||||||
|
|
||||||
|
// 总计算次数
|
||||||
|
$totalCalculateCount = Db::name($recordTable)->count();
|
||||||
|
|
||||||
|
return json([
|
||||||
|
'status' => 1,
|
||||||
|
'msg' => '获取成功',
|
||||||
|
'data' => [
|
||||||
|
'user_count' => $userCount,
|
||||||
|
'info_count' => $infoCount,
|
||||||
|
'last_calculate_time' => $lastCalculate ?: '暂无',
|
||||||
|
'today_user_count' => $todayUserCount,
|
||||||
|
'total_calculate_count' => $totalCalculateCount
|
||||||
|
]
|
||||||
|
]);
|
||||||
|
} catch (\Exception $e) {
|
||||||
|
return json([
|
||||||
|
'status' => 0,
|
||||||
|
'msg' => '获取失败:' . $e->getMessage(),
|
||||||
|
'data' => [
|
||||||
|
'user_count' => 0,
|
||||||
|
'info_count' => 0,
|
||||||
|
'last_calculate_time' => '暂无',
|
||||||
|
'today_user_count' => 0,
|
||||||
|
'total_calculate_count' => 0
|
||||||
|
]
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
138
application/admin/view/dashboard/index.html
Normal file
138
application/admin/view/dashboard/index.html
Normal file
@@ -0,0 +1,138 @@
|
|||||||
|
<!DOCTYPE html>
|
||||||
|
<html>
|
||||||
|
<head>
|
||||||
|
<meta charset="utf-8">
|
||||||
|
<meta name="renderer" content="webkit|ie-comp|ie-stand">
|
||||||
|
<meta http-equiv="X-UA-Compatible" content="IE=edge">
|
||||||
|
<meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no">
|
||||||
|
<title>系统概览</title>
|
||||||
|
<link rel="stylesheet" href="/static/admin/layui/css/layui.css">
|
||||||
|
<style>
|
||||||
|
body{
|
||||||
|
background:#f5f7fb;
|
||||||
|
padding:24px 24px 40px;
|
||||||
|
box-sizing:border-box;
|
||||||
|
font-family:"Microsoft YaHei",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
|
||||||
|
}
|
||||||
|
.dash-card{
|
||||||
|
background:#fff;
|
||||||
|
border-radius:10px;
|
||||||
|
box-shadow:0 10px 30px rgba(15,35,52,0.06);
|
||||||
|
padding:20px 24px;
|
||||||
|
margin-bottom:20px;
|
||||||
|
}
|
||||||
|
.dash-title{
|
||||||
|
font-size:18px;
|
||||||
|
font-weight:600;
|
||||||
|
color:#1f2d3d;
|
||||||
|
margin-bottom:4px;
|
||||||
|
}
|
||||||
|
.dash-sub{
|
||||||
|
font-size:12px;
|
||||||
|
color:#9aa4b1;
|
||||||
|
margin-bottom:18px;
|
||||||
|
}
|
||||||
|
.dash-grid{
|
||||||
|
display:flex;
|
||||||
|
flex-wrap:wrap;
|
||||||
|
gap:16px;
|
||||||
|
}
|
||||||
|
.dash-item{
|
||||||
|
flex:1 1 200px;
|
||||||
|
min-width:200px;
|
||||||
|
background:#f8fafc;
|
||||||
|
border-radius:8px;
|
||||||
|
padding:14px 16px;
|
||||||
|
cursor:pointer;
|
||||||
|
transition:all 0.3s;
|
||||||
|
}
|
||||||
|
.dash-item:hover{
|
||||||
|
background:#f0f4f8;
|
||||||
|
transform:translateY(-2px);
|
||||||
|
box-shadow:0 4px 12px rgba(15,35,52,0.1);
|
||||||
|
}
|
||||||
|
.dash-item-label{
|
||||||
|
font-size:13px;
|
||||||
|
color:#9aa4b1;
|
||||||
|
}
|
||||||
|
.dash-item-value{
|
||||||
|
margin-top:6px;
|
||||||
|
font-size:22px;
|
||||||
|
font-weight:600;
|
||||||
|
color:#1f2d3d;
|
||||||
|
}
|
||||||
|
.dash-item-desc{
|
||||||
|
margin-top:4px;
|
||||||
|
font-size:12px;
|
||||||
|
color:#b0b7c3;
|
||||||
|
}
|
||||||
|
.dash-empty{
|
||||||
|
margin-top:10px;
|
||||||
|
font-size:13px;
|
||||||
|
color:#9aa4b1;
|
||||||
|
}
|
||||||
|
.loading{
|
||||||
|
text-align:center;
|
||||||
|
padding:40px;
|
||||||
|
color:#9aa4b1;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
<div class="dash-card">
|
||||||
|
<div class="dash-title">欢迎使用后台管理系统</div>
|
||||||
|
<div class="dash-sub">这里是系统概览,实时展示系统统计数据。</div>
|
||||||
|
<div class="dash-grid" id="dashGrid">
|
||||||
|
<div class="loading">数据加载中...</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<script src="/static/admin/js/jquery.js"></script>
|
||||||
|
<script>
|
||||||
|
$(function(){
|
||||||
|
// 加载统计数据
|
||||||
|
loadStatistics();
|
||||||
|
|
||||||
|
function loadStatistics(){
|
||||||
|
$.ajax({
|
||||||
|
url: '/admin/Dashboard/getStatistics',
|
||||||
|
type: 'post',
|
||||||
|
dataType: 'json',
|
||||||
|
success: function(res){
|
||||||
|
if(res.status == 1){
|
||||||
|
renderStatistics(res.data);
|
||||||
|
} else {
|
||||||
|
$('#dashGrid').html('<div class="loading">数据加载失败:' + res.msg + '</div>');
|
||||||
|
}
|
||||||
|
},
|
||||||
|
error: function(){
|
||||||
|
$('#dashGrid').html('<div class="loading">数据加载失败,请稍后重试</div>');
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
function renderStatistics(data){
|
||||||
|
var html = `
|
||||||
|
<div class="dash-item" onclick="parent.location.href='/admin/wechatinfro/wechatUserList'">
|
||||||
|
<div class="dash-item-label">小程序注册用户</div>
|
||||||
|
<div class="dash-item-value">${data.user_count}</div>
|
||||||
|
<div class="dash-item-desc">今日新增:${data.today_user_count} 人</div>
|
||||||
|
</div>
|
||||||
|
<div class="dash-item" onclick="parent.location.href='/admin/wechatset/wechatRealTimeInfo'">
|
||||||
|
<div class="dash-item-label">首页资讯数量</div>
|
||||||
|
<div class="dash-item-value">${data.info_count}</div>
|
||||||
|
<div class="dash-item-desc">可在「咨询管理」菜单中维护展示内容</div>
|
||||||
|
</div>
|
||||||
|
<div class="dash-item" onclick="parent.location.href='/admin/wechatinfro/wechatRecordList'">
|
||||||
|
<div class="dash-item-label">总计算次数</div>
|
||||||
|
<div class="dash-item-value">${data.total_calculate_count}</div>
|
||||||
|
<div class="dash-item-desc">最近一次:${data.last_calculate_time}</div>
|
||||||
|
</div>
|
||||||
|
`;
|
||||||
|
$('#dashGrid').html(html);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
</script>
|
||||||
|
</body>
|
||||||
|
</html>
|
||||||
|
|
||||||
@@ -18,7 +18,7 @@
|
|||||||
<div style='background:#e3e3e3;height:450px;width:100%;position:relative;'>
|
<div style='background:#e3e3e3;height:450px;width:100%;position:relative;'>
|
||||||
<div style='width:350px;height:400px;background:#EDF1F5;float:right;margin-right:20%;margin-top:1.5%;box-shadow:#666 0px 0px 20px;'>
|
<div style='width:350px;height:400px;background:#EDF1F5;float:right;margin-right:20%;margin-top:1.5%;box-shadow:#666 0px 0px 20px;'>
|
||||||
<div class="login-top" style="padding-bottom:0;">
|
<div class="login-top" style="padding-bottom:0;">
|
||||||
<div style='color:#453A3E;margin:30px auto 10px auto;width:150px;font-size:18px;font-weight:bold;text-align:center;'>瑞莱医疗</div>
|
<div style='color:#453A3E;margin:30px auto 10px auto;width:auto;max-width:90%;font-size:16px;font-weight:bold;text-align:center;padding:0 10px;'>女童成长发育早熟预测模型后台</div>
|
||||||
</div>
|
</div>
|
||||||
<div style='height:1px;width:100%;background:#DEDCDD;'>
|
<div style='height:1px;width:100%;background:#DEDCDD;'>
|
||||||
<div style='background:#e3e3e3;height:3px;width:80%;margin:0px auto 0 auto;'></div>
|
<div style='background:#e3e3e3;height:3px;width:80%;margin:0px auto 0 auto;'></div>
|
||||||
|
|||||||
@@ -5,7 +5,7 @@
|
|||||||
<meta http-equiv="X-UA-Compatible" content="IE=edge">
|
<meta http-equiv="X-UA-Compatible" content="IE=edge">
|
||||||
<meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no">
|
<meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no">
|
||||||
<meta http-equiv="Cache-Control" content="no-siteapp">
|
<meta http-equiv="Cache-Control" content="no-siteapp">
|
||||||
<title>瑞莱医疗后台</title>
|
<title>女童成长发育早熟预测模型后台</title>
|
||||||
|
|
||||||
<link rel="stylesheet" href="/static/admin/layui/css/layui.css?t=1554901097999" media="all">
|
<link rel="stylesheet" href="/static/admin/layui/css/layui.css?t=1554901097999" media="all">
|
||||||
<link rel="stylesheet" type="text/css" href="/static/admin/css/nav.css" />
|
<link rel="stylesheet" type="text/css" href="/static/admin/css/nav.css" />
|
||||||
@@ -33,17 +33,9 @@
|
|||||||
</div>
|
</div>
|
||||||
<!--顶部-->
|
<!--顶部-->
|
||||||
<div class="top_right">
|
<div class="top_right">
|
||||||
<a href="javascript:void(0)" class="logo">
|
<div class="header_title">女童成长发育早熟预测模型后台</div>
|
||||||
<!-- <img id="packBtn" src="{S_URL}/templates/adminfactory/img/logo.png">-->
|
|
||||||
</a>
|
|
||||||
<b></b>
|
|
||||||
<div class="user_right">
|
<div class="user_right">
|
||||||
<a href="javascript:;" id="user" style="position: absolute;left: 100px;top: 4px;font-size: 16px;"></a>
|
<span id="inform"></span>
|
||||||
<span id="inform">
|
|
||||||
<!-- 您好!工厂
|
|
||||||
<img id="u_headimg" src="{S_URL}/templates/adminfactory/img/logo.png" alt="">
|
|
||||||
<i>荣麟</i> -->
|
|
||||||
</span>
|
|
||||||
<b class="out" id="sign_out">退出</b>
|
<b class="out" id="sign_out">退出</b>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
@@ -9,10 +9,9 @@ use think\Response;
|
|||||||
class Base extends Controller
|
class Base extends Controller
|
||||||
{
|
{
|
||||||
protected function _initialize()
|
protected function _initialize()
|
||||||
{var_dump(1111);exit;
|
{
|
||||||
if(!session('adminghd_user_id')){//没有登录信息
|
if(!session('adminghd_user_id')){//没有登录信息
|
||||||
// $this->redirect('login/index');
|
// $this->redirect('login/index');
|
||||||
var_dump(url('Login/logoutJump'));exit;
|
|
||||||
return $this->error('您还未登录',url('Login/logoutJump'));
|
return $this->error('您还未登录',url('Login/logoutJump'));
|
||||||
//Response::create(['status' => '0','msg'=> '还未登录,验证失败'], 'json')->send();
|
//Response::create(['status' => '0','msg'=> '还未登录,验证失败'], 'json')->send();
|
||||||
exit;
|
exit;
|
||||||
|
|||||||
77
application/adminghd/controller/Dashboard.php
Normal file
77
application/adminghd/controller/Dashboard.php
Normal file
@@ -0,0 +1,77 @@
|
|||||||
|
<?php
|
||||||
|
namespace app\adminghd\controller;
|
||||||
|
|
||||||
|
use app\adminghd\common\Base;
|
||||||
|
use think\Db;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 系统概览控制器
|
||||||
|
* GHD预测后台独立实现,不再依赖common模块
|
||||||
|
*/
|
||||||
|
class Dashboard extends Base
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* 后台首页概览
|
||||||
|
*/
|
||||||
|
public function index()
|
||||||
|
{
|
||||||
|
return $this->view->fetch('dashboard/index');
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 获取统计数据
|
||||||
|
* adminghd模块独立实现,使用ghd_wechat_user表
|
||||||
|
*/
|
||||||
|
public function getStatistics()
|
||||||
|
{
|
||||||
|
try {
|
||||||
|
// adminghd模块使用的表名(固定)
|
||||||
|
$userTable = 'ghd_wechat_user';
|
||||||
|
$infoTable = 'wechat_real_time_info';
|
||||||
|
$recordTable = 'wechat_calculate_record';
|
||||||
|
|
||||||
|
// 小程序注册用户数量
|
||||||
|
$userCount = Db::name($userTable)->count();
|
||||||
|
|
||||||
|
// 首页资讯数量
|
||||||
|
$infoCount = Db::name($infoTable)->count();
|
||||||
|
|
||||||
|
// 最近一次计算时间
|
||||||
|
$lastCalculate = Db::name($recordTable)
|
||||||
|
->order('create_time desc')
|
||||||
|
->value('create_time');
|
||||||
|
|
||||||
|
// 今日新增用户
|
||||||
|
$todayUserCount = Db::name($userTable)
|
||||||
|
->whereTime('create_time', 'today')
|
||||||
|
->count();
|
||||||
|
|
||||||
|
// 总计算次数
|
||||||
|
$totalCalculateCount = Db::name($recordTable)->count();
|
||||||
|
|
||||||
|
return json([
|
||||||
|
'status' => 1,
|
||||||
|
'msg' => '获取成功',
|
||||||
|
'data' => [
|
||||||
|
'user_count' => $userCount,
|
||||||
|
'info_count' => $infoCount,
|
||||||
|
'last_calculate_time' => $lastCalculate ?: '暂无',
|
||||||
|
'today_user_count' => $todayUserCount,
|
||||||
|
'total_calculate_count' => $totalCalculateCount
|
||||||
|
]
|
||||||
|
]);
|
||||||
|
} catch (\Exception $e) {
|
||||||
|
return json([
|
||||||
|
'status' => 0,
|
||||||
|
'msg' => '获取失败:' . $e->getMessage(),
|
||||||
|
'data' => [
|
||||||
|
'user_count' => 0,
|
||||||
|
'info_count' => 0,
|
||||||
|
'last_calculate_time' => '暂无',
|
||||||
|
'today_user_count' => 0,
|
||||||
|
'total_calculate_count' => 0
|
||||||
|
]
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
138
application/adminghd/view/dashboard/index.html
Normal file
138
application/adminghd/view/dashboard/index.html
Normal file
@@ -0,0 +1,138 @@
|
|||||||
|
<!DOCTYPE html>
|
||||||
|
<html>
|
||||||
|
<head>
|
||||||
|
<meta charset="utf-8">
|
||||||
|
<meta name="renderer" content="webkit|ie-comp|ie-stand">
|
||||||
|
<meta http-equiv="X-UA-Compatible" content="IE=edge">
|
||||||
|
<meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no">
|
||||||
|
<title>系统概览</title>
|
||||||
|
<link rel="stylesheet" href="/static/adminghd/layui/css/layui.css">
|
||||||
|
<style>
|
||||||
|
body{
|
||||||
|
background:#f5f7fb;
|
||||||
|
padding:24px 24px 40px;
|
||||||
|
box-sizing:border-box;
|
||||||
|
font-family:"Microsoft YaHei",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
|
||||||
|
}
|
||||||
|
.dash-card{
|
||||||
|
background:#fff;
|
||||||
|
border-radius:10px;
|
||||||
|
box-shadow:0 10px 30px rgba(15,35,52,0.06);
|
||||||
|
padding:20px 24px;
|
||||||
|
margin-bottom:20px;
|
||||||
|
}
|
||||||
|
.dash-title{
|
||||||
|
font-size:18px;
|
||||||
|
font-weight:600;
|
||||||
|
color:#1f2d3d;
|
||||||
|
margin-bottom:4px;
|
||||||
|
}
|
||||||
|
.dash-sub{
|
||||||
|
font-size:12px;
|
||||||
|
color:#9aa4b1;
|
||||||
|
margin-bottom:18px;
|
||||||
|
}
|
||||||
|
.dash-grid{
|
||||||
|
display:flex;
|
||||||
|
flex-wrap:wrap;
|
||||||
|
gap:16px;
|
||||||
|
}
|
||||||
|
.dash-item{
|
||||||
|
flex:1 1 200px;
|
||||||
|
min-width:200px;
|
||||||
|
background:#f8fafc;
|
||||||
|
border-radius:8px;
|
||||||
|
padding:14px 16px;
|
||||||
|
cursor:pointer;
|
||||||
|
transition:all 0.3s;
|
||||||
|
}
|
||||||
|
.dash-item:hover{
|
||||||
|
background:#f0f4f8;
|
||||||
|
transform:translateY(-2px);
|
||||||
|
box-shadow:0 4px 12px rgba(15,35,52,0.1);
|
||||||
|
}
|
||||||
|
.dash-item-label{
|
||||||
|
font-size:13px;
|
||||||
|
color:#9aa4b1;
|
||||||
|
}
|
||||||
|
.dash-item-value{
|
||||||
|
margin-top:6px;
|
||||||
|
font-size:22px;
|
||||||
|
font-weight:600;
|
||||||
|
color:#1f2d3d;
|
||||||
|
}
|
||||||
|
.dash-item-desc{
|
||||||
|
margin-top:4px;
|
||||||
|
font-size:12px;
|
||||||
|
color:#b0b7c3;
|
||||||
|
}
|
||||||
|
.dash-empty{
|
||||||
|
margin-top:10px;
|
||||||
|
font-size:13px;
|
||||||
|
color:#9aa4b1;
|
||||||
|
}
|
||||||
|
.loading{
|
||||||
|
text-align:center;
|
||||||
|
padding:40px;
|
||||||
|
color:#9aa4b1;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
<div class="dash-card">
|
||||||
|
<div class="dash-title">欢迎使用后台管理系统</div>
|
||||||
|
<div class="dash-sub">这里是系统概览,实时展示系统统计数据。</div>
|
||||||
|
<div class="dash-grid" id="dashGrid">
|
||||||
|
<div class="loading">数据加载中...</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<script src="/static/adminghd/js/jquery.js"></script>
|
||||||
|
<script>
|
||||||
|
$(function(){
|
||||||
|
// 加载统计数据
|
||||||
|
loadStatistics();
|
||||||
|
|
||||||
|
function loadStatistics(){
|
||||||
|
$.ajax({
|
||||||
|
url: '/adminghd/Dashboard/getStatistics',
|
||||||
|
type: 'post',
|
||||||
|
dataType: 'json',
|
||||||
|
success: function(res){
|
||||||
|
if(res.status == 1){
|
||||||
|
renderStatistics(res.data);
|
||||||
|
} else {
|
||||||
|
$('#dashGrid').html('<div class="loading">数据加载失败:' + res.msg + '</div>');
|
||||||
|
}
|
||||||
|
},
|
||||||
|
error: function(){
|
||||||
|
$('#dashGrid').html('<div class="loading">数据加载失败,请稍后重试</div>');
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
function renderStatistics(data){
|
||||||
|
var html = `
|
||||||
|
<div class="dash-item" onclick="parent.location.href='/adminghd/wechatinfro/wechatUserList'">
|
||||||
|
<div class="dash-item-label">小程序注册用户</div>
|
||||||
|
<div class="dash-item-value">${data.user_count}</div>
|
||||||
|
<div class="dash-item-desc">今日新增:${data.today_user_count} 人</div>
|
||||||
|
</div>
|
||||||
|
<div class="dash-item" onclick="parent.location.href='/adminghd/wechatset/wechatRealTimeInfo'">
|
||||||
|
<div class="dash-item-label">首页资讯数量</div>
|
||||||
|
<div class="dash-item-value">${data.info_count}</div>
|
||||||
|
<div class="dash-item-desc">可在「咨询管理」菜单中维护展示内容</div>
|
||||||
|
</div>
|
||||||
|
<div class="dash-item" onclick="parent.location.href='/adminghd/wechatinfro/wechatRecordList'">
|
||||||
|
<div class="dash-item-label">总计算次数</div>
|
||||||
|
<div class="dash-item-value">${data.total_calculate_count}</div>
|
||||||
|
<div class="dash-item-desc">最近一次:${data.last_calculate_time}</div>
|
||||||
|
</div>
|
||||||
|
`;
|
||||||
|
$('#dashGrid').html(html);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
</script>
|
||||||
|
</body>
|
||||||
|
</html>
|
||||||
|
|
||||||
@@ -18,7 +18,7 @@
|
|||||||
<div style='background:#e3e3e3;height:450px;width:100%;position:relative;'>
|
<div style='background:#e3e3e3;height:450px;width:100%;position:relative;'>
|
||||||
<div style='width:350px;height:400px;background:#EDF1F5;float:right;margin-right:20%;margin-top:1.5%;box-shadow:#666 0px 0px 20px;'>
|
<div style='width:350px;height:400px;background:#EDF1F5;float:right;margin-right:20%;margin-top:1.5%;box-shadow:#666 0px 0px 20px;'>
|
||||||
<div class="login-top" style="padding-bottom:0;">
|
<div class="login-top" style="padding-bottom:0;">
|
||||||
<div style='color:#453A3E;margin:30px auto 10px auto;width:150px;font-size:18px;font-weight:bold;text-align:center;'>瑞莱医疗</div>
|
<div style='color:#453A3E;margin:30px auto 10px auto;width:auto;max-width:90%;font-size:16px;font-weight:bold;text-align:center;padding:0 10px;'>生长激素缺乏预测模型后台</div>
|
||||||
</div>
|
</div>
|
||||||
<div style='height:1px;width:100%;background:#DEDCDD;'>
|
<div style='height:1px;width:100%;background:#DEDCDD;'>
|
||||||
<div style='background:#e3e3e3;height:3px;width:80%;margin:0px auto 0 auto;'></div>
|
<div style='background:#e3e3e3;height:3px;width:80%;margin:0px auto 0 auto;'></div>
|
||||||
|
|||||||
@@ -5,7 +5,7 @@
|
|||||||
<meta http-equiv="X-UA-Compatible" content="IE=edge">
|
<meta http-equiv="X-UA-Compatible" content="IE=edge">
|
||||||
<meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no">
|
<meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no">
|
||||||
<meta http-equiv="Cache-Control" content="no-siteapp">
|
<meta http-equiv="Cache-Control" content="no-siteapp">
|
||||||
<title>瑞莱医疗后台</title>
|
<title>生长激素缺乏预测模型后台</title>
|
||||||
|
|
||||||
<link rel="stylesheet" href="/static/adminghd/layui/css/layui.css?t=1554901097999" media="all">
|
<link rel="stylesheet" href="/static/adminghd/layui/css/layui.css?t=1554901097999" media="all">
|
||||||
<link rel="stylesheet" type="text/css" href="/static/adminghd/css/nav.css" />
|
<link rel="stylesheet" type="text/css" href="/static/adminghd/css/nav.css" />
|
||||||
@@ -33,22 +33,14 @@
|
|||||||
</div>
|
</div>
|
||||||
<!--顶部-->
|
<!--顶部-->
|
||||||
<div class="top_right">
|
<div class="top_right">
|
||||||
<a href="javascript:void(0)" class="logo">
|
<div class="header_title">生长激素缺乏预测模型后台</div>
|
||||||
<!-- <img id="packBtn" src="{S_URL}/templates/adminfactory/img/logo.png">-->
|
|
||||||
</a>
|
|
||||||
<b></b>
|
|
||||||
<div class="user_right">
|
<div class="user_right">
|
||||||
<a href="javascript:;" id="user" style="position: absolute;left: 100px;top: 4px;font-size: 16px;"></a>
|
<span id="inform"></span>
|
||||||
<span id="inform">
|
|
||||||
<!-- 您好!工厂
|
|
||||||
<img id="u_headimg" src="{S_URL}/templates/adminfactory/img/logo.png" alt="">
|
|
||||||
<i>荣麟</i> -->
|
|
||||||
</span>
|
|
||||||
<b class="out" id="sign_out">退出</b>
|
<b class="out" id="sign_out">退出</b>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="main_content">
|
<div class="main_content">
|
||||||
<iframe id="iframeId" src="" frameborder="0"></iframe>
|
<iframe id="iframeId" src="/adminghd/Dashboard/index" frameborder="0"></iframe>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<script src="/static/adminghd/js/jquery.js" type="text/javascript" charset="utf-8"></script>
|
<script src="/static/adminghd/js/jquery.js" type="text/javascript" charset="utf-8"></script>
|
||||||
|
|||||||
71
application/common/common/BaseController.php
Normal file
71
application/common/common/BaseController.php
Normal file
@@ -0,0 +1,71 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* 公共基础控制器
|
||||||
|
* 统一处理登录验证和业务类型识别
|
||||||
|
*/
|
||||||
|
namespace app\common\common;
|
||||||
|
|
||||||
|
use think\Controller;
|
||||||
|
use think\Session;
|
||||||
|
use app\common\config\BusinessConfig;
|
||||||
|
|
||||||
|
class BaseController extends Controller
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* 当前业务类型
|
||||||
|
* @var string
|
||||||
|
*/
|
||||||
|
protected $businessType;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 数据表映射
|
||||||
|
* @var array
|
||||||
|
*/
|
||||||
|
protected $tableMap;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 初始化
|
||||||
|
*/
|
||||||
|
protected function _initialize()
|
||||||
|
{
|
||||||
|
// 获取业务类型
|
||||||
|
$this->businessType = BusinessConfig::getBusinessTypeByModule();
|
||||||
|
$this->tableMap = BusinessConfig::getTableMap($this->businessType);
|
||||||
|
|
||||||
|
// 验证登录
|
||||||
|
$this->checkLogin();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 检查登录状态
|
||||||
|
*/
|
||||||
|
protected function checkLogin()
|
||||||
|
{
|
||||||
|
$sessionKey = BusinessConfig::getSessionKey($this->businessType);
|
||||||
|
$loginTimeKey = BusinessConfig::getLoginTimeKey($this->businessType);
|
||||||
|
|
||||||
|
if (!session($sessionKey)) {
|
||||||
|
// 没有登录信息
|
||||||
|
return $this->error('您还未登录', url('Login/logoutJump'));
|
||||||
|
exit;
|
||||||
|
} else {
|
||||||
|
// 登录信息超时
|
||||||
|
$logTime = session($loginTimeKey) - time();
|
||||||
|
if ($logTime < 0) {
|
||||||
|
Session::clear();
|
||||||
|
return $this->error('登录超时', url('Login/logoutJump'));
|
||||||
|
exit;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 获取数据表名
|
||||||
|
* @param string $tableKey 表键名
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
protected function getTableName($tableKey)
|
||||||
|
{
|
||||||
|
return isset($this->tableMap[$tableKey]) ? $this->tableMap[$tableKey] : $tableKey;
|
||||||
|
}
|
||||||
|
}
|
||||||
92
application/common/config/BusinessConfig.php
Normal file
92
application/common/config/BusinessConfig.php
Normal file
@@ -0,0 +1,92 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* 业务配置类
|
||||||
|
* 用于区分不同小程序业务的数据表映射
|
||||||
|
*/
|
||||||
|
namespace app\common\config;
|
||||||
|
|
||||||
|
class BusinessConfig
|
||||||
|
{
|
||||||
|
// 业务类型常量
|
||||||
|
const BUSINESS_ADMIN = 'admin'; // 通用后台
|
||||||
|
const BUSINESS_ADMINGHD = 'adminghd'; // GHD项目后台
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 获取业务类型对应的数据表映射
|
||||||
|
* @param string $businessType 业务类型
|
||||||
|
* @return array
|
||||||
|
*/
|
||||||
|
public static function getTableMap($businessType)
|
||||||
|
{
|
||||||
|
$maps = [
|
||||||
|
self::BUSINESS_ADMIN => [
|
||||||
|
'user' => 'wechat_user',
|
||||||
|
'real_time_info' => 'wechat_real_time_info',
|
||||||
|
'calculate_record' => 'wechat_calculate_record',
|
||||||
|
],
|
||||||
|
self::BUSINESS_ADMINGHD => [
|
||||||
|
'user' => 'ghd_wechat_user',
|
||||||
|
'real_time_info' => 'wechat_real_time_info',
|
||||||
|
'calculate_record' => 'wechat_calculate_record',
|
||||||
|
],
|
||||||
|
];
|
||||||
|
|
||||||
|
return isset($maps[$businessType]) ? $maps[$businessType] : $maps[self::BUSINESS_ADMIN];
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 获取业务类型对应的Session标识
|
||||||
|
* @param string $businessType 业务类型
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public static function getSessionKey($businessType)
|
||||||
|
{
|
||||||
|
$keys = [
|
||||||
|
self::BUSINESS_ADMIN => 'admin_user_id',
|
||||||
|
self::BUSINESS_ADMINGHD => 'adminghd_user_id',
|
||||||
|
];
|
||||||
|
|
||||||
|
return isset($keys[$businessType]) ? $keys[$businessType] : 'admin_user_id';
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 获取业务类型对应的登录时间Session标识
|
||||||
|
* @param string $businessType 业务类型
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public static function getLoginTimeKey($businessType)
|
||||||
|
{
|
||||||
|
$keys = [
|
||||||
|
self::BUSINESS_ADMIN => 'admin_user_login_time',
|
||||||
|
self::BUSINESS_ADMINGHD => 'adminghd_user_login_time',
|
||||||
|
];
|
||||||
|
|
||||||
|
return isset($keys[$businessType]) ? $keys[$businessType] : 'admin_user_login_time';
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 根据当前模块名获取业务类型
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public static function getBusinessTypeByModule()
|
||||||
|
{
|
||||||
|
$module = request()->module();
|
||||||
|
return $module === 'adminghd' ? self::BUSINESS_ADMINGHD : self::BUSINESS_ADMIN;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 获取数据表名
|
||||||
|
* @param string $tableKey 表键名(user, real_time_info, calculate_record)
|
||||||
|
* @param string|null $businessType 业务类型,为空则自动检测
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public static function getTableName($tableKey, $businessType = null)
|
||||||
|
{
|
||||||
|
if ($businessType === null) {
|
||||||
|
$businessType = self::getBusinessTypeByModule();
|
||||||
|
}
|
||||||
|
|
||||||
|
$map = self::getTableMap($businessType);
|
||||||
|
return isset($map[$tableKey]) ? $map[$tableKey] : $tableKey;
|
||||||
|
}
|
||||||
|
}
|
||||||
68
application/common/controller/DashboardBase.php
Normal file
68
application/common/controller/DashboardBase.php
Normal file
@@ -0,0 +1,68 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* 系统概览公共控制器
|
||||||
|
* 提供统一的业务逻辑,供admin和adminghd模块继承使用
|
||||||
|
*/
|
||||||
|
namespace app\common\controller;
|
||||||
|
|
||||||
|
use app\common\common\BaseController;
|
||||||
|
use think\Db;
|
||||||
|
|
||||||
|
class DashboardBase extends BaseController
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* 获取统计数据
|
||||||
|
*/
|
||||||
|
public function getStatistics()
|
||||||
|
{
|
||||||
|
try {
|
||||||
|
// 获取表名
|
||||||
|
$userTable = $this->getTableName('user');
|
||||||
|
$infoTable = $this->getTableName('real_time_info');
|
||||||
|
$recordTable = $this->getTableName('calculate_record');
|
||||||
|
|
||||||
|
// 小程序注册用户数量
|
||||||
|
$userCount = Db::name($userTable)->count();
|
||||||
|
|
||||||
|
// 首页资讯数量
|
||||||
|
$infoCount = Db::name($infoTable)->count();
|
||||||
|
|
||||||
|
// 最近一次计算时间
|
||||||
|
$lastCalculate = Db::name($recordTable)
|
||||||
|
->order('create_time desc')
|
||||||
|
->value('create_time');
|
||||||
|
|
||||||
|
// 今日新增用户
|
||||||
|
$todayUserCount = Db::name($userTable)
|
||||||
|
->whereTime('create_time', 'today')
|
||||||
|
->count();
|
||||||
|
|
||||||
|
// 总计算次数
|
||||||
|
$totalCalculateCount = Db::name($recordTable)->count();
|
||||||
|
|
||||||
|
return json([
|
||||||
|
'status' => 1,
|
||||||
|
'msg' => '获取成功',
|
||||||
|
'data' => [
|
||||||
|
'user_count' => $userCount,
|
||||||
|
'info_count' => $infoCount,
|
||||||
|
'last_calculate_time' => $lastCalculate ?: '暂无',
|
||||||
|
'today_user_count' => $todayUserCount,
|
||||||
|
'total_calculate_count' => $totalCalculateCount
|
||||||
|
]
|
||||||
|
]);
|
||||||
|
} catch (\Exception $e) {
|
||||||
|
return json([
|
||||||
|
'status' => 0,
|
||||||
|
'msg' => '获取失败:' . $e->getMessage(),
|
||||||
|
'data' => [
|
||||||
|
'user_count' => 0,
|
||||||
|
'info_count' => 0,
|
||||||
|
'last_calculate_time' => '暂无',
|
||||||
|
'today_user_count' => 0,
|
||||||
|
'total_calculate_count' => 0
|
||||||
|
]
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
100
application/common/controller/WechatinfroBase.php
Normal file
100
application/common/controller/WechatinfroBase.php
Normal file
@@ -0,0 +1,100 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* 微信用户信息管理公共控制器
|
||||||
|
* 提供统一的业务逻辑,供admin和adminghd模块继承使用
|
||||||
|
*/
|
||||||
|
namespace app\common\controller;
|
||||||
|
|
||||||
|
use app\common\common\BaseController;
|
||||||
|
use think\Request;
|
||||||
|
use think\Db;
|
||||||
|
|
||||||
|
class WechatinfroBase extends BaseController
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* 查看小程序注册用户信息
|
||||||
|
* @author hjc
|
||||||
|
* @date 2024-05-14
|
||||||
|
*/
|
||||||
|
public function getWechatUserList(Request $request)
|
||||||
|
{
|
||||||
|
$post = $request->param();
|
||||||
|
|
||||||
|
$page = isset($post['page']) && !empty($post['page']) ? $post['page'] : 1; // 页数
|
||||||
|
$page_size = isset($post['page_size']) && !empty($post['page_size']) ? $post['page_size'] : 30; // 每页条数
|
||||||
|
|
||||||
|
// 搜索
|
||||||
|
$where = [];
|
||||||
|
if (isset($post['title']) && !empty($post['title'])) {
|
||||||
|
$where['nickname'] = ['like', '%' . $post['title'] . '%'];
|
||||||
|
}
|
||||||
|
|
||||||
|
// 获取用户表名
|
||||||
|
$tableName = $this->getTableName('user');
|
||||||
|
|
||||||
|
// 升序获取菜单列表
|
||||||
|
$res = Db::name($tableName)
|
||||||
|
->field('uid,nickname,headimg,create_time')
|
||||||
|
->where($where)
|
||||||
|
->order('create_time desc')
|
||||||
|
->paginate($page_size, false, ['page' => $page]);
|
||||||
|
|
||||||
|
$lists = $res->items();
|
||||||
|
$start = ($page - 1) * $page_size;
|
||||||
|
foreach ($lists as $k => $v) {
|
||||||
|
$start += 1;
|
||||||
|
$lists[$k]['no_id'] = $start;
|
||||||
|
}
|
||||||
|
|
||||||
|
$result['lists'] = $lists;
|
||||||
|
$result['lastPage'] = $res->lastPage(); // 总页数
|
||||||
|
$result['currentPage'] = $res->currentPage(); // 当前页
|
||||||
|
$result['erro'] = 0;
|
||||||
|
$result['msg'] = '查询成功';
|
||||||
|
return json($result);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 查看小程序记录
|
||||||
|
* @author hjc
|
||||||
|
* @date 2024-05-14
|
||||||
|
*/
|
||||||
|
public function getWechatRecordList(Request $request)
|
||||||
|
{
|
||||||
|
$post = $request->param();
|
||||||
|
|
||||||
|
$page = isset($post['page']) && !empty($post['page']) ? $post['page'] : 1; // 页数
|
||||||
|
$page_size = isset($post['page_size']) && !empty($post['page_size']) ? $post['page_size'] : 30; // 每页条数
|
||||||
|
|
||||||
|
// 搜索
|
||||||
|
$where = [];
|
||||||
|
if (isset($post['title']) && !empty($post['title'])) {
|
||||||
|
$where['name'] = ['like', '%' . $post['title'] . '%'];
|
||||||
|
}
|
||||||
|
|
||||||
|
// 获取计算记录表名
|
||||||
|
$tableName = $this->getTableName('calculate_record');
|
||||||
|
|
||||||
|
// 查询列表
|
||||||
|
$res = Db::name($tableName)
|
||||||
|
->field('id,name,age,height,bone_age,father_height,mother_height,IGF,LH,uterus_thickness,calculate_resutlt,create_time')
|
||||||
|
->where($where)
|
||||||
|
->order('create_time desc')
|
||||||
|
->paginate($page_size, false, ['page' => $page]);
|
||||||
|
|
||||||
|
$lists = $res->items();
|
||||||
|
$start = ($page - 1) * $page_size;
|
||||||
|
foreach ($lists as $k => $v) {
|
||||||
|
$start += 1;
|
||||||
|
$lists[$k]['no_id'] = $start;
|
||||||
|
}
|
||||||
|
|
||||||
|
$result = array();
|
||||||
|
$result['lists'] = $lists;
|
||||||
|
$result['lastPage'] = $res->lastPage(); // 总页数
|
||||||
|
$result['currentPage'] = $res->currentPage(); // 当前页
|
||||||
|
$result['erro'] = 0;
|
||||||
|
$result['msg'] = '查询成功';
|
||||||
|
return json($result);
|
||||||
|
}
|
||||||
|
}
|
||||||
169
application/common/controller/WechatsetBase.php
Normal file
169
application/common/controller/WechatsetBase.php
Normal file
@@ -0,0 +1,169 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* 微信设置管理公共控制器
|
||||||
|
* 提供统一的业务逻辑,供admin和adminghd模块继承使用
|
||||||
|
*/
|
||||||
|
namespace app\common\controller;
|
||||||
|
|
||||||
|
use app\common\common\BaseController;
|
||||||
|
use think\Request;
|
||||||
|
use think\Db;
|
||||||
|
|
||||||
|
class WechatsetBase extends BaseController
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* 查询小程序资讯信息
|
||||||
|
* @author hjc
|
||||||
|
* @date 2024-05-14
|
||||||
|
*/
|
||||||
|
public function getWechatRealTimeInfoList(Request $request)
|
||||||
|
{
|
||||||
|
$post = $request->param();
|
||||||
|
|
||||||
|
$page = isset($post['page']) && !empty($post['page']) ? $post['page'] : 1; // 页数
|
||||||
|
$page_size = isset($post['page_size']) && !empty($post['page_size']) ? $post['page_size'] : 30; // 每页条数
|
||||||
|
|
||||||
|
// 搜索
|
||||||
|
$where = [];
|
||||||
|
if (isset($post['title']) && !empty($post['title'])) {
|
||||||
|
$where['title_plain'] = ['like', '%' . $post['title'] . '%'];
|
||||||
|
}
|
||||||
|
|
||||||
|
// 获取资讯表名
|
||||||
|
$tableName = $this->getTableName('real_time_info');
|
||||||
|
|
||||||
|
// 升序获取菜单列表
|
||||||
|
$res = Db::name($tableName)
|
||||||
|
->field('id,title_plain,thumbnail,excerpt_plain,url,create_time')
|
||||||
|
->where($where)
|
||||||
|
->order('create_time desc')
|
||||||
|
->paginate($page_size, false, ['page' => $page]);
|
||||||
|
|
||||||
|
$lists = $res->items();
|
||||||
|
$start = ($page - 1) * $page_size;
|
||||||
|
foreach ($lists as $k => $v) {
|
||||||
|
$start += 1;
|
||||||
|
$lists[$k]['no_id'] = $start;
|
||||||
|
}
|
||||||
|
|
||||||
|
$result['lists'] = $lists;
|
||||||
|
$result['lastPage'] = $res->lastPage(); // 总页数
|
||||||
|
$result['currentPage'] = $res->currentPage(); // 当前页
|
||||||
|
$result['erro'] = 0;
|
||||||
|
$result['msg'] = '查询成功';
|
||||||
|
return json($result);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 删除小程序资讯信息
|
||||||
|
* @author hjc
|
||||||
|
* @date 2024-05-14
|
||||||
|
*/
|
||||||
|
public function delWechatRealTimeInfo(Request $request)
|
||||||
|
{
|
||||||
|
$post = $request->param();
|
||||||
|
if (!isset($post['id']) || empty($post['id'])) {
|
||||||
|
$result['erro'] = -1;
|
||||||
|
$result['msg'] = "请选择要删除的记录";
|
||||||
|
return json($result);
|
||||||
|
}
|
||||||
|
|
||||||
|
$tableName = $this->getTableName('real_time_info');
|
||||||
|
$id = Db::name($tableName)->where('id', $post['id'])->value('id');
|
||||||
|
|
||||||
|
if (empty($id)) {
|
||||||
|
$result['erro'] = -1;
|
||||||
|
$result['msg'] = "该记录异常,无法删除";
|
||||||
|
return json($result);
|
||||||
|
}
|
||||||
|
|
||||||
|
$res = Db::name($tableName)->where('id', $id)->delete();
|
||||||
|
if ($res > 0) {
|
||||||
|
$result['erro'] = 0;
|
||||||
|
$result['msg'] = '删除成功';
|
||||||
|
} else {
|
||||||
|
$result['erro'] = -1;
|
||||||
|
$result['msg'] = '删除失败';
|
||||||
|
}
|
||||||
|
return json($result);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 保存小程序资讯信息
|
||||||
|
* @author hjc
|
||||||
|
*/
|
||||||
|
public function saveWechatRealTimeInfo(Request $request)
|
||||||
|
{
|
||||||
|
$post = $request->param();
|
||||||
|
|
||||||
|
if (!isset($post['title_plain']) || empty($post['title_plain'])) {
|
||||||
|
$result['erro'] = -1;
|
||||||
|
$result['msg'] = "未传入标题";
|
||||||
|
return json($result);
|
||||||
|
}
|
||||||
|
if (!isset($post['thumbnail']) || empty($post['thumbnail'])) {
|
||||||
|
$result['erro'] = -1;
|
||||||
|
$result['msg'] = "未传入图片";
|
||||||
|
return json($result);
|
||||||
|
}
|
||||||
|
if (!isset($post['excerpt_plain']) || empty($post['excerpt_plain'])) {
|
||||||
|
$result['erro'] = -1;
|
||||||
|
$result['msg'] = "未传入简介";
|
||||||
|
return json($result);
|
||||||
|
}
|
||||||
|
if (!isset($post['url']) || empty($post['url'])) {
|
||||||
|
$result['erro'] = -1;
|
||||||
|
$result['msg'] = "未传入资讯跳转链接";
|
||||||
|
return json($result);
|
||||||
|
}
|
||||||
|
|
||||||
|
// 提交数据
|
||||||
|
$data = [];
|
||||||
|
$data['title_plain'] = $post['title_plain']; // 标题
|
||||||
|
$data['thumbnail'] = $post['thumbnail']; // 图片
|
||||||
|
$data['excerpt_plain'] = $post['excerpt_plain']; // 介绍
|
||||||
|
$data['url'] = $post['url']; // 跳转连接
|
||||||
|
|
||||||
|
$tableName = $this->getTableName('real_time_info');
|
||||||
|
|
||||||
|
if (isset($post['id']) && !empty($post['id'])) {
|
||||||
|
// 修改数据
|
||||||
|
$res = Db::name($tableName)->where('id', $post['id'])->update($data);
|
||||||
|
} else {
|
||||||
|
// 保存记录数据
|
||||||
|
$data['id'] = md5(time() . rand(100000, 999999));
|
||||||
|
$data['create_time'] = date('Y-m-d H:i:s');
|
||||||
|
$res = Db::name($tableName)->insert($data);
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($res === false) {
|
||||||
|
$result['erro'] = -1;
|
||||||
|
$result['msg'] = "添加失败";
|
||||||
|
return json($result);
|
||||||
|
} else {
|
||||||
|
$result['erro'] = 0;
|
||||||
|
$result['msg'] = "添加成功";
|
||||||
|
return json($result);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 查询资讯信息详情
|
||||||
|
* @author hjc
|
||||||
|
*/
|
||||||
|
public function getRealTimeInfoDetail(Request $request)
|
||||||
|
{
|
||||||
|
$post = $request->param();
|
||||||
|
if (!isset($post['id']) || empty($post['id'])) {
|
||||||
|
$result['erro'] = -1;
|
||||||
|
$result['msg'] = "未传入资讯id";
|
||||||
|
return json($result);
|
||||||
|
}
|
||||||
|
|
||||||
|
$tableName = $this->getTableName('real_time_info');
|
||||||
|
$result['infro'] = Db::name($tableName)->where('id', $post['id'])->find();
|
||||||
|
$result['erro'] = 0;
|
||||||
|
$result['msg'] = "查询成功";
|
||||||
|
return json($result);
|
||||||
|
}
|
||||||
|
}
|
||||||
105
合并优化说明.md
Normal file
105
合并优化说明.md
Normal file
@@ -0,0 +1,105 @@
|
|||||||
|
# 两套后台合并优化说明
|
||||||
|
|
||||||
|
## 优化目标
|
||||||
|
将 `admin` 和 `adminghd` 两套后台的重复代码进行合并,通过统一的架构减少代码冗余,提高可维护性。
|
||||||
|
|
||||||
|
## 优化成果
|
||||||
|
|
||||||
|
### 1. 创建公共配置类
|
||||||
|
**文件**: `application/common/config/BusinessConfig.php`
|
||||||
|
|
||||||
|
- 统一管理业务类型配置
|
||||||
|
- 提供数据表映射(`wechat_user` vs `ghd_wechat_user`)
|
||||||
|
- 提供Session标识映射(`admin_user_id` vs `adminghd_user_id`)
|
||||||
|
- 自动根据模块名识别业务类型
|
||||||
|
|
||||||
|
### 2. 创建公共基础控制器
|
||||||
|
**文件**: `application/common/common/BaseController.php`
|
||||||
|
|
||||||
|
- 统一处理登录验证逻辑
|
||||||
|
- 自动识别业务类型并加载对应的数据表映射
|
||||||
|
- 提供 `getTableName()` 方法,自动获取正确的数据表名
|
||||||
|
|
||||||
|
### 3. 创建公共业务控制器
|
||||||
|
**文件**:
|
||||||
|
- `application/common/controller/WechatinfroBase.php` - 微信用户信息管理
|
||||||
|
- `application/common/controller/WechatsetBase.php` - 微信设置管理
|
||||||
|
- `application/common/controller/DashboardBase.php` - 系统概览
|
||||||
|
|
||||||
|
**功能**:
|
||||||
|
- 统一的业务逻辑实现
|
||||||
|
- 自动使用正确的数据表(通过 `getTableName()` 方法)
|
||||||
|
- 减少重复代码约 **70%**
|
||||||
|
|
||||||
|
### 4. 重构模块控制器
|
||||||
|
**修改文件**:
|
||||||
|
- `application/admin/controller/Wechatinfro.php`
|
||||||
|
- `application/admin/controller/Wechatset.php`
|
||||||
|
- `application/admin/controller/Dashboard.php`
|
||||||
|
- `application/adminghd/controller/Wechatinfro.php`
|
||||||
|
- `application/adminghd/controller/Wechatset.php`
|
||||||
|
- `application/adminghd/controller/Dashboard.php`
|
||||||
|
|
||||||
|
**改进**:
|
||||||
|
- 继承公共控制器,代码量减少 **80%**
|
||||||
|
- 只保留视图渲染方法,业务逻辑全部复用
|
||||||
|
|
||||||
|
### 5. 统一Base类
|
||||||
|
**修改文件**:
|
||||||
|
- `application/admin/common/Base.php`
|
||||||
|
- `application/adminghd/common/Base.php`
|
||||||
|
|
||||||
|
**改进**:
|
||||||
|
- 继承公共 `BaseController`
|
||||||
|
- 自动处理业务类型识别和登录验证
|
||||||
|
- 修复了 `adminghd` 模块中的调试代码问题
|
||||||
|
|
||||||
|
## 代码减少统计
|
||||||
|
|
||||||
|
### 控制器代码减少
|
||||||
|
- **Wechatinfro**: 从 ~105 行减少到 ~25 行(减少 76%)
|
||||||
|
- **Wechatset**: 从 ~183 行减少到 ~30 行(减少 84%)
|
||||||
|
- **Dashboard**: 从 ~68 行减少到 ~12 行(减少 82%)
|
||||||
|
|
||||||
|
### 总体效果
|
||||||
|
- **总代码行数减少**: 约 **600+ 行**
|
||||||
|
- **重复代码消除**: 约 **90%**
|
||||||
|
- **维护成本降低**: 修改业务逻辑只需在一个地方进行
|
||||||
|
|
||||||
|
## 架构优势
|
||||||
|
|
||||||
|
1. **单一职责**: 公共控制器只负责业务逻辑,模块控制器只负责视图渲染
|
||||||
|
2. **易于扩展**: 新增业务类型只需在 `BusinessConfig` 中添加配置
|
||||||
|
3. **向后兼容**: 保持两套后台的访问路径不变(`/admin/` 和 `/adminghd/`)
|
||||||
|
4. **数据隔离**: 通过配置自动使用不同的数据表,保证数据隔离
|
||||||
|
|
||||||
|
## 使用说明
|
||||||
|
|
||||||
|
### 添加新的业务类型
|
||||||
|
1. 在 `BusinessConfig.php` 中添加新的业务类型常量
|
||||||
|
2. 在 `getTableMap()` 方法中添加数据表映射
|
||||||
|
3. 在 `getSessionKey()` 方法中添加Session标识映射
|
||||||
|
|
||||||
|
### 添加新的公共业务逻辑
|
||||||
|
1. 在 `application/common/controller/` 下创建新的公共控制器
|
||||||
|
2. 继承 `BaseController`,使用 `getTableName()` 获取数据表名
|
||||||
|
3. 在模块控制器中继承公共控制器
|
||||||
|
|
||||||
|
## 注意事项
|
||||||
|
|
||||||
|
1. **静态资源**: CSS和JS文件保持独立,因为路径不同(`/admin/` vs `/adminghd/`)
|
||||||
|
2. **视图文件**: 视图文件保持独立,因为可能有个性化需求
|
||||||
|
3. **登录控制器**: 登录逻辑保持独立,因为Session标识不同
|
||||||
|
|
||||||
|
## 后续优化建议
|
||||||
|
|
||||||
|
1. **统一静态资源**: 可以考虑通过动态变量统一CSS/JS路径
|
||||||
|
2. **统一视图模板**: 如果视图完全一致,可以考虑使用公共视图
|
||||||
|
3. **API统一**: 可以考虑将API接口也进行统一管理
|
||||||
|
|
||||||
|
## 测试建议
|
||||||
|
|
||||||
|
1. 测试 `admin` 模块的所有功能是否正常
|
||||||
|
2. 测试 `adminghd` 模块的所有功能是否正常
|
||||||
|
3. 验证数据表是否正确使用(`wechat_user` vs `ghd_wechat_user`)
|
||||||
|
4. 验证Session是否正确隔离
|
||||||
822
后台文档.md
Normal file
822
后台文档.md
Normal file
@@ -0,0 +1,822 @@
|
|||||||
|
# 后台管理系统文档
|
||||||
|
|
||||||
|
**项目名称:** 瑞莱医疗后台管理系统
|
||||||
|
**技术架构:** ThinkPHP 5.0 + Layui + jQuery
|
||||||
|
**数据库:** MySQL
|
||||||
|
**文档版本:** v2.0
|
||||||
|
**创建日期:** 2025年1月28日
|
||||||
|
**最后更新:** 2025年1月29日(已完成逻辑彻底分离)
|
||||||
|
|
||||||
|
> **✅ 分离状态:** 两个后台模块已实现**逻辑彻底分离**(方案一),可独立维护,互不影响。
|
||||||
|
> - **admin 模块**:早熟预测后台,完全独立实现
|
||||||
|
> - **adminghd 模块**:GHD预测后台,完全独立实现
|
||||||
|
> - 两个模块不再依赖 `common` 模块的业务基类
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 一、系统概述
|
||||||
|
|
||||||
|
### 1.1 系统简介
|
||||||
|
|
||||||
|
本系统为两个医疗小程序提供统一的后台管理服务:
|
||||||
|
|
||||||
|
1. **女童成长发育早熟预测模型后台** (`admin` 模块)
|
||||||
|
- 对应小程序:瑞莱医疗小程序
|
||||||
|
- 小程序AppID: `wx0847525a15342a46`
|
||||||
|
- 访问路径:`/admin/`
|
||||||
|
|
||||||
|
2. **生长激素缺乏预测模型后台** (`adminghd` 模块)
|
||||||
|
- 对应小程序:生长激素缺乏(GHD)预测模型小程序
|
||||||
|
- 小程序AppID: `wxa75a76964ae7ce73`
|
||||||
|
- 访问路径:`/adminghd/`
|
||||||
|
|
||||||
|
### 1.2 系统架构
|
||||||
|
|
||||||
|
```
|
||||||
|
┌─────────────────────────────────────────┐
|
||||||
|
│ 后台管理系统 │
|
||||||
|
├─────────────────────────────────────────┤
|
||||||
|
│ admin模块 adminghd模块 │
|
||||||
|
│ (早熟预测) (GHD预测) │
|
||||||
|
├─────────────────────────────────────────┤
|
||||||
|
│ 共同功能: │
|
||||||
|
│ - 登录认证 │
|
||||||
|
│ - 菜单管理 │
|
||||||
|
│ - 资讯管理 │
|
||||||
|
│ - 用户管理 │
|
||||||
|
│ - 计算记录管理 │
|
||||||
|
└─────────────────────────────────────────┘
|
||||||
|
```
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 二、系统架构
|
||||||
|
|
||||||
|
### 2.1 目录结构
|
||||||
|
|
||||||
|
```
|
||||||
|
/www/wwwroot/code/
|
||||||
|
├── application/ # 应用目录
|
||||||
|
│ ├── admin/ # 早熟预测后台模块
|
||||||
|
│ │ ├── controller/ # 控制器
|
||||||
|
│ │ │ ├── Login.php # 登录控制器
|
||||||
|
│ │ │ ├── Menu.php # 菜单管理
|
||||||
|
│ │ │ ├── Wechatset.php # 资讯管理
|
||||||
|
│ │ │ ├── Wechatinfro.php # 用户和记录管理
|
||||||
|
│ │ │ └── Dashboard.php # 仪表盘
|
||||||
|
│ │ ├── common/ # 公共类
|
||||||
|
│ │ │ └── Base.php # 基础控制器(登录验证)
|
||||||
|
│ │ └── view/ # 视图模板
|
||||||
|
│ │ ├── login/ # 登录相关视图
|
||||||
|
│ │ │ ├── login.html # 登录页
|
||||||
|
│ │ │ └── nav.html # 主框架页
|
||||||
|
│ │ ├── wechatset/ # 资讯管理视图
|
||||||
|
│ │ └── wechatinfro/ # 用户和记录视图
|
||||||
|
│ ├── adminghd/ # GHD预测后台模块
|
||||||
|
│ │ ├── controller/ # 控制器(结构同admin)
|
||||||
|
│ │ ├── common/ # 公共类
|
||||||
|
│ │ └── view/ # 视图模板
|
||||||
|
│ ├── app/ # 小程序API模块
|
||||||
|
│ │ └── controller/
|
||||||
|
│ │ ├── Ruilaiwechat.php # 瑞莱小程序API
|
||||||
|
│ │ └── Ghdwechat.php # GHD小程序API
|
||||||
|
│ └── common/ # 公共模块
|
||||||
|
│ ├── config/ # 配置类
|
||||||
|
│ │ └── BusinessConfig.php # 业务配置
|
||||||
|
│ └── controller/ # 公共控制器
|
||||||
|
│ ├── WechatsetBase.php # 资讯管理基类
|
||||||
|
│ ├── WechatinfroBase.php # 用户管理基类
|
||||||
|
│ └── DashboardBase.php # 仪表盘基类
|
||||||
|
├── public/ # 公共访问目录
|
||||||
|
│ ├── static/ # 静态资源
|
||||||
|
│ │ ├── admin/ # admin模块静态资源
|
||||||
|
│ │ │ ├── css/ # 样式文件
|
||||||
|
│ │ │ ├── js/ # JavaScript文件
|
||||||
|
│ │ │ └── layui/ # Layui框架
|
||||||
|
│ │ └── adminghd/ # adminghd模块静态资源
|
||||||
|
│ └── index.php # 入口文件
|
||||||
|
└── thinkphp/ # ThinkPHP框架核心
|
||||||
|
```
|
||||||
|
|
||||||
|
### 2.2 技术栈
|
||||||
|
|
||||||
|
- **后端框架:** ThinkPHP 5.0
|
||||||
|
- **前端框架:** Layui 2.x
|
||||||
|
- **JavaScript库:** jQuery
|
||||||
|
- **数据库:** MySQL
|
||||||
|
- **会话管理:** ThinkPHP Session
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 三、模块说明
|
||||||
|
|
||||||
|
### 3.1 admin 模块(早熟预测后台)
|
||||||
|
|
||||||
|
#### 3.1.1 访问路径
|
||||||
|
- 登录页:`/admin/login`
|
||||||
|
- 主框架:`/admin/login/index`(登录后自动跳转)
|
||||||
|
|
||||||
|
#### 3.1.2 Session配置
|
||||||
|
- 用户ID键名:`admin_user_id`
|
||||||
|
- 登录时间键名:`admin_user_login_time`
|
||||||
|
- 超时时间:3600秒(1小时)
|
||||||
|
|
||||||
|
#### 3.1.3 数据表映射
|
||||||
|
| 业务表 | 数据库表名 |
|
||||||
|
|--------|-----------|
|
||||||
|
| 用户表 | `wechat_user` |
|
||||||
|
| 资讯表 | `wechat_real_time_info` |
|
||||||
|
| 计算记录表 | `wechat_calculate_record` |
|
||||||
|
| 菜单表 | `menu` |
|
||||||
|
| 管理员表 | `user` |
|
||||||
|
|
||||||
|
#### 3.1.4 静态资源路径
|
||||||
|
- CSS:`/static/admin/css/`
|
||||||
|
- JS:`/static/admin/js/`
|
||||||
|
- Layui:`/static/admin/layui/`
|
||||||
|
|
||||||
|
### 3.2 adminghd 模块(GHD预测后台)
|
||||||
|
|
||||||
|
#### 3.2.1 访问路径
|
||||||
|
- 登录页:`/adminghd/login`
|
||||||
|
- 主框架:`/adminghd/login/index`(登录后自动跳转)
|
||||||
|
|
||||||
|
#### 3.2.2 Session配置
|
||||||
|
- 用户ID键名:`adminghd_user_id`
|
||||||
|
- 登录时间键名:`adminghd_user_login_time`
|
||||||
|
- 超时时间:3600秒(1小时)
|
||||||
|
|
||||||
|
#### 3.2.3 数据表映射
|
||||||
|
| 业务表 | 数据库表名 |
|
||||||
|
|--------|-----------|
|
||||||
|
| 用户表 | `ghd_wechat_user` |
|
||||||
|
| 资讯表 | `wechat_real_time_info` |
|
||||||
|
| 计算记录表 | `wechat_calculate_record` |
|
||||||
|
| 菜单表 | `menu` |
|
||||||
|
| 管理员表 | `user` |
|
||||||
|
|
||||||
|
#### 3.2.4 静态资源路径
|
||||||
|
- CSS:`/static/adminghd/css/`
|
||||||
|
- JS:`/static/adminghd/js/`
|
||||||
|
- Layui:`/static/adminghd/layui/`
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 四、功能模块
|
||||||
|
|
||||||
|
### 4.1 登录认证模块
|
||||||
|
|
||||||
|
#### 4.1.1 登录功能
|
||||||
|
|
||||||
|
**控制器:** `Login.php`
|
||||||
|
|
||||||
|
**登录流程:**
|
||||||
|
1. 用户访问登录页 `/admin/login` 或 `/adminghd/login`
|
||||||
|
2. 输入用户名(手机号)和密码
|
||||||
|
3. 系统验证用户信息:
|
||||||
|
- 查询 `user` 表
|
||||||
|
- 验证条件:`phone` = 用户名,`password` = MD5(密码),`status` = 1,`type` = 1
|
||||||
|
4. 登录成功:
|
||||||
|
- 设置Session:`admin_user_id` 或 `adminghd_user_id`
|
||||||
|
- 设置登录时间:`admin_user_login_time` 或 `adminghd_user_login_time`(当前时间 + 3600秒)
|
||||||
|
- 返回JSON:`{'status':1, 'msg':'登录成功', 'token':1}`
|
||||||
|
5. 跳转到主框架页面
|
||||||
|
|
||||||
|
**登录验证:**
|
||||||
|
- 所有需要登录的页面继承 `Base` 类
|
||||||
|
- `Base::_initialize()` 方法自动检查Session
|
||||||
|
- 未登录或超时:跳转到登录页
|
||||||
|
|
||||||
|
#### 4.1.2 退出功能
|
||||||
|
|
||||||
|
**接口:** `/admin/Login/logout` 或 `/adminghd/Login/logout`
|
||||||
|
|
||||||
|
**功能:**
|
||||||
|
- 清除所有Session数据
|
||||||
|
- 返回JSON:`{'status':1, 'msg':'退出成功'}`
|
||||||
|
- 前端跳转到登录页
|
||||||
|
|
||||||
|
### 4.2 菜单管理模块
|
||||||
|
|
||||||
|
#### 4.2.1 菜单结构
|
||||||
|
|
||||||
|
**数据表:** `menu`
|
||||||
|
|
||||||
|
**表结构:**
|
||||||
|
- `id`:菜单ID(主键)
|
||||||
|
- `pid`:父菜单ID(空或0表示一级菜单)
|
||||||
|
- `menu_name`:菜单名称
|
||||||
|
- `url`:菜单链接
|
||||||
|
- `seq_on`:排序序号
|
||||||
|
- `menu_icon`:菜单图标
|
||||||
|
- `create_time`:创建时间
|
||||||
|
|
||||||
|
**菜单层级:**
|
||||||
|
- 一级菜单:`pid` 为空或0
|
||||||
|
- 二级菜单:`pid` 指向一级菜单的 `id`
|
||||||
|
|
||||||
|
#### 4.2.2 获取菜单列表
|
||||||
|
|
||||||
|
**接口:** `/admin/Menu/getMenuList` 或 `/adminghd/Menu/getMenuList`
|
||||||
|
|
||||||
|
**返回格式:**
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"status": 1,
|
||||||
|
"msg": "获取数据成功!!",
|
||||||
|
"data": [
|
||||||
|
{
|
||||||
|
"id": "xxx",
|
||||||
|
"pid": "",
|
||||||
|
"menu_name": "小程序设置",
|
||||||
|
"url": "",
|
||||||
|
"seq_on": 1,
|
||||||
|
"type": 1,
|
||||||
|
"children": [
|
||||||
|
{
|
||||||
|
"id": "yyy",
|
||||||
|
"pid": "xxx",
|
||||||
|
"menu_name": "首页资讯列表",
|
||||||
|
"url": "/admin/Wechatset/wechatRealTimeInfo",
|
||||||
|
"type": 2
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
#### 4.2.3 菜单管理功能
|
||||||
|
|
||||||
|
- **添加菜单:** `/admin/Menu/doaddMenu`
|
||||||
|
- **修改菜单:** `/admin/Menu/doupdMenu`
|
||||||
|
- **删除菜单:** `/admin/Menu/delMenu`
|
||||||
|
- **获取菜单详情:** `/admin/Menu/updMenu`
|
||||||
|
|
||||||
|
### 4.3 用户信息模块
|
||||||
|
|
||||||
|
#### 4.3.1 获取当前用户信息
|
||||||
|
|
||||||
|
**接口:** `/admin/Menu/getUserInfor` 或 `/adminghd/Menu/getUserInfor`
|
||||||
|
|
||||||
|
**返回格式:**
|
||||||
|
```json
|
||||||
|
{
|
||||||
|
"status": 1,
|
||||||
|
"msg": "查询成功",
|
||||||
|
"infro": {
|
||||||
|
"user_name": "管理员",
|
||||||
|
"user_head": "/static/admin/img/upload.png"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
#### 4.3.2 小程序注册用户管理
|
||||||
|
|
||||||
|
**控制器:** `Wechatinfro.php`
|
||||||
|
|
||||||
|
**功能列表:**
|
||||||
|
- **用户列表:** `/admin/Wechatinfro/wechatUserList`
|
||||||
|
- **获取用户列表:** `/admin/Wechatinfro/getWechatUserList`
|
||||||
|
|
||||||
|
**数据表:**
|
||||||
|
- admin模块:`wechat_user`
|
||||||
|
- adminghd模块:`ghd_wechat_user`
|
||||||
|
|
||||||
|
**用户列表字段:**
|
||||||
|
- `uid`:用户ID
|
||||||
|
- `nickname`:用户昵称
|
||||||
|
- `headimg`:头像
|
||||||
|
- `create_time`:注册时间
|
||||||
|
|
||||||
|
**搜索功能:**
|
||||||
|
- 支持按昵称模糊搜索
|
||||||
|
|
||||||
|
### 4.4 资讯管理模块
|
||||||
|
|
||||||
|
#### 4.4.1 资讯列表
|
||||||
|
|
||||||
|
**控制器:** `Wechatset.php`
|
||||||
|
|
||||||
|
**功能列表:**
|
||||||
|
- **资讯列表页:** `/admin/Wechatset/wechatRealTimeInfo`
|
||||||
|
- **获取资讯列表:** `/admin/Wechatset/getWechatRealTimeInfoList`
|
||||||
|
- **添加资讯页:** `/admin/Wechatset/wechatRealTimeInfoAdd`
|
||||||
|
- **编辑资讯页:** `/admin/Wechatset/wechatRealTimeInfoUpdate`
|
||||||
|
- **保存资讯:** `/admin/Wechatset/saveWechatRealTimeInfo`
|
||||||
|
- **删除资讯:** `/admin/Wechatset/delWechatRealTimeInfo`
|
||||||
|
- **获取资讯详情:** `/admin/Wechatset/getRealTimeInfoDetail`
|
||||||
|
|
||||||
|
**数据表:** `wechat_real_time_info`(两个模块共用)
|
||||||
|
|
||||||
|
**资讯字段:**
|
||||||
|
- `id`:资讯ID
|
||||||
|
- `title_plain`:标题
|
||||||
|
- `thumbnail`:缩略图
|
||||||
|
- `excerpt_plain`:简介
|
||||||
|
- `url`:跳转链接
|
||||||
|
- `create_time`:创建时间
|
||||||
|
|
||||||
|
**搜索功能:**
|
||||||
|
- 支持按标题模糊搜索
|
||||||
|
|
||||||
|
#### 4.4.2 资讯管理流程
|
||||||
|
|
||||||
|
1. **添加资讯:**
|
||||||
|
- 填写标题、上传图片、填写简介、填写跳转链接
|
||||||
|
- 系统自动生成ID(MD5(时间戳+随机数))
|
||||||
|
- 保存到数据库
|
||||||
|
|
||||||
|
2. **编辑资讯:**
|
||||||
|
- 根据ID获取资讯详情
|
||||||
|
- 修改后保存
|
||||||
|
|
||||||
|
3. **删除资讯:**
|
||||||
|
- 根据ID删除记录
|
||||||
|
|
||||||
|
### 4.5 计算记录管理模块
|
||||||
|
|
||||||
|
#### 4.5.1 计算记录列表
|
||||||
|
|
||||||
|
**控制器:** `Wechatinfro.php`
|
||||||
|
|
||||||
|
**功能列表:**
|
||||||
|
- **记录列表页:** `/admin/Wechatinfro/wechatRecordList`
|
||||||
|
- **获取记录列表:** `/admin/Wechatinfro/getWechatRecordList`
|
||||||
|
|
||||||
|
**数据表:** `wechat_calculate_record`(两个模块共用)
|
||||||
|
|
||||||
|
**记录字段:**
|
||||||
|
- `id`:记录ID
|
||||||
|
- `name`:姓名
|
||||||
|
- `age`:年龄
|
||||||
|
- `height`:身高
|
||||||
|
- `bone_age`:骨龄
|
||||||
|
- `father_height`:父亲身高
|
||||||
|
- `mother_height`:母亲身高
|
||||||
|
- `IGF`:IGF-1值(GHD)或IGFBP-3值(早熟)
|
||||||
|
- `LH`:LH值(早熟)
|
||||||
|
- `uterus_thickness`:子宫厚度(早熟)
|
||||||
|
- `calculate_resutlt`:计算结果
|
||||||
|
- `create_time`:创建时间
|
||||||
|
|
||||||
|
**搜索功能:**
|
||||||
|
- 支持按姓名模糊搜索
|
||||||
|
|
||||||
|
### 4.6 仪表盘模块(Dashboard)
|
||||||
|
|
||||||
|
#### 4.6.1 统计概览
|
||||||
|
|
||||||
|
**控制器:** `Dashboard.php`
|
||||||
|
|
||||||
|
**功能列表:**
|
||||||
|
- **仪表盘页面:** `/admin/Dashboard/index`
|
||||||
|
- **获取统计数据:** `/admin/Dashboard/getStatistics`
|
||||||
|
|
||||||
|
**统计数据:**
|
||||||
|
- 注册用户数
|
||||||
|
- 首页资讯数量
|
||||||
|
- 最近一次计算时间
|
||||||
|
- 今日新增用户数
|
||||||
|
- 总计算次数
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 五、数据库设计
|
||||||
|
|
||||||
|
### 5.1 核心数据表
|
||||||
|
|
||||||
|
#### 5.1.1 管理员表(user)
|
||||||
|
|
||||||
|
**说明:** 后台管理员账户表,两个模块共用
|
||||||
|
|
||||||
|
**字段:**
|
||||||
|
- `id`:管理员ID(主键)
|
||||||
|
- `user_name`:管理员姓名
|
||||||
|
- `phone`:手机号(登录用户名)
|
||||||
|
- `password`:密码(MD5加密)
|
||||||
|
- `user_head`:头像
|
||||||
|
- `status`:状态(1=启用,0=禁用)
|
||||||
|
- `type`:类型(1=管理员)
|
||||||
|
|
||||||
|
#### 5.1.2 菜单表(menu)
|
||||||
|
|
||||||
|
**说明:** 后台菜单配置表,两个模块共用
|
||||||
|
|
||||||
|
**字段:**
|
||||||
|
- `id`:菜单ID(主键,MD5生成)
|
||||||
|
- `pid`:父菜单ID(空或0=一级菜单)
|
||||||
|
- `menu_name`:菜单名称
|
||||||
|
- `url`:菜单链接
|
||||||
|
- `seq_on`:排序序号
|
||||||
|
- `menu_icon`:菜单图标
|
||||||
|
- `create_time`:创建时间
|
||||||
|
|
||||||
|
#### 5.1.3 小程序用户表
|
||||||
|
|
||||||
|
**说明:** 小程序注册用户表,两个模块使用不同的表
|
||||||
|
|
||||||
|
**admin模块:** `wechat_user`
|
||||||
|
**adminghd模块:** `ghd_wechat_user`
|
||||||
|
|
||||||
|
**字段:**
|
||||||
|
- `uid`:用户ID(主键)
|
||||||
|
- `openid`:微信OpenID
|
||||||
|
- `nickname`:用户昵称
|
||||||
|
- `headimg`:头像
|
||||||
|
- `create_time`:注册时间
|
||||||
|
|
||||||
|
#### 5.1.4 资讯表(wechat_real_time_info)
|
||||||
|
|
||||||
|
**说明:** 首页资讯表,两个模块共用
|
||||||
|
|
||||||
|
**字段:**
|
||||||
|
- `id`:资讯ID(主键,MD5生成)
|
||||||
|
- `title_plain`:标题
|
||||||
|
- `thumbnail`:缩略图URL
|
||||||
|
- `excerpt_plain`:简介
|
||||||
|
- `url`:跳转链接
|
||||||
|
- `create_time`:创建时间
|
||||||
|
|
||||||
|
#### 5.1.5 计算记录表(wechat_calculate_record)
|
||||||
|
|
||||||
|
**说明:** 预测计算记录表,两个模块共用
|
||||||
|
|
||||||
|
**字段:**
|
||||||
|
- `id`:记录ID(主键,MD5生成)
|
||||||
|
- `uid`:用户ID
|
||||||
|
- `name`:姓名
|
||||||
|
- `age`:年龄
|
||||||
|
- `height`:身高(cm)
|
||||||
|
- `bone_age`:骨龄(年)
|
||||||
|
- `father_height`:父亲身高(cm)
|
||||||
|
- `mother_height`:母亲身高(cm)
|
||||||
|
- `IGF`:IGF-1值(GHD)或IGFBP-3值(早熟)
|
||||||
|
- `LH`:LH值(早熟预测)
|
||||||
|
- `uterus_thickness`:子宫厚度(早熟预测)
|
||||||
|
- `calculate_resutlt`:计算结果(JSON格式)
|
||||||
|
- `create_time`:创建时间
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 六、前端架构
|
||||||
|
|
||||||
|
### 6.1 主框架结构
|
||||||
|
|
||||||
|
**文件:** `application/admin/view/login/nav.html` 或 `application/adminghd/view/login/nav.html`
|
||||||
|
|
||||||
|
**布局:**
|
||||||
|
- 左侧导航栏:菜单列表
|
||||||
|
- 顶部栏:面包屑导航 + 用户信息 + 退出按钮
|
||||||
|
- 主内容区:iframe加载功能页面
|
||||||
|
|
||||||
|
### 6.2 导航菜单渲染
|
||||||
|
|
||||||
|
**文件:** `public/static/admin/js/nav.js` 或 `public/static/adminghd/js/nav.js`
|
||||||
|
|
||||||
|
**功能:**
|
||||||
|
1. 页面加载时调用 `/admin/Menu/getMenuList` 获取菜单数据
|
||||||
|
2. 将菜单数据渲染为左侧导航栏
|
||||||
|
3. 支持一级和二级菜单结构
|
||||||
|
4. 点击菜单项,在iframe中加载对应页面
|
||||||
|
|
||||||
|
### 6.3 样式框架
|
||||||
|
|
||||||
|
**CSS框架:** Layui 2.x
|
||||||
|
|
||||||
|
**主要样式文件:**
|
||||||
|
- `nav.css`:主框架样式
|
||||||
|
- `login.css`:登录页样式
|
||||||
|
- `index.css`:列表页样式
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 七、API接口
|
||||||
|
|
||||||
|
### 7.1 登录相关
|
||||||
|
|
||||||
|
| 接口 | 方法 | 说明 |
|
||||||
|
|------|------|------|
|
||||||
|
| `/admin/Login/index` | GET | 登录页 |
|
||||||
|
| `/admin/Login/login` | POST | 登录验证 |
|
||||||
|
| `/admin/Login/logout` | POST | 退出登录 |
|
||||||
|
| `/admin/Login/logoutJump` | GET | 超时跳转页 |
|
||||||
|
|
||||||
|
### 7.2 菜单相关
|
||||||
|
|
||||||
|
| 接口 | 方法 | 说明 |
|
||||||
|
|------|------|------|
|
||||||
|
| `/admin/Menu/getMenuList` | POST | 获取菜单列表 |
|
||||||
|
| `/admin/Menu/getUserInfor` | POST | 获取当前用户信息 |
|
||||||
|
| `/admin/Menu/doaddMenu` | POST | 添加菜单 |
|
||||||
|
| `/admin/Menu/doupdMenu` | POST | 修改菜单 |
|
||||||
|
| `/admin/Menu/delMenu` | POST | 删除菜单 |
|
||||||
|
|
||||||
|
### 7.3 用户管理
|
||||||
|
|
||||||
|
| 接口 | 方法 | 说明 |
|
||||||
|
|------|------|------|
|
||||||
|
| `/admin/Wechatinfro/wechatUserList` | GET | 用户列表页 |
|
||||||
|
| `/admin/Wechatinfro/getWechatUserList` | POST | 获取用户列表 |
|
||||||
|
|
||||||
|
### 7.4 资讯管理
|
||||||
|
|
||||||
|
| 接口 | 方法 | 说明 |
|
||||||
|
|------|------|------|
|
||||||
|
| `/admin/Wechatset/wechatRealTimeInfo` | GET | 资讯列表页 |
|
||||||
|
| `/admin/Wechatset/getWechatRealTimeInfoList` | POST | 获取资讯列表 |
|
||||||
|
| `/admin/Wechatset/wechatRealTimeInfoAdd` | GET | 添加资讯页 |
|
||||||
|
| `/admin/Wechatset/wechatRealTimeInfoUpdate` | GET | 编辑资讯页 |
|
||||||
|
| `/admin/Wechatset/saveWechatRealTimeInfo` | POST | 保存资讯 |
|
||||||
|
| `/admin/Wechatset/delWechatRealTimeInfo` | POST | 删除资讯 |
|
||||||
|
| `/admin/Wechatset/getRealTimeInfoDetail` | POST | 获取资讯详情 |
|
||||||
|
|
||||||
|
### 7.5 计算记录
|
||||||
|
|
||||||
|
| 接口 | 方法 | 说明 |
|
||||||
|
|------|------|------|
|
||||||
|
| `/admin/Wechatinfro/wechatRecordList` | GET | 记录列表页 |
|
||||||
|
| `/admin/Wechatinfro/getWechatRecordList` | POST | 获取记录列表 |
|
||||||
|
|
||||||
|
### 7.6 仪表盘
|
||||||
|
|
||||||
|
| 接口 | 方法 | 说明 |
|
||||||
|
|------|------|------|
|
||||||
|
| `/admin/Dashboard/index` | GET | 仪表盘页面 |
|
||||||
|
| `/admin/Dashboard/getStatistics` | POST | 获取统计数据 |
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 八、安全机制
|
||||||
|
|
||||||
|
### 8.1 登录验证
|
||||||
|
|
||||||
|
- 所有需要登录的控制器继承 `Base` 类
|
||||||
|
- `Base::_initialize()` 自动检查Session
|
||||||
|
- 未登录或超时自动跳转到登录页
|
||||||
|
|
||||||
|
### 8.2 密码加密
|
||||||
|
|
||||||
|
- 密码使用MD5加密存储
|
||||||
|
- 登录时对输入密码进行MD5加密后比对
|
||||||
|
|
||||||
|
### 8.3 Session管理
|
||||||
|
|
||||||
|
- 登录成功设置Session,有效期1小时
|
||||||
|
- 每次请求检查Session是否过期
|
||||||
|
- 退出登录清除所有Session
|
||||||
|
|
||||||
|
### 8.4 权限控制
|
||||||
|
|
||||||
|
- 当前版本未实现细粒度权限控制
|
||||||
|
- 所有登录用户拥有相同权限
|
||||||
|
- 预留权限控制接口(代码中已注释)
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 九、部署说明
|
||||||
|
|
||||||
|
### 9.1 环境要求
|
||||||
|
|
||||||
|
- PHP >= 5.6
|
||||||
|
- MySQL >= 5.6
|
||||||
|
- Apache/Nginx Web服务器
|
||||||
|
- ThinkPHP 5.0框架
|
||||||
|
|
||||||
|
### 9.2 配置说明
|
||||||
|
|
||||||
|
#### 9.2.1 数据库配置
|
||||||
|
|
||||||
|
**文件:** `application/database.php`
|
||||||
|
|
||||||
|
```php
|
||||||
|
return [
|
||||||
|
'type' => 'mysql',
|
||||||
|
'hostname' => '127.0.0.1',
|
||||||
|
'database' => 'ruilai',
|
||||||
|
'username' => 'rootrui',
|
||||||
|
'password' => 'X2)jB+k%YH.p',
|
||||||
|
'charset' => 'utf8',
|
||||||
|
'prefix' => 't_sys_',
|
||||||
|
];
|
||||||
|
```
|
||||||
|
|
||||||
|
#### 9.2.2 路由配置
|
||||||
|
|
||||||
|
**文件:** `application/route.php`
|
||||||
|
|
||||||
|
默认使用ThinkPHP的路由规则,URL格式:
|
||||||
|
- `/模块/控制器/方法`
|
||||||
|
|
||||||
|
例如:
|
||||||
|
- `/admin/Login/index` → `application/admin/controller/Login.php::index()`
|
||||||
|
|
||||||
|
### 9.3 静态资源
|
||||||
|
|
||||||
|
静态资源存放在 `public/static/` 目录下,通过Web服务器直接访问。
|
||||||
|
|
||||||
|
**访问路径:**
|
||||||
|
- `/static/admin/css/nav.css`
|
||||||
|
- `/static/adminghd/js/nav.js`
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 十、常见问题
|
||||||
|
|
||||||
|
### 10.1 登录问题
|
||||||
|
|
||||||
|
**问题:** 登录后立即跳转到登录页
|
||||||
|
|
||||||
|
**原因:** Session未正确设置或Base类验证失败
|
||||||
|
|
||||||
|
**解决:**
|
||||||
|
1. 检查Session配置
|
||||||
|
2. 检查Base类的Session键名是否正确
|
||||||
|
3. 检查数据库用户表数据
|
||||||
|
|
||||||
|
### 10.2 菜单不显示
|
||||||
|
|
||||||
|
**问题:** 左侧导航栏菜单不显示
|
||||||
|
|
||||||
|
**原因:**
|
||||||
|
1. 菜单数据未正确返回
|
||||||
|
2. JavaScript渲染错误
|
||||||
|
3. 菜单表数据为空
|
||||||
|
|
||||||
|
**解决:**
|
||||||
|
1. 检查浏览器控制台错误
|
||||||
|
2. 检查 `/admin/Menu/getMenuList` 接口返回
|
||||||
|
3. 检查 `menu` 表是否有数据
|
||||||
|
|
||||||
|
### 10.3 数据表不存在
|
||||||
|
|
||||||
|
**问题:** 提示数据表不存在
|
||||||
|
|
||||||
|
**原因:** 数据库表前缀配置错误
|
||||||
|
|
||||||
|
**解决:**
|
||||||
|
1. 检查 `application/database.php` 中的 `prefix` 配置
|
||||||
|
2. 确认数据库表名是否正确(包含前缀)
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 十一、开发规范
|
||||||
|
|
||||||
|
### 11.1 代码规范
|
||||||
|
|
||||||
|
- 遵循PSR-2编码规范
|
||||||
|
- 控制器类名首字母大写
|
||||||
|
- 方法名使用驼峰命名
|
||||||
|
- 注释使用PHPDoc格式
|
||||||
|
|
||||||
|
### 11.2 命名规范
|
||||||
|
|
||||||
|
- **控制器:** 大驼峰,如 `Wechatset.php`
|
||||||
|
- **方法:** 小驼峰,如 `getWechatUserList()`
|
||||||
|
- **数据表:** 小写下划线,如 `wechat_user`
|
||||||
|
- **Session键:** 小写下划线,如 `admin_user_id`
|
||||||
|
|
||||||
|
### 11.3 文件组织
|
||||||
|
|
||||||
|
- 控制器放在 `controller/` 目录
|
||||||
|
- 视图放在 `view/` 目录
|
||||||
|
- 静态资源放在 `public/static/` 目录
|
||||||
|
- 公共类放在 `common/` 目录
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 十二、后续优化建议
|
||||||
|
|
||||||
|
### 12.1 代码优化
|
||||||
|
|
||||||
|
1. **统一公共逻辑:** 将两个模块的公共代码提取到 `common` 模块
|
||||||
|
2. **配置统一管理:** 使用配置文件管理业务类型和表映射
|
||||||
|
3. **错误处理:** 统一异常处理和错误返回格式
|
||||||
|
|
||||||
|
### 12.2 功能增强
|
||||||
|
|
||||||
|
1. **权限管理:** 实现基于角色的权限控制(RBAC)
|
||||||
|
2. **操作日志:** 记录管理员操作日志
|
||||||
|
3. **数据统计:** 增加更详细的数据统计和报表功能
|
||||||
|
4. **批量操作:** 支持批量删除、批量导出等功能
|
||||||
|
|
||||||
|
### 12.3 性能优化
|
||||||
|
|
||||||
|
1. **缓存机制:** 菜单数据、统计数据使用缓存
|
||||||
|
2. **数据库优化:** 添加索引,优化查询语句
|
||||||
|
3. **前端优化:** 压缩静态资源,使用CDN
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 十三、后台模块彻底分离维护方案
|
||||||
|
|
||||||
|
两个后台(admin 早熟预测、adminghd GHD 预测)可以做到**彻底分离维护**,互不影响。根据目标不同,有两种做法。
|
||||||
|
|
||||||
|
### 13.1 分离状态
|
||||||
|
|
||||||
|
**✅ 已完成逻辑彻底分离(方案一)**
|
||||||
|
|
||||||
|
| 模块 | 状态 | 说明 |
|
||||||
|
|------|------|------|
|
||||||
|
| **admin 模块** | ✅ 已独立 | 所有控制器继承 `app\admin\common\Base`,不再依赖 common 模块 |
|
||||||
|
| **adminghd 模块** | ✅ 已独立 | 所有控制器继承 `app\adminghd\common\Base`,不再依赖 common 模块 |
|
||||||
|
| **Dashboard** | ✅ 已独立 | 两个模块的 `Dashboard` 控制器各自实现 `getStatistics` 方法,使用固定的表名 |
|
||||||
|
| **数据库** | 共用 | 同一库 `ruilai`,同一前缀 `t_sys_`;部分表共用(menu、wechat_real_time_info、wechat_calculate_record),用户表不同(wechat_user / ghd_wechat_user) |
|
||||||
|
| **入口与框架** | 共用 | 同一 `public/index.php`、同一 ThinkPHP 应用目录 |
|
||||||
|
|
||||||
|
**已解除的耦合:**
|
||||||
|
- ✅ `Dashboard` 不再继承 `DashboardBase`
|
||||||
|
- ✅ 表名和 Session 键已硬编码到各自控制器中
|
||||||
|
- ✅ 两个模块可独立修改,互不影响
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
### 13.2 方案一:同仓库内逻辑彻底分离(✅ 已采用)
|
||||||
|
|
||||||
|
**目标**:同一套代码、同一部署,但 admin 与 adminghd 在代码上**完全独立**,改一个模块不会牵动另一个,也不依赖 common 里的业务基类。
|
||||||
|
|
||||||
|
**实施状态:** ✅ **已完成**
|
||||||
|
|
||||||
|
**已完成的修改:**
|
||||||
|
|
||||||
|
1. **✅ 解除 Dashboard 对 common 的依赖**
|
||||||
|
- `application/admin/controller/Dashboard.php` 已改为继承 `\app\admin\common\Base`,不再继承 `DashboardBase`。
|
||||||
|
- `getStatistics` 方法已独立实现,使用固定的表名 `wechat_user`、`wechat_real_time_info`、`wechat_calculate_record`。
|
||||||
|
- `application/adminghd/controller/Dashboard.php` 已改为继承 `\app\adminghd\common\Base`,使用固定的表名 `ghd_wechat_user`、`wechat_real_time_info`、`wechat_calculate_record`。
|
||||||
|
|
||||||
|
2. **✅ 代码独立性验证**
|
||||||
|
- 两个模块的控制器已完全独立,不再依赖 `app\common\controller\*Base` 和 `BusinessConfig`。
|
||||||
|
- 表名和 Session 键已硬编码到各自控制器中。
|
||||||
|
|
||||||
|
3. **✅ common 模块保留**
|
||||||
|
- `common` 模块中的基类(`DashboardBase`、`WechatinfroBase`、`WechatsetBase`)已保留,但不再被使用。
|
||||||
|
- 可作为参考或未来新后台的模板,但不影响现有两个模块的独立性。
|
||||||
|
|
||||||
|
**优点**:✅ 部署不变、数据库不变,只改一处不影响另一处,适合继续同仓库、同服务器维护。
|
||||||
|
**维护约定**:两个模块独立维护,如需同步功能,需分别在两个模块中实现。建议在代码注释中标注需要同步的功能点。
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
### 13.3 方案二:拆成两个独立项目(物理分离)
|
||||||
|
|
||||||
|
**目标**:两套独立代码库、可独立部署、独立发版,甚至不同服务器、不同数据库。
|
||||||
|
|
||||||
|
**思路**:
|
||||||
|
- 以当前代码为基准,复制出两份项目:一份只保留 admin 相关(及 app、index 等必要模块),一份只保留 adminghd 相关。
|
||||||
|
- 每份项目有独立 `application`、独立入口(可共用同一 `public` 或各建各的)、独立配置与依赖。
|
||||||
|
|
||||||
|
**具体步骤**:
|
||||||
|
|
||||||
|
1. **项目 A(早熟预测后台)**
|
||||||
|
- 新建目录如 `code-admin`,保留 ThinkPHP 框架、`public`、`application/database.php` 等。
|
||||||
|
- 只保留 `application/admin`、`application/app`(瑞莱小程序 API)、`application/index` 等与早熟业务相关的模块;删除 `application/adminghd` 和 `application/common` 中业务相关部分。
|
||||||
|
- 将原 admin 内对表名、Session 的写法固定为早熟业务(wechat_user、admin_user_id 等)。
|
||||||
|
- 配置独立入口(如 `code-admin/public/index.php`)和独立域名或路径。
|
||||||
|
|
||||||
|
2. **项目 B(GHD 预测后台)**
|
||||||
|
- 新建目录如 `code-adminghd`,同样保留框架与必要目录。
|
||||||
|
- 只保留 `application/adminghd`、`application/app`(GHD 小程序 API)等;删除 `application/admin` 和 common 业务基类。
|
||||||
|
- 表名、Session 固定为 GHD(ghd_wechat_user、adminghd_user_id 等)。
|
||||||
|
- 配置独立入口与访问方式。
|
||||||
|
|
||||||
|
3. **数据库**
|
||||||
|
- **选项甲**:仍用同一库,两项目连同一 `database.php`,仅模块不同、访问表不同。
|
||||||
|
- **选项乙**:分库(如 `ruilai` 与 `ruilai_ghd`),各项目独立 `database.php`,表结构可复制或迁移脚本分表。
|
||||||
|
|
||||||
|
4. **静态资源**
|
||||||
|
- 各项目 `public/static` 下只保留本后台所需(如项目 A 只保留 `admin`,项目 B 只保留 `adminghd`),避免混用。
|
||||||
|
|
||||||
|
**优点**:版本、上线、回滚完全独立,技术栈升级可分批进行。
|
||||||
|
**缺点**:两套代码、两套部署与运维;公共 bug 或需求要改两处,需通过复制或少量共享库(如 composer 私有包)来收敛。
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
### 13.4 选择建议
|
||||||
|
|
||||||
|
| 场景 | 建议 |
|
||||||
|
|------|------|
|
||||||
|
| 希望**少动部署、少动库**,只希望开发时互不干扰 | 采用 **方案一**(同仓库逻辑分离) |
|
||||||
|
| 需要**独立域名、独立服务器、独立发版节奏** | 采用 **方案二**(拆成两个项目) |
|
||||||
|
| 未来可能新增更多“类似后台”且希望复用一套基类 | 可保留 common 基类,仅把 admin、adminghd 改为不继承它们,实现“可选复用、默认分离” |
|
||||||
|
|
||||||
|
**实施完成日期:** 2025年1月29日
|
||||||
|
**采用的方案:** 方案一(同仓库内逻辑彻底分离)
|
||||||
|
**状态:** ✅ 已完成,两个模块已完全独立,可独立维护
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## 附录
|
||||||
|
|
||||||
|
### A. 相关文档
|
||||||
|
|
||||||
|
- [数据库配置文档](./数据库配置.md)
|
||||||
|
- [生长激素缺乏预测模型项目需求文档](./生长激素缺乏预测模型项目需求文档.md)
|
||||||
|
|
||||||
|
### B. 联系方式
|
||||||
|
|
||||||
|
如有问题,请联系开发团队。
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**文档生成时间:** 2025年1月28日
|
||||||
|
**最后更新:** 2025年1月28日
|
||||||
Reference in New Issue
Block a user