100 lines
3.4 KiB
PHP
100 lines
3.4 KiB
PHP
<?php
|
||
/**
|
||
* 班级操行分管理系统 - 管理端修改密码
|
||
*
|
||
* 开发者: Canglan
|
||
* 联系方式: admin@sea-studio.top
|
||
* 版权归属: Sea Network Technology Studio
|
||
* 许可证: MIT License
|
||
*
|
||
* 版权所有 © Sea Network Technology Studio
|
||
*/
|
||
|
||
require_once __DIR__ . '/../config.php';
|
||
|
||
if (!isset($_SESSION['user_id']) || $_SESSION['user_type'] !== 'admin') {
|
||
header('Location: /index.php');
|
||
exit();
|
||
}
|
||
|
||
$page_title = '修改密码';
|
||
$role = $_SESSION['role'] ?? '';
|
||
include __DIR__ . '/../includes/header.php';
|
||
?>
|
||
|
||
<div class="nav">
|
||
<a href="/admin/dashboard.php" class="nav-item">首页</a>
|
||
<a href="/admin/students.php" class="nav-item">学生管理</a>
|
||
<?php if ($role === '班主任' || $role === '班长'): ?>
|
||
<a href="/admin/conduct.php" class="nav-item">操行分管理</a>
|
||
<?php endif; ?>
|
||
<?php if ($role === '班主任' || $role === '科代表'): ?>
|
||
<a href="/admin/homework.php" class="nav-item">作业管理</a>
|
||
<?php endif; ?>
|
||
<?php if ($role === '班主任' || $role === '考勤委员'): ?>
|
||
<a href="/admin/attendance.php" class="nav-item">考勤管理</a>
|
||
<?php endif; ?>
|
||
<?php if ($role === '班主任'): ?>
|
||
<a href="/admin/subjects.php" class="nav-item">科目管理</a>
|
||
<a href="/admin/admins.php" class="nav-item">管理员管理</a>
|
||
<?php endif; ?>
|
||
<a href="/admin/history.php" class="nav-item">历史记录</a>
|
||
<a href="/admin/password.php" class="nav-item active">修改密码</a>
|
||
</div>
|
||
|
||
<div class="container">
|
||
<div class="card">
|
||
<div class="card-title">修改密码</div>
|
||
<form id="passwordForm">
|
||
<div class="form-group">
|
||
<label>原密码 <span style="color:red;">*</span></label>
|
||
<input type="password" id="oldPassword" required>
|
||
</div>
|
||
<div class="form-group">
|
||
<label>新密码 <span style="color:red;">*</span></label>
|
||
<input type="password" id="newPassword" required>
|
||
<small>密码长度6-20位,需包含字母和数字</small>
|
||
</div>
|
||
<div class="form-group">
|
||
<label>确认新密码 <span style="color:red;">*</span></label>
|
||
<input type="password" id="confirmPassword" required>
|
||
</div>
|
||
<button type="submit" class="btn btn-primary">确认修改</button>
|
||
</form>
|
||
</div>
|
||
</div>
|
||
|
||
<script>
|
||
document.getElementById('passwordForm').addEventListener('submit', async (e) => {
|
||
e.preventDefault();
|
||
|
||
const oldPassword = document.getElementById('oldPassword').value;
|
||
const newPassword = document.getElementById('newPassword').value;
|
||
const confirmPassword = document.getElementById('confirmPassword').value;
|
||
|
||
if (newPassword !== confirmPassword) {
|
||
showToast('两次输入的新密码不一致', 'error');
|
||
return;
|
||
}
|
||
|
||
if (newPassword.length < 6 || newPassword.length > 20) {
|
||
showToast('密码长度需为6-20位', 'error');
|
||
return;
|
||
}
|
||
|
||
const res = await apiPost('/api/auth/change-password', {
|
||
old_password: oldPassword,
|
||
new_password: newPassword
|
||
});
|
||
|
||
if (res && res.success) {
|
||
showToast('密码修改成功,请重新登录');
|
||
setTimeout(() => logout(), 1500);
|
||
} else {
|
||
showToast(res?.message || '密码修改失败', 'error');
|
||
}
|
||
});
|
||
</script>
|
||
<script src="/assets/js/admin.js"></script>
|
||
|
||
<?php include __DIR__ . '/../includes/footer.php'; ?>
|