110 lines
3.8 KiB
C
110 lines
3.8 KiB
C
/**
|
|
* @file user_manage.h
|
|
* @brief 用户管理实现文件
|
|
* @note 实现用户认证和管理功能函数声明
|
|
*/
|
|
|
|
#ifndef USER_MANAGE_H
|
|
#define USER_MANAGE_H
|
|
|
|
#include "config.h"
|
|
|
|
/**
|
|
* @brief 处理用户登录
|
|
* @details 提供用户登录验证功能,验证用户名和密码的正确性
|
|
* 登录成功后设置当前用户信息和管理员权限
|
|
* @return int 登录成功返回1,失败返回0
|
|
* @note 登录过程:
|
|
* 1. 获取用户输入的用户名和密码
|
|
* 2. 遍历用户数组进行验证
|
|
* 3. 验证成功则设置currentUser和isCurrentUserAdmin
|
|
* @note 设置的全局变量:
|
|
* - currentUser: 当前登录用户名
|
|
* - isCurrentUserAdmin: 当前用户是否为管理员
|
|
*/
|
|
int loginSystem();
|
|
|
|
/**
|
|
* @brief 从文件加载用户数据
|
|
* @details 从USERS_FILE文件中读取用户数据到内存
|
|
* 如果文件不存在,则创建默认的管理员和普通用户账户
|
|
* @note 文件格式:每行格式为 "username:password:isAdmin"
|
|
* 其中isAdmin为1表示管理员,0表示普通用户
|
|
* @note 默认账户:
|
|
* - 管理员:用户名admin,密码123456
|
|
* - 普通用户:用户名teacher,密码password
|
|
* @warning 如果文件格式错误,可能导致数据加载不完整
|
|
*/
|
|
void loadUsersFromFile();
|
|
|
|
/**
|
|
* @brief 将用户数据保存到文件
|
|
* @details 将内存中的用户数据写入到USERS_FILE文件中
|
|
* 采用文本格式存储,每个用户占一行
|
|
* @note 文件格式:每行格式为 "username:password:isAdmin"
|
|
* 其中isAdmin为1表示管理员,0表示普通用户
|
|
* @warning 如果文件无法打开,将显示错误信息
|
|
*/
|
|
void saveUsersToFile();
|
|
|
|
/**
|
|
* @brief 增加用户账户
|
|
* @details 提供交互式界面添加新的用户账户
|
|
* 包括用户名唯一性检查、密码设置和用户类型选择
|
|
* @note 添加流程:
|
|
* 1. 检查用户数量是否达到上限
|
|
* 2. 输入新用户名并检查唯一性
|
|
* 3. 设置密码
|
|
* 4. 选择用户类型(普通用户/管理员)
|
|
* 5. 保存到文件并更新数据修改标志
|
|
* @warning 如果用户数量已达MAX_USERS上限,将拒绝添加
|
|
* @warning 如果用户名已存在,将拒绝添加
|
|
*/
|
|
void addUserAccount();
|
|
|
|
/**
|
|
* @brief 删除用户账户
|
|
* @details 提供交互式界面删除指定的用户账户
|
|
* 包含安全检查,防止删除当前登录用户和最后一个用户
|
|
* @note 删除限制:
|
|
* - 不能删除当前登录的用户
|
|
* - 系统至少需要保留一个用户账户
|
|
* @note 删除过程:
|
|
* 1. 输入要删除的用户名
|
|
* 2. 进行安全检查
|
|
* 3. 查找用户并删除
|
|
* 4. 重新排列用户数组
|
|
* 5. 保存到文件并更新数据修改标志
|
|
* @warning 删除操作不可逆,请谨慎操作
|
|
*/
|
|
void deleteUserAccount();
|
|
|
|
/**
|
|
* @brief 修改用户密码
|
|
* @details 提供交互式界面修改指定用户的密码
|
|
* 管理员可以修改任何用户的密码
|
|
* @note 修改流程:
|
|
* 1. 输入要修改密码的用户名
|
|
* 2. 查找用户是否存在
|
|
* 3. 输入新密码
|
|
* 4. 更新用户密码
|
|
* 5. 保存到文件并更新数据修改标志
|
|
* @warning 密码修改后立即生效,用户需要使用新密码登录
|
|
*/
|
|
void modifyUserPassword();
|
|
|
|
/**
|
|
* @brief 查看所有用户
|
|
* @details 显示系统中所有用户的信息列表
|
|
* 包括用户名、用户类型和当前登录状态
|
|
* @note 显示内容:
|
|
* - 用户名
|
|
* - 用户类型(管理员/普通用户)
|
|
* - 状态(标识当前登录用户)
|
|
* - 总用户数统计
|
|
* @note 表格格式显示,便于查看和管理
|
|
* @warning 如果没有用户数据,将显示警告信息
|
|
*/
|
|
void viewAllUsers();
|
|
|
|
#endif // USER_MANAGE_H
|