三网通电玩城平台系统结构与源码工程详解(三):控制台与银商权限模块设计

本篇聚焦于三网通电玩城系统中的控制台管理系统及银商权限逻辑。通过深入解构后台系统的角色分权、账目明细管理、发卡接口与日志追踪机制,本文将提供完整的权限划分方案和部分关键实现代码,为平台运维与数据安全提供坚实基础。


一、控制台整体结构概览

控制台由 PHP 编写,功能模块包括用户管理、账目查询、发卡充值、日志追踪、银商权限等,典型目录结构如下:

复制代码
/admin/
  ├── login.php             // 管理员登录
  ├── index.php             // 控制台首页
  ├── user_manage.php       // 玩家数据查看
  ├── silver_manage.php     // 银商权限管理
  ├── recharge.php          // 发卡/充值操作
  ├── log_view.php          // 操作日志
  └── common/
      ├── check_admin.php   // 权限验证
      └── config.php        // 数据库配置

二、权限分级设计与验证机制

系统默认分为三类角色:

  • 超级管理员(SuperAdmin)

  • 运营(Operator)

  • 银商(SilverAgent)

权限拦截示例:

复制代码
// check_admin.php
session_start();
if (!isset($_SESSION['role'])) {
  header("Location: login.php"); exit;
}
if ($_SESSION['role'] != 'SuperAdmin') {
  echo "无权限操作";
  exit;
}

通过角色字段控制页面按钮的显示与操作权限:

复制代码
<?php if ($_SESSION['role'] == 'SilverAgent') { ?>
  <button disabled>充值(权限不足)</button>
<?php } ?>

三、银商账户管理模块设计

银商功能用于赋权二级代理(银商)在后台分发卡密与管理下级。

表结构设计

复制代码
CREATE TABLE silver_account (
  id INT PRIMARY KEY AUTO_INCREMENT,
  uid INT NOT NULL,
  name VARCHAR(50),
  balance INT DEFAULT 0,
  parent_uid INT,
  role ENUM('SilverAgent','Operator','SuperAdmin')
);

卡密发放示例逻辑:

复制代码
function grant_card($silver_uid, $target_uid, $amount) {
  $sql = "UPDATE player SET diamond = diamond + $amount WHERE uid = $target_uid";
  mysqli_query($conn, $sql);

  $sql_log = "INSERT INTO silver_log(silver_uid, target_uid, amount, time) VALUES($silver_uid, $target_uid, $amount, NOW())";
  mysqli_query($conn, $sql_log);
}

四、后台发卡接口与日志记录

管理员操作发卡必须自动记录日志,防止越权行为。

recharge.php 核心逻辑:

复制代码
if ($_POST) {
  $uid = intval($_POST['uid']);
  $diamond = intval($_POST['diamond']);

  // 发卡
  $sql = "UPDATE player SET diamond = diamond + $diamond WHERE uid = $uid";
  mysqli_query($conn, $sql);

  // 日志
  $sql_log = "INSERT INTO recharge_log(admin_uid, target_uid, amount, time) VALUES($_SESSION[uid], $uid, $diamond, NOW())";
  mysqli_query($conn, $sql_log);

  echo "发卡成功";
}

五、日志审计系统设计

所有重要操作将写入日志,便于后期查询与追责。

recharge_log 表设计:

复制代码
CREATE TABLE recharge_log (
  id INT AUTO_INCREMENT PRIMARY KEY,
  admin_uid INT,
  target_uid INT,
  amount INT,
  time DATETIME
);

log_view.php 分页显示:

复制代码
$sql = "SELECT * FROM recharge_log ORDER BY time DESC LIMIT 50";
$res = mysqli_query($conn, $sql);
while ($row = mysqli_fetch_assoc($res)) {
  echo "<tr><td>{$row['admin_uid']}</td><td>{$row['target_uid']}</td><td>{$row['amount']}</td><td>{$row['time']}</td></tr>";
}

六、系统安全建议

为防止后台被恶意操作或撞库,建议加入以下机制:

  • 所有操作均加入 CSRF Token

  • 管理员登录加入验证码 + 短信二次验证

  • 限制银商权限,防止伪造充值

  • 所有日志每日自动备份至只读分区


七、小结

通过本篇文章我们详细梳理了三网通电玩城平台中控制台与银商权限系统的结构与逻辑,从角色分权、发卡接口、日志系统到安全设计,构建出一套完整的后台管理架构。在下一篇文章中,我们将进入具体的子游戏集成与服务器调度模块,重点分析"李逵劈鱼"、"疯狂玛丽"等子游戏的接入流程与并发管理方案。

相关推荐
jiaxingcode4 分钟前
MAC系统下完全卸载Android Studio
android·macos·android studio
张力尹11 分钟前
「架构篇 1」认识 MVC / MVP / MVVM / MVI
android·面试·架构
张力尹15 分钟前
「架构篇 2」认识 MVC / MVP / MVVM / MVI
android·面试·架构
不穿铠甲的穿山甲34 分钟前
Android-KeyStore安全的存储系统
android·安全
dora2 小时前
Flutter的屏幕适配
android·flutter
SoulKuyan2 小时前
android 发送onkey广播,Android 添加键值并上报从驱动到上层
android
Yang-Never3 小时前
ADB->查看某个应用的版本信息
android·adb·android studio
居然是阿宋5 小时前
Android RecyclerView 多布局场景下的设计思考:SRP 与 OCP 的权衡与优化
android·开闭原则·单一职责原则
前行的小黑炭5 小时前
Retrofit框架分析(二):注解、反射以及动态代理,Retrofit框架动态代理的源码分析
android·kotlin·retrofit