feat: 添加ERP服务和系统服务,完善员工门户功能

## 新增服务模块

### 1. ERP服务 (hzhub-erp)
- 新增独立的ERP数据适配服务
- 支持SQL Server 2008 R2数据源
- 提供动态API配置管理系统
- 包含客户管理、销售数据等业务接口

### 2. 系统服务 (hzhub-system)
- 新增独立的系统管理服务
- 用户、角色、权限、部门、菜单管理
- 租户管理、操作日志、在线用户监控
- 工作流引擎(warm-flow)集成
- 企业微信审批同步功能

### 3. API网关 (hzhub-gateway)
- 新增Spring Cloud Gateway网关服务
- JWT认证、路由分发、限流熔断
- XSS防护、请求日志记录
- 统一入口端口8080

## 后台管理功能增强

### ERP动态API管理
- 新增动态API配置管理界面
- API测试、文档预览、统计监控
- 错误日志查看、缓存管理
- 从数据库表自动导入API配置

### 系统管理增强
- 企业微信配置管理
- 企业微信审批同步配置
- 部门和用户管理优化

## 员工门户功能完善

### 业务页面
- 审批中心:工作流审批、待办任务
- CRM管理:客户关系管理
- 经销商管理:经销商数据展示
- 供应链管理:采购、库存、销售
- BI报表:数据可视化分析
- ERP数据探索:SQL Server数据查询

### 个人中心
- 基本设置:个人信息管理
- 安全设置:密码修改、登录日志
- 锁屏功能:自动锁屏、手动锁屏

### 其他功能
- 标签页管理:多标签页导航
- 页面缓存:keepAlive缓存机制
- 会话超时:自动检测并提示

## 经销商门户

### 页面路由
- 新增经销商管理页面路由
- AI聊天界面完善

## 文档更新

- ERP API数据库初始化指南
- ERP API前端完整实现文档
- ERP API测试和验证指南
- Gateway路由迁移计划
- 项目配置文档更新

## 部署脚本

- 统一启动/停止/重启脚本
- Docker Compose配置优化
- Nginx配置文件更新

## 技术栈

- 后端: Spring Boot 3.5.8, Java 17
- 前端: Vue 3, TypeScript, Element Plus, Vben Admin
- 工作流: warm-flow 1.8.2
- 网关: Spring Cloud Gateway
- 数据库: MySQL 8.0, SQL Server 2008 R2
- 缓存: Redis 7
- 向量库: Weaviate 1.25.0

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
大壮
2026-05-08 08:00:19 +00:00
parent e6fc123b1f
commit c2513849b4
1564 changed files with 52903 additions and 641 deletions

View File

@@ -0,0 +1,93 @@
#!/usr/bin/env python3
"""
ERP API 配置表初始化脚本 - MySQL版本
在MySQL hzhub数据库中创建配置表
"""
import pymysql
import os
from pathlib import Path
# MySQL数据库连接配置
MYSQL_HOST = os.getenv('MYSQL_HOST', '192.168.120.60')
MYSQL_PORT = int(os.getenv('MYSQL_PORT', '3306'))
MYSQL_DB = os.getenv('MYSQL_DB', 'hzhub')
MYSQL_USER = os.getenv('MYSQL_USERNAME', 'root')
MYSQL_PASSWORD = os.getenv('MYSQL_PASSWORD', 'hzhub123')
print(f"Connecting to MySQL: {MYSQL_HOST}:{MYSQL_PORT}/{MYSQL_DB}")
try:
# 连接MySQL数据库
conn = pymysql.connect(
host=MYSQL_HOST,
port=MYSQL_PORT,
database=MYSQL_DB,
user=MYSQL_USER,
password=MYSQL_PASSWORD,
charset='utf8mb4'
)
cursor = conn.cursor()
# 读取MySQL SQL文件
sql_file = Path(__file__).parent / 'docs' / 'sql' / 'erp_api_tables.sql'
print(f"Reading SQL file: {sql_file}")
with open(sql_file, 'r', encoding='utf-8') as f:
sql_content = f.read()
# 分割SQL语句按分号分割跳过注释和USE语句
sql_statements = []
for statement in sql_content.split(';'):
statement = statement.strip()
# 跳过USE语句、注释和空语句
if not statement or statement.startswith('--') or statement.upper().startswith('USE'):
continue
sql_statements.append(statement)
print(f"Found {len(sql_statements)} SQL statements")
# 执行每个SQL语句
for i, statement in enumerate(sql_statements, 1):
print(f"Executing statement {i}...")
try:
cursor.execute(statement)
conn.commit()
print(f"✓ Statement {i} executed successfully")
except Exception as e:
error_msg = str(e)
if "already exists" in error_msg or "Duplicate" in error_msg:
print(f"✓ Statement {i} skipped (already exists)")
else:
print(f"✗ Error in statement {i}: {e}")
conn.rollback()
# 验证表创建
print("\nVerifying tables...")
tables_to_check = ['erp_api_config', 'erp_api_param', 'erp_api_stats']
for table in tables_to_check:
cursor.execute(f"SHOW TABLES LIKE '{table}'")
result = cursor.fetchone()
if result:
print(f"✓ Table {table} exists")
# 显示表的行数
cursor.execute(f"SELECT COUNT(*) FROM {table}")
rows = cursor.fetchone()[0]
print(f" - Rows: {rows}")
else:
print(f"✗ Table {table} NOT found")
cursor.close()
conn.close()
print("\n✓ ERP API configuration tables initialized successfully in MySQL!")
except pymysql.Error as e:
print(f"\n✗ MySQL error: {e}")
exit(1)
except Exception as e:
print(f"\n✗ Error: {e}")
exit(1)