refactor(frontend): 重构前端目录结构并优化认证流程

将前端文件从html目录迁移到views目录,按功能模块组织
重构认证中间件和路由处理,简化页面权限控制
更新静态资源引用路径,统一使用/public前缀
添加学生仪表板页面,优化移动端显示
移除旧版html和js文件,更新样式和脚本
This commit is contained in:
祀梦
2025-12-21 22:07:23 +08:00
parent 38b200f9b3
commit bcf2c71fad
20 changed files with 2009 additions and 2009 deletions

View File

@@ -0,0 +1,342 @@
<!DOCTYPE html>
<html lang="zh-CN">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>学生成绩管理系统 - 管理员仪表板</title>
<link rel="stylesheet" href="/public/css/style.css">
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.0.0/css/all.min.css">
</head>
</head>
<body>
<!-- 顶部导航<E5AFBC><E888AA>?-->
<nav class="navbar">
<div class="navbar-brand">
<i class="fas fa-graduation-cap"></i>
<span>XX学校成绩管理系统</span>
</div>
<div class="navbar-menu">
<a href="/" class="btn btn-secondary">
<i class="fas fa-home"></i> 主页
</a>
<div class="navbar-user">
<span class="user-name" id="userName">管理<EFBFBD><EFBFBD>?/span>
<button id="logoutBtn" class="btn btn-primary">
<i class="fas fa-sign-out-alt"></i> 退<><E98080>? </button>
</div>
</div>
</nav>
<!-- 仪表板容<E69DBF><E5AEB9>?-->
<div class="dashboard-container">
<!-- 左侧侧边<E4BEA7><E8BEB9>?-->
<aside class="sidebar">
<div class="sidebar-header">
<div class="user-info">
<div class="user-avatar">
<i class="fas fa-user-shield"></i>
</div>
<div class="user-details">
<h3 id="adminName">管理<EFBFBD><EFBFBD>?/h3>
<p>系统管理<EFBFBD><EFBFBD>?| 权限<E69D83><E99990>?span id="adminRole">超级管理<E7AEA1><E79086>?/span></p>
</div>
</div>
</div>
<ul class="sidebar-menu">
<li>
<a href="#" class="active">
<i class="fas fa-tachometer-alt"></i>
<span>仪表<EFBFBD><EFBFBD>?/span>
</a>
</li>
<li>
<a href="/admin/user_management">
<i class="fas fa-users"></i>
<span>用户管理</span>
</a>
</li>
<li>
<a href="/admin/student_management">
<i class="fas fa-user-graduate"></i>
<span>学生管理</span>
</a>
</li>
<li>
<a href="teacher_management.html">
<i class="fas fa-chalkboard-teacher"></i>
<span>教师管理</span>
</a>
</li>
<li>
<a href="grade_statistics.html">
<i class="fas fa-chart-bar"></i>
<span>成绩统计</span>
</a>
</li>
<li>
<a href="system_settings.html">
<i class="fas fa-cog"></i>
<span>系统设置</span>
</a>
</li>
<li>
<a href="data_export.html">
<i class="fas fa-download"></i>
<span>数据导出</span>
</a>
</li>
<li>
<a href="audit_log.html">
<i class="fas fa-history"></i>
<span>操作日志</span>
</a>
</li>
</ul>
</aside>
<!-- 主内容区 -->
<main class="main-content">
<div class="content-header">
<div>
<h1 class="page-title">管理员仪表板</h1>
<div class="breadcrumb">
<a href="/">主页</a>
<i class="fas fa-chevron-right"></i>
<span>管理员仪表板</span>
</div>
</div>
<div class="current-time" id="currentTime"></div>
</div>
<!-- 统计卡片 -->
<div class="stats-grid">
<div class="stat-card">
<div class="stat-icon users">
<i class="fas fa-users"></i>
</div>
<div class="stat-content">
<div class="stat-value" id="totalUsers">1,248</div>
<div class="stat-label">总用户数</div>
<div class="stat-change positive">
<i class="fas fa-arrow-up"></i> 12 本周新增
</div>
</div>
</div>
<div class="stat-card">
<div class="stat-icon students">
<i class="fas fa-user-graduate"></i>
</div>
<div class="stat-content">
<div class="stat-value" id="totalStudents">3,567</div>
<div class="stat-label">学生总数</div>
<div class="stat-change positive">
<i class="fas fa-arrow-up"></i> 45 本周新增
</div>
</div>
</div>
<div class="stat-card">
<div class="stat-icon teachers">
<i class="fas fa-chalkboard-teacher"></i>
</div>
<div class="stat-content">
<div class="stat-value" id="totalTeachers">128</div>
<div class="stat-label">教师总数</div>
<div class="stat-change">
<i class="fas fa-minus"></i> 无变<E697A0><E58F98>? </div>
</div>
</div>
<div class="stat-card">
<div class="stat-icon courses">
<i class="fas fa-book"></i>
</div>
<div class="stat-content">
<div class="stat-value" id="totalCourses">89</div>
<div class="stat-label">课程总数</div>
<div class="stat-change positive">
<i class="fas fa-arrow-up"></i> 3 本周新增
</div>
</div>
</div>
</div>
<!-- 功能卡片 -->
<div class="function-grid">
<div class="function-card" onclick="window.location.href='user_management.html'">
<div class="function-icon">
<i class="fas fa-users"></i>
</div>
<h3 class="function-title">用户管理</h3>
<p class="function-description">
管理所有用户账户包括添加、编辑、删除用户设置用户角色和权限<E69D83><E99990>? </p>
<button class="btn btn-primary">进入管理</button>
</div>
<div class="function-card" onclick="window.location.href='student_management.html'">
<div class="function-icon">
<i class="fas fa-user-graduate"></i>
</div>
<h3 class="function-title">学生管理</h3>
<p class="function-description">
管理学生信息包括学籍管理、班级分配、信息维护和批量导入导出<E5AFBC><E587BA>? </p>
<button class="btn btn-primary">进入管理</button>
</div>
<div class="function-card" onclick="window.location.href='teacher_management.html'">
<div class="function-icon">
<i class="fas fa-chalkboard-teacher"></i>
</div>
<h3 class="function-title">教师管理</h3>
<p class="function-description">
管理教师信息包括教师分配、课程安排、权限设置和绩效考核<E88083><E6A0B8>? </p>
<button class="btn btn-primary">进入管理</button>
</div>
<div class="function-card" onclick="window.location.href='grade_statistics.html'">
<div class="function-icon">
<i class="fas fa-chart-bar"></i>
</div>
<h3 class="function-title">成绩统计</h3>
<p class="function-description">
查看全校成绩统计生成分析报告支持图表展示和数据导出<E5AFBC><E587BA>? </p>
<button class="btn btn-primary">查看统计</button>
</div>
</div>
<!-- 系统状<E7BB9F><E78AB6>?-->
<div class="system-status">
<h2 class="section-title">
<i class="fas fa-server"></i>
系统状<E7BB9F><E78AB6>? </h2>
<div class="status-list">
<div class="status-item">
<div class="status-indicator online"></div>
<div>
<div class="status-label">数据库服<EFBFBD><EFBFBD>?/div>
<div class="status-value">运行正常 | 响应时间: 12ms</div>
</div>
</div>
<div class="status-item">
<div class="status-indicator online"></div>
<div>
<div class="status-label">Web服务<EFBFBD><EFBFBD>?/div>
<div class="status-value">运行正常 | 在线用户: 156</div>
</div>
</div>
<div class="status-item">
<div class="status-indicator online"></div>
<div>
<div class="status-label">文件存储</div>
<div class="status-value">使用<EFBFBD><EFBFBD>? 65% | 剩余: 35GB</div>
</div>
</div>
<div class="status-item">
<div class="status-indicator warning"></div>
<div>
<div class="status-label">备份服务</div>
<div class="status-value">上次备份: 2天前 | 建议立即备份</div>
</div>
</div>
</div>
</div>
<!-- 最近活<E8BF91><E6B4BB>?-->
<div class="recent-activities">
<h2 class="section-title">
<i class="fas fa-history"></i>
最近活<E8BF91><E6B4BB>? </h2>
<ul class="activity-list">
<li class="activity-item">
<div class="activity-icon">
<i class="fas fa-user-plus"></i>
</div>
<div class="activity-content">
<div class="activity-title">新增学生用户</div>
<div class="activity-time">10分钟<EFBFBD><EFBFBD>?| 操作<E6938D><E4BD9C>? 管理<E7AEA1><E79086>?/div>
</div>
</li>
<li class="activity-item">
<div class="activity-icon">
<i class="fas fa-edit"></i>
</div>
<div class="activity-content">
<div class="activity-title">修改教师信息</div>
<div class="activity-time">1小时<EFBFBD><EFBFBD>?| 操作<E6938D><E4BD9C>? 管理<E7AEA1><E79086>?/div>
</div>
</li>
<li class="activity-item">
<div class="activity-icon">
<i class="fas fa-chart-bar"></i>
</div>
<div class="activity-content">
<div class="activity-title">生成成绩统计报告</div>
<div class="activity-time">3小时<EFBFBD><EFBFBD>?| 操作<E6938D><E4BD9C>? 系统</div>
</div>
</li>
<li class="activity-item">
<div class="activity-icon">
<i class="fas fa-download"></i>
</div>
<div class="activity-content">
<div class="activity-title">导出用户数据</div>
<div class="activity-time">5小时<EFBFBD><EFBFBD>?| 操作<E6938D><E4BD9C>? 管理<E7AEA1><E79086>?/div>
</div>
</li>
<li class="activity-item">
<div class="activity-icon">
<i class="fas fa-cog"></i>
</div>
<div class="activity-content">
<div class="activity-title">系统设置更新</div>
<div class="activity-time">1天前 | 操作<E6938D><E4BD9C>? 管理<E7AEA1><E79086>?/div>
</div>
</li>
</ul>
</div>
</main>
</div>
<script>
// 更新当前时间
function updateCurrentTime() {
const now = new Date();
const options = {
year: 'numeric',
month: 'long',
day: 'numeric',
weekday: 'long',
hour: '2-digit',
minute: '2-digit',
second: '2-digit'
};
document.getElementById('currentTime').textContent = now.toLocaleDateString('zh-CN', options);
}
// 页面加载时初始化
document.addEventListener('DOMContentLoaded', function() {
updateCurrentTime();
setInterval(updateCurrentTime, 1000);
// 退出登<E587BA><E799BB>? document.getElementById('logoutBtn').addEventListener('click', function() {
if (confirm('确定要退出登录吗<E5BD95><E59097>?)) {
// 清除登录状<E5BD95><E78AB6>? localStorage.removeItem('token');
localStorage.removeItem('userRole');
localStorage.removeItem('userInfo');
// 跳转到登录页<E5BD95><E9A1B5>? window.location.href = 'login.html';
}
});
// 加载用户信息
const userInfo = JSON.parse(localStorage.getItem('userInfo') || '{}');
if (userInfo.name) {
document.getElementById('adminName').textContent = userInfo.name;
document.getElementById('userName').textContent = userInfo.name;
}
});
</script>
</body>
</html>