v0.8.7测试

This commit is contained in:
2026-04-16 11:54:33 +08:00
parent 3a4e0357a3
commit 21b53375d7
4 changed files with 60 additions and 12 deletions

View File

@@ -27,7 +27,7 @@ from schemas.admin import (
AddPointsRequest, RevokeRequest, AddAdminRequest,
AddStudentRequest,
UpdateHomeworkStatusRequest, AddAttendanceRequest,
UpdateAdminRequest, DeleteAdminRequest
UpdateAdminRequest, DeleteAdminRequest, ResetPasswordRequest
)
from utils.response import success_response, error_response
from utils.logger import get_logger
@@ -439,7 +439,7 @@ async def delete_admin(request: Request, user_id: int):
@router.post("/reset-password/{user_id}")
async def reset_admin_password(request: Request, user_id: int):
async def reset_admin_password(request: Request, user_id: int, req: ResetPasswordRequest):
"""重置管理员密码(班主任)"""
user = await get_current_user(request)
is_teacher = await PermissionChecker.check_is_teacher(user["user_id"])
@@ -457,8 +457,8 @@ async def reset_admin_password(request: Request, user_id: int):
if target_user["user_type"] != "admin":
return error_response(message="只能重置管理员密码", code=400)
# 生成新密码
new_password = SecurityUtils.generate_random_password(8)
# 使用传入的新密码
new_password = req.new_password
password_hash = SecurityUtils.sha1_md5_password(new_password)
# 更新密码
@@ -471,6 +471,6 @@ async def reset_admin_password(request: Request, user_id: int):
details=f"重置管理员密码: {target_user['real_name']}({target_user['username']})",
ip=request.client.host
)
return success_response(data={"password": new_password}, message="密码重置成功")
return success_response(message="密码重置成功")
else:
return error_response(message="密码重置失败")

View File

@@ -98,3 +98,8 @@ class UpdateAdminRequest(BaseModel):
class DeleteAdminRequest(BaseModel):
"""删除管理员请求"""
user_id: int = Field(..., description="用户ID")
class ResetPasswordRequest(BaseModel):
"""重置密码请求"""
new_password: str = Field(..., min_length=6, max_length=50, description="新密码")

View File

@@ -121,8 +121,35 @@ include __DIR__ . '/../includes/header.php';
</div>
</div>
<!-- 重置密码模态框 -->
<div id="resetPasswordModal" class="modal">
<div class="modal-content">
<div class="modal-header">
<h3>重置密码</h3>
<button class="modal-close" onclick="closeModal('resetPasswordModal')">&times;</button>
</div>
<form onsubmit="event.preventDefault(); submitResetPassword()">
<input type="hidden" id="resetPasswordUserId">
<div class="form-group">
<label>管理员</label>
<input type="text" id="resetPasswordAdminName" disabled>
</div>
<div class="form-group">
<label>新密码</label>
<input type="text" id="newPassword" required minlength="6" placeholder="请输入新密码至少6位">
<small>密码长度至少6位</small>
</div>
<div class="modal-footer">
<button type="submit" class="btn btn-primary">确认重置</button>
<button type="button" class="btn" onclick="closeModal('resetPasswordModal')">取消</button>
</div>
</form>
</div>
</div>
<script>
var currentEditUserId = null;
var currentResetUserId = null;
async function loadAdmins() {
const res = await apiGet('/api/admin/list');
@@ -228,14 +255,30 @@ async function deleteAdmin(userId, realName) {
}
}
async function resetAdminPassword(userId, realName) {
if (!confirm(`确定要重置管理员 "${realName}" 的密码吗?`)) {
function resetAdminPassword(userId, realName) {
currentResetUserId = userId;
document.getElementById('resetPasswordUserId').value = userId;
document.getElementById('resetPasswordAdminName').value = realName;
document.getElementById('newPassword').value = '';
document.getElementById('resetPasswordModal').style.display = 'flex';
}
async function submitResetPassword() {
if (!currentResetUserId) return;
const newPassword = document.getElementById('newPassword').value;
if (!newPassword || newPassword.length < 6) {
showToast('密码长度至少6位', 'warning');
return;
}
const res = await apiPost(`/api/admin/reset-password/${userId}`, {});
const res = await apiPost(`/api/admin/reset-password/${currentResetUserId}`, {
new_password: newPassword
});
if (res && res.success) {
alert(`密码重置成功\n管理员${realName}\n新密码${res.data.password}\n请妥善保管并及时通知该管理员。`);
showToast('密码重置成功');
closeModal('resetPasswordModal');
} else {
showToast(res?.message || '密码重置失败', 'error');
}

View File

@@ -114,8 +114,8 @@ async function exportMoralityRecords() {
return;
}
// 获取所有历史记录(不分页,获取全部)
const historyRes = await apiGet('/api/admin/conduct/history', { page: 1, page_size: 10000 });
// 获取所有历史记录(获取全部API限制最大1000条
const historyRes = await apiGet('/api/admin/conduct/history', { page: 1, page_size: 1000 });
if (!historyRes || !historyRes.success) {
showToast('获取历史记录失败', 'error');
return;