- 后端从 Python FastAPI 重写为 Go Gin(端口 56789) - 多班级完全隔离 - 超级管理员独立登录 - 课代表作业管理、排行榜分项排行 - 角色加减分上下限可配置 - 家长改密功能(可开关) - 周度/月度重置功能 - MySQL 5.7 兼容 - 43轮代码审查+全部修复 - Apache 2.0 许可证
143 lines
5.9 KiB
PHP
143 lines
5.9 KiB
PHP
<?php
|
||
/**
|
||
* 多班级版班级管理系统 - 登录入口
|
||
*
|
||
* 开发者: Canglan
|
||
* 联系方式: admin@sea-studio.top
|
||
* 版权归属: Sea Network Technology Studio
|
||
* 许可证: Apache License 2.0
|
||
*
|
||
* 版权所有 © Sea Network Technology Studio
|
||
*/
|
||
|
||
require_once __DIR__ . '/config.php';
|
||
|
||
if (isset($_SESSION['user_id']) && isset($_SESSION['user_type'])) {
|
||
$redirect = [
|
||
'student' => '/student/dashboard.php',
|
||
'parent' => '/parent/dashboard.php',
|
||
'admin' => '/admin/dashboard.php',
|
||
'super_admin' => '/admin/dashboard.php'
|
||
];
|
||
header("Location: " . ($redirect[$_SESSION['user_type']] ?? '/index.php'));
|
||
exit();
|
||
}
|
||
?>
|
||
<!DOCTYPE html>
|
||
<html lang="zh-CN">
|
||
<head>
|
||
<meta charset="UTF-8">
|
||
<meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=no">
|
||
<title><?php echo htmlspecialchars(SITE_NAME, ENT_QUOTES, 'UTF-8'); ?> - 登录</title>
|
||
<link rel="stylesheet" href="/assets/css/style.css">
|
||
</head>
|
||
<body>
|
||
<div class="login-container">
|
||
<div class="login-header">
|
||
<h1><?php echo htmlspecialchars(SITE_NAME, ENT_QUOTES, 'UTF-8'); ?></h1>
|
||
<p>学生 / 家长 / 管理员 统一登录</p>
|
||
</div>
|
||
|
||
<form id="loginForm" class="login-form">
|
||
<div class="form-group">
|
||
<label>用户名</label>
|
||
<input type="text" id="username" name="username" required autocomplete="off" placeholder="学号/手机号/管理员账号">
|
||
</div>
|
||
<div class="form-group">
|
||
<label>密码</label>
|
||
<input type="password" id="password" name="password" required placeholder="请输入密码">
|
||
</div>
|
||
<button type="submit" class="btn-login">登 录</button>
|
||
<div id="errorMsg" class="error-msg" style="display: none;"></div>
|
||
</form>
|
||
|
||
<div class="login-footer">
|
||
<p>© <?php echo date('Y'); ?> Sea Network Technology Studio</p>
|
||
<?php if (defined('ICP_ENABLED') && ICP_ENABLED && defined('ICP_NUMBER') && ICP_NUMBER): ?>
|
||
<p><a href="https://beian.miit.gov.cn/" target="_blank" rel="noopener noreferrer"><?php echo htmlspecialchars(ICP_NUMBER); ?></a></p>
|
||
<?php endif; ?>
|
||
</div>
|
||
</div>
|
||
|
||
<script>
|
||
window.API_BASE_URL = <?php echo json_encode(API_BASE_URL); ?>;
|
||
window.JWT_STORAGE_KEY = <?php echo json_encode(JWT_STORAGE_KEY); ?>;
|
||
window.USER_STORAGE_KEY = <?php echo json_encode(USER_STORAGE_KEY); ?>;
|
||
|
||
document.getElementById('loginForm').addEventListener('submit', async (e) => {
|
||
e.preventDefault();
|
||
|
||
const username = document.getElementById('username').value.trim();
|
||
const password = document.getElementById('password').value;
|
||
const errorMsg = document.getElementById('errorMsg');
|
||
|
||
if (!username || !password) {
|
||
showError('请填写用户名和密码');
|
||
return;
|
||
}
|
||
|
||
try {
|
||
const response = await fetch(`${API_BASE_URL}/api/auth/login`, {
|
||
method: 'POST',
|
||
headers: { 'Content-Type': 'application/json' },
|
||
body: JSON.stringify({ username, password })
|
||
});
|
||
|
||
const data = await response.json();
|
||
|
||
if (data.success && data.data) {
|
||
const userData = data.data;
|
||
|
||
// 保存 Token 和用户信息到 localStorage
|
||
localStorage.setItem(JWT_STORAGE_KEY, userData.token);
|
||
localStorage.setItem(USER_STORAGE_KEY, JSON.stringify(userData));
|
||
|
||
// 同步设置 PHP Session(保持 Session + Token 双轨制认证)
|
||
try {
|
||
const sessionResponse = await fetch('/api/save_session.php', {
|
||
method: 'POST',
|
||
headers: {
|
||
'Content-Type': 'application/json',
|
||
'Authorization': 'Bearer ' + userData.token
|
||
},
|
||
body: JSON.stringify({
|
||
user_id: userData.user_id,
|
||
user_type: userData.user_type,
|
||
username: userData.username,
|
||
real_name: userData.real_name,
|
||
role: userData.role || '',
|
||
student_id: userData.student_id || null,
|
||
class_id: userData.class_id || null,
|
||
class_name: userData.class_name || ''
|
||
})
|
||
});
|
||
|
||
if (!sessionResponse.ok) {
|
||
console.warn('Session 同步失败,但继续跳转');
|
||
}
|
||
} catch (sessionError) {
|
||
console.warn('Session 同步异常:', sessionError);
|
||
}
|
||
|
||
// 跳转到对应端首页
|
||
window.location.href = userData.redirect;
|
||
} else {
|
||
showError(data.message || '登录失败');
|
||
}
|
||
} catch (error) {
|
||
console.error('登录错误:', error);
|
||
showError('网络错误,请检查后端服务是否启动');
|
||
}
|
||
});
|
||
|
||
function showError(msg) {
|
||
const errorMsg = document.getElementById('errorMsg');
|
||
errorMsg.textContent = msg;
|
||
errorMsg.style.display = 'block';
|
||
setTimeout(() => {
|
||
errorMsg.style.display = 'none';
|
||
}, 3000);
|
||
}
|
||
</script>
|
||
</body>
|
||
</html>
|