Files
Stu_scores_system/validation.h
T

101 lines
3.4 KiB
C

/**
* @file validation.h
* @brief 数据验证函数头文件
* @note 包含学生信息各字段的验证函数声明
*/
#ifndef VALIDATION_H
#define VALIDATION_H
#include <stdbool.h>
// 数据验证函数
/**
* @brief 验证成绩是否有效
* @details 检查成绩是否在有效范围内(0-100分)
* @param score 要验证的成绩值
* @return 如果成绩有效返回true,否则返回false
* @note 有效成绩范围为0.0到100.0(包含边界值)
*/
bool isValidScore(float score);
/**
* @brief 验证学号是否有效
* @details 检查学号格式是否符合要求:非空且长度在合理范围内
* @param id 要验证的学号字符串
* @return 如果学号有效返回true,否则返回false
* @note 学号不能为空,长度必须在1到MAX_ID_LENGTH之间
* @warning 如果id为NULL,返回false
*/
bool isValidStudentId(const char* id);
/**
* @brief 验证姓名是否有效
* @details 检查姓名格式是否符合要求:非空且长度在合理范围内
* @param name 要验证的姓名字符串
* @return 如果姓名有效返回true,否则返回false
* @note 姓名不能为空,长度必须在1到MAX_NAME_LENGTH之间
* @warning 如果name为NULL,返回false
*/
bool isValidName(const char* name);
/**
* @brief 验证性别是否有效
* @details 检查性别是否为'M'(男)或'F'(女)
* @param gender 要验证的性别字符
* @return 如果性别有效返回true,否则返回false
* @note 只接受'M'或'F'两个值
*/
bool isValidGender(char gender);
/**
* @brief 验证年龄是否有效
* @details 检查年龄是否在合理范围内
* @param age 要验证的年龄值
* @return 如果年龄有效返回true,否则返回false
* @note 有效年龄范围为MIN_AGE到MAX_AGE(包含边界值)
*/
bool isValidAge(int age);
/**
* @brief 验证课程名称是否有效
* @details 检查课程名称格式是否符合要求:非空且长度在合理范围内
* @param courseName 要验证的课程名称字符串
* @return 如果课程名称有效返回true,否则返回false
* @note 课程名称不能为空,长度必须在1到MAX_COURSE_NAME_LENGTH之间
* @warning 如果courseName为NULL,返回false
*/
bool isValidCourseName(const char* courseName);
/**
* @brief 验证用户名是否有效
* @details 检查用户名格式是否符合要求:非空、长度合理且只包含字母数字
* @param username 要验证的用户名字符串
* @return 如果用户名有效返回true,否则返回false
* @note 用户名不能为空,长度必须在3到MAX_USERNAME_LENGTH之间,只能包含字母和数字
* @warning 如果username为NULL,返回false
*/
bool isValidUsername(const char* username);
/**
* @brief 验证密码强度是否符合要求
* @details 检查密码是否满足最低安全要求
* @param password 要验证的密码字符串
* @return 如果密码有效返回true,否则返回false
* @note 密码长度必须在6到MAX_PASSWORD_LENGTH之间
* @warning 如果password为NULL,返回false
*/
bool isValidPassword(const char* password);
/**
* @brief 验证数组索引是否在有效范围内
* @details 检查索引是否在指定范围内,防止数组越界
* @param index 要验证的索引值
* @param maxIndex 最大有效索引值(不包含)
* @return 如果索引有效返回true,否则返回false
* @note 有效索引范围为0到maxIndex-1
*/
bool isValidIndex(int index, int maxIndex);
#endif // VALIDATION_H