接下来将要实现用户管理模块的相关功能,用户管理模块的主要功能包括增加用户,查找用户以及保存用户等功能,查找用户时,如果查找成功,充许对查找到用户进行更新或删除操作。如果查找不成功,则给出相应的提示信息。

打开user.c文件, 首先包含要用到的头文件,同时还需要定义一个常量用来表示存储用户信息的文件,定义一个单链表的头节点,并初试化为空。具体实现如下:

  1. #pragma warning(disable:4996)
  1.  
  1. //Header Info
  1. #include <stdio.h>
  1. #include <stdlib.h>
  1. #include <string.h> //使用memset函数 memset是字符串处理函数
  1. #include <conio.h> //使用kbhit()函数 来星号显示密码
  1. #include "user.h"
  1. #include <assert.h>
  1.  
  1. #define USER_FILE "user.dat" //表示用来存储用户信息的文件
  1. user* first_user = NULL; //定义一个头节点, 初始化为NULL

.csharpcode, .csharpcode pre
{
font-size: small;
color: black;
font-family: consolas, "Courier New", courier, monospace;
background-color: #ffffff;
/*white-space: pre;*/
}
.csharpcode pre { margin: 0em; }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000ff; }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
{
background-color: #f4f4f4;
width: 100%;
margin: 0em;
}
.csharpcode .lnum { color: #606060; }

下面来实现主要的处理函数:

1.新增用户

函数名称:add_user

函数功能:新增一个用户信息,在管理员操作菜单中,选择6调用本函数,由于用户名不充许重复,所以用户输入用户名和密码后,需要在用户链表中查询用户名是否重复。

处理流程:1创建一个用户节点new_user. 2初始化new_user. 3.调用函数input_user(), 提示用户输入用户信息,为new_user赋值。4.调用函数find_user(),查找用户名是否存在,如果新增用户名不存在,则增加该用户,否则提示相应的信息。具体实现如下:

  1. //新增用户信息
  1. void add_user()
  1. {
  1. char try_again = 'Y';
  1. user* p = NULL;
  1. user* new_user= (user*)malloc(sizeof(user));
  1. assert(new_user != NULL);
  1. while(try_again == 'Y' || try_again == 'y')
  1. {
  1. memset(new_user,0,sizeof(user));
  1. printf(">增加用户信息...\n");
  1. input_user(&(new_user->ui));
  1. //对比用户名是否已存在
  1. p = find_user(new_user->ui.username);
  1. if(NULL == p)
  1. {
  1. p = get_last_user();
  1. p->next = new_user;
  1. break;
  1. }
  1.  
  1. printf(">用户[ %s ]已存在.重新输入?(y or n ):",new_user->ui.username);
  1. fflush(stdin);
  1. try_again = getchar();
  1. if(try_again !='y' && try_again !='Y')
  1. {
  1. free(new_user);
  1. }
  1. }
  1. }

.csharpcode, .csharpcode pre
{
font-size: small;
color: black;
font-family: consolas, "Courier New", courier, monospace;
background-color: #ffffff;
/*white-space: pre;*/
}
.csharpcode pre { margin: 0em; }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000ff; }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
{
background-color: #f4f4f4;
width: 100%;
margin: 0em;
}
.csharpcode .lnum { color: #606060; }

2.查找用户

函数名称:search_user

函数功能:查找用户信息,在管理员操作菜单中选择7调用本函数,提示用户输入要查询的用户名,在用户链表中进行查找,如果查找成功,显示该用户信息,并提示按d/D键删除该用户信息,按u/U键更新该用户信息。如果查找不成功,则给出提示信息。

处理流程:1提示用户输入要查询的用户名,根据用户名进行查找。2调用函数find_user()查找输入的用户名信息,若存在,则将用户信息赋值给节点p。3如果没有找到,则给出提示信息,如果找到了则调用show_user()函数,显示该用户信息,并提示用户可以对该用户信息进行删除或更新操作。具体实现如下:

  1. void search_user()
  1. {
  1. char input_char = 'Y';
  1. char username[MAX_USERNAME] = {0};
  1. user* p = NULL;
  1. while(input_char == 'Y' || input_char == 'y')
  1. {
  1. printf(">查找用户信息...\n");
  1. printf(">请输入用户名(最大长度为 %d):",MAX_USERNAME);
  1. fflush(stdin);
  1. scanf("%s",username);
  1. p = find_user(username);
  1. if(p == NULL)
  1. {
  1. printf(">未找到用户:%s的信息.继续查找?(y or n)",username);
  1. fflush(stdin);
  1. input_char = getchar();
  1. continue;
  1. }
  1. show_user(&(p->ui));
  1. printf(">查找成功!按d/D键删除该用户,按u/U键更新该用户信息,按其它键返回!");
  1. fflush(stdin);
  1. input_char = getchar();
  1. if(input_char == 'd'||input_char == 'D')
  1. {
  1. delete_user(p);
  1. }else if(input_char =='U' || input_char == 'u')
  1. {
  1. update_user(p);
  1. }
  1. printf(">继续查找其它用户吗?(y or n):");
  1. fflush(stdin);
  1. input_char = getchar();
  1. }
  1. }

.csharpcode, .csharpcode pre
{
font-size: small;
color: black;
font-family: consolas, "Courier New", courier, monospace;
background-color: #ffffff;
/*white-space: pre;*/
}
.csharpcode pre { margin: 0em; }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000ff; }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
{
background-color: #f4f4f4;
width: 100%;
margin: 0em;
}
.csharpcode .lnum { color: #606060; }

3.删除用户信息

函数名称:delete_user

函数功能:管理员在查找到用户成功时,充许对其找到的用户信息进行删除操作。

处理流程:提示用户是否确认要删除该用户信息,如果输入"y"或"Y", 则删除该用户信息,否则继续查找。具体实现如下:

  1. void delete_user(user* p)
  1. {
  1. char input_char = 'N';
  1. user* previous = NULL;
  1. printf(">确认要删除用户 [%s] 吗?(y or n):",p->ui.username);
  1. fflush(stdin);
  1. input_char = getchar();
  1. if(input_char == 'y' || input_char == 'Y')
  1. {
  1. previous = get_previous_user(p);
  1. previous->next = p->next;
  1. free(p);
  1. p = NULL;
  1. }
  1. }

.csharpcode, .csharpcode pre
{
font-size: small;
color: black;
font-family: consolas, "Courier New", courier, monospace;
background-color: #ffffff;
/*white-space: pre;*/
}
.csharpcode pre { margin: 0em; }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000ff; }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
{
background-color: #f4f4f4;
width: 100%;
margin: 0em;
}
.csharpcode .lnum { color: #606060; }

4.更新用户信息

函数名称:update_user

函数功能:管理员在查找到用户成功时,充许对找到的用户信息进行更新操作。

处理流程:1创建一个用户信息new_p, 2调用函数input_user()往new_p中输入用户信息。3在用户链表中查找该用户是否存在,如果输入的用户名已存在,并且这个用户名不是原来的p,系统给出相关提示信息,等待下一步操作,否则进行更新操作。具体实现如下:

  1. //更新用户信息
  1. void update_user(user* p)
  1. {
  1. char input = 'y';
  1. user* exist_p = NULL;
  1. user_info* new_p = (user_info*)malloc(sizeof(user_info));
  1. assert(new_p != NULL);
  1. while(input == 'y'|| input == 'Y')
  1. {
  1. memset(new_p,0,sizeof(user_info));
  1. input_user(new_p);
  1. //查找当前更新时输入的用户名是否已经存在
  1. exist_p = find_user(new_p->username);
  1. //如果单链表中存在这个用户名,且新更新的用户名和刚才被更新的用户名不相等
  1. //则表示不能进行更新
  1. if(exist_p != NULL && exist_p != p)
  1. {
  1. printf(">用户[%s] 已存在.请选用其它用户名.\n",exist_p->ui.username);
  1. printf(">重新输入?(y or n):");
  1. fflush(stdin);
  1. input = getchar();
  1. }else{
  1. strcpy(p->ui.username,new_p->username);
  1. strcpy(p->ui.password,new_p->password);
  1. p->ui.user_type = new_p->user_type;
  1. break;
  1. }
  1. }
  1. free(new_p);
  1. }

.csharpcode, .csharpcode pre
{
font-size: small;
color: black;
font-family: consolas, "Courier New", courier, monospace;
background-color: #ffffff;
/*white-space: pre;*/
}
.csharpcode pre { margin: 0em; }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000ff; }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
{
background-color: #f4f4f4;
width: 100%;
margin: 0em;
}
.csharpcode .lnum { color: #606060; }

5.保存用户信息

1.函数名称:save_users

函数功能:管理员操作菜单中选择8调用本函数,用来保存用户信息,函数中通过调用save_users_to_file()函数将用户信息保存到文件中,并给出提示信息,具体实现如下:

  1. void save_users()
  1. {
  1. save_users_to_file();
  1. printf(">保存成功!按任意键返回...");
  1. fflush(stdin);
  1. getchar();
  1. }

2.保存用户信息到文件

函数名称:save_users_to_file
函数功能:将用户信息保存到文件。具体实现如下:
  1. void save_users_to_file()
  1. {
  1. FILE* fp = fopen(USER_FILE,"wb");
  1. user* p = first_user;
  1. while(p != NULL)
  1. {
  1. fwrite(&(p->ui),sizeof(user_info),1,fp);
  1. fseek(fp,0,SEEK_END);
  1. p = p->next;
  1. }
  1.  
  1. fclose(fp);
  1. }

.csharpcode, .csharpcode pre
{
font-size: small;
color: black;
font-family: consolas, "Courier New", courier, monospace;
background-color: #ffffff;
/*white-space: pre;*/
}
.csharpcode pre { margin: 0em; }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000ff; }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
{
background-color: #f4f4f4;
width: 100%;
margin: 0em;
}
.csharpcode .lnum { color: #606060; }

.csharpcode, .csharpcode pre
{
font-size: small;
color: black;
font-family: consolas, "Courier New", courier, monospace;
background-color: #ffffff;
/*white-space: pre;*/
}
.csharpcode pre { margin: 0em; }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000ff; }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
{
background-color: #f4f4f4;
width: 100%;
margin: 0em;
}
.csharpcode .lnum { color: #606060; }

上面完成了用户管理模块的主要功能函数,但是还需要一些辅助函数才能完整的实现用户管理模块的功能,这些辅助函数实现如下:

1.用户模块初始化

函数名称:init_user

函数功能:设定默认的用户名为admin, 密码为123,权限为管理员,如果存储用户信息的文件不存在则创建一个,如果创建失败则给出提示信息。具体实现如下:

  1. void init_user()
  1. {
  1. FILE* fp = NULL;
  1. user_info default_admin;
  1. strcpy(default_admin.username,"admin");
  1. strcpy(default_admin.password,"123");
  1. default_admin.user_type = ADMIN;
  1. fp = fopen(USER_FILE,"r");
  1. if(NULL == fp)
  1. {
  1. fp = fopen(USER_FILE, "wb");
  1. fwrite(&default_admin,sizeof(user_info),1,fp);
  1. }
  1. fclose(fp);
  1. }

.csharpcode, .csharpcode pre
{
font-size: small;
color: black;
font-family: consolas, "Courier New", courier, monospace;
background-color: #ffffff;
/*white-space: pre;*/
}
.csharpcode pre { margin: 0em; }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000ff; }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
{
background-color: #f4f4f4;
width: 100%;
margin: 0em;
}
.csharpcode .lnum { color: #606060; }

2.加载用户信息

函数名称:load_users

函数功能:从用户文件中将用户信息加载到用户链表中。具体实现如下:

  1. void load_users()
  1. {
  1. user* u = NULL;
  1. user* last = NULL;
  1. FILE* fp = NULL;
  1. int count = 0;
  1. u = (user*)malloc(sizeof(user));
  1. memset(u,0,sizeof(user));
  1. u->next = NULL;
  1. //以只读方式打开二进制文件USER_FILE
  1. fp = fopen(USER_FILE , "rb");
  1. //将文件指针置为文件开始处
  1. fseek(fp,0,SEEK_SET);
  1. //从文件中逐个读取用户信息,并把它们存放到用户链表中
  1. while(fread(&(u->ui),sizeof(user_info),1,fp) == 1)
  1. {
  1. if(first_user == NULL)
  1. {
  1. first_user = u;
  1. }else{
  1. last = get_last_user();
  1. last->next = u;
  1. }
  1. count++;
  1. //以user_info长度为单位相对文件开始位置
  1. //偏移文件指针的位置
  1. fseek(fp,count*sizeof(user_info),SEEK_SET);
  1. u = (user*)malloc(sizeof(user));
  1. memset(u,0,sizeof(user));
  1. u->next = NULL;
  1. }
  1. free(u);
  1. u = NULL;
  1. fclose(fp);
  1. }

.csharpcode, .csharpcode pre
{
font-size: small;
color: black;
font-family: consolas, "Courier New", courier, monospace;
background-color: #ffffff;
/*white-space: pre;*/
}
.csharpcode pre { margin: 0em; }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000ff; }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
{
background-color: #f4f4f4;
width: 100%;
margin: 0em;
}
.csharpcode .lnum { color: #606060; }

3.判断用户类型

函数名称:login

函数功能:用户登录功能,如果输入正确,返回用户类型。

处理流程:1.提示输入登录名和密码,2.在用户链表中查找是否存在该登录名,若不存在,则给出提示信息,否则继续判断密码是否匹配,如果匹配成功,则返回用户权限类型,否则给出提示信息。具体实现如下:

  1. USER_TYPE login()
  1. {
  1. char username[MAX_USERNAME] = {0};
  1. char password[MAX_PASSWORD] = {0};
  1. int j = 0;
  1. char try_again = 'Y';
  1. user* p = NULL;
  1. while(try_again == 'y' || try_again == 'Y')
  1. {
  1. printf("请输入用户名:");
  1. fflush(stdin);
  1. scanf("%s",username);
  1. printf(" 请输入密码:");
  1. fflush(stdin);
  1. //scanf("%s",password);
  1. //密码输入处理:输入一个字符,回显一个星号
  1. getLine(password,MAX_PASSWORD);
  1. //printf("\n");
  1. p = find_user(username);
  1. if(p == NULL)
  1. {
  1. printf("\n用户名输入有误.请重试!\n");
  1. }else if(strcmp(p->ui.password,password) != 0)
  1. {
  1. printf("\n密码输入有误.请重试!按任意键继续...\n");
  1. }else{
  1. return p->ui.user_type;
  1. }
  1. printf(">重新输入吗?按其它键退出系统(y or Y 继续):");
  1. fflush(stdin);
  1. try_again = getchar();
  1. }
  1. exit(0);
  1. }
  1.  
  1. //密码输入处理,输入一个字符就回显一个星号
  1. char *getLine(char *buf,int len)
  1. {
  1. int i = 0;
  1. char ch;
  1. fflush(stdin);
  1. /*while(i<len-1 && '\n' !=(ch = kbhit()))*/
  1. while(i<len-1)
  1. {
  1. //ch 第一次接收到一个字符之后, 以后一直存在这个字符,所以输入失效
  1. /*if('\0' != ch){*/
  1. if(0 != kbhit()){
  1. //kbhit()只能检测到键盘是否有键位按下,如果有则返回非零值,否则返回零
  1. //返回的这个非零值并非代码键位的ASCII值,所以返回值不能用
  1. //getchar()用来接收输入的字符串,输入一个就回显一个直到遇到空格或回车
  1. //才停止接收输入
  1. //ch = getchar();
  1. ch = getch();
  1. //c中 \r 才是代表 回车符
  1. if(ch == '\r') break;
  1. putchar('*');
  1. buf[i] = ch;
  1. ++i;
  1. }
  1. }
  1. buf[i] = '\0';
  1. return buf;
  1. }

.csharpcode, .csharpcode pre
{
font-size: small;
color: black;
font-family: consolas, "Courier New", courier, monospace;
background-color: #ffffff;
/*white-space: pre;*/
}
.csharpcode pre { margin: 0em; }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000ff; }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
{
background-color: #f4f4f4;
width: 100%;
margin: 0em;
}
.csharpcode .lnum { color: #606060; }

4.清除用户链表

函数名称:clear_users

函数功能:从内存中清除用户链表中的内容。具体实现如下:

  1. void clear_users()
  1. {
  1. user* p = NULL;
  1. //从头节点往后一个个清空
  1. while(first_user != NULL)
  1. {
  1. if(first_user->next != NULL)
  1. {
  1. p = first_user;
  1. first_user = first_user->next;
  1. free(p);
  1. p = NULL;
  1. }else{
  1. free(first_user);
  1. first_user = NULL;
  1. }
  1. }
  1. }

.csharpcode, .csharpcode pre
{
font-size: small;
color: black;
font-family: consolas, "Courier New", courier, monospace;
background-color: #ffffff;
/*white-space: pre;*/
}
.csharpcode pre { margin: 0em; }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000ff; }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
{
background-color: #f4f4f4;
width: 100%;
margin: 0em;
}
.csharpcode .lnum { color: #606060; }

5.取用户链表中的最后一个节点

函数名称:get_last_user

函数功能:取得用户链表中的最后一个节点并返回该节点指针。具体实现如下:

  1. user* get_last_user()
  1. {
  1. user* p = first_user;
  1. while((NULL != p) &&(p->next != NULL))
  1. {
  1. p = p->next;
  1. }
  1. return p;
  1. }

.csharpcode, .csharpcode pre
{
font-size: small;
color: black;
font-family: consolas, "Courier New", courier, monospace;
background-color: #ffffff;
/*white-space: pre;*/
}
.csharpcode pre { margin: 0em; }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000ff; }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
{
background-color: #f4f4f4;
width: 100%;
margin: 0em;
}
.csharpcode .lnum { color: #606060; }

6.取某节点的前驱节点

函数名称:get_previous_user

函数功能:取得节点p的前驱节点并返回该节点的指针。具体实现如下:

  1. user* get_previous_user(user* p)
  1. {
  1. user* previous = first_user;
  1. while(previous != NULL)
  1. {
  1. if(previous->next == p)
  1. {
  1. break;
  1. }
  1. previous = previous->next;
  1. }
  1. return previous;
  1. }

.csharpcode, .csharpcode pre
{
font-size: small;
color: black;
font-family: consolas, "Courier New", courier, monospace;
background-color: #ffffff;
/*white-space: pre;*/
}
.csharpcode pre { margin: 0em; }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000ff; }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
{
background-color: #f4f4f4;
width: 100%;
margin: 0em;
}
.csharpcode .lnum { color: #606060; }

7.显示用户信息

函数名称:show_user

函数功能:显示用户信息。具体实现如下:

  1. void show_user(user_info* info)
  1. {
  1. printf("------------------------------------------\n");
  1. printf(" 用户名:%s\n",info->username);
  1. printf(" 密码:%s\n",info->password);
  1. printf("用户类型:%s\n",info->user_type == ADMIN ? "admin" : "user");
  1. printf("\n");
  1. }

.csharpcode, .csharpcode pre
{
font-size: small;
color: black;
font-family: consolas, "Courier New", courier, monospace;
background-color: #ffffff;
/*white-space: pre;*/
}
.csharpcode pre { margin: 0em; }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000ff; }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
{
background-color: #f4f4f4;
width: 100%;
margin: 0em;
}
.csharpcode .lnum { color: #606060; }

8.输入用户信息

函数名称:input_user

函数功能:提示用户输入用户相关信息,具体实现如下:

  1. void input_user(user_info* info)
  1. {
  1. printf(">请输入用户名(最大长度为 %d):",MAX_USERNAME);
  1. fflush(stdin);
  1. scanf("%s",info->username);
  1. printf(">请输入密码(最大长度为 %d):",MAX_PASSWORD);
  1. fflush(stdin);
  1. scanf("%s",info->password);
  1. printf(">请输入用户类型(%d 是管理员,%d 是普通用户):",ADMIN,USER);
  1. fflush(stdin);
  1. scanf("%d",&(info->user_type));
  1. }

.csharpcode, .csharpcode pre
{
font-size: small;
color: black;
font-family: consolas, "Courier New", courier, monospace;
background-color: #ffffff;
/*white-space: pre;*/
}
.csharpcode pre { margin: 0em; }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000ff; }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
{
background-color: #f4f4f4;
width: 100%;
margin: 0em;
}
.csharpcode .lnum { color: #606060; }

9查找一个用户

函数名称:find_user

函数功能:从用户链表中查找指定的用户名是否存在,若存在则返回该用户节点指针,否则返回NULL。具体实现如下:

  1. user* find_user(char* name)
  1. {
  1. user* p = first_user;
  1. int is_found = 0;
  1. while(p != NULL)
  1. {
  1. //字段比对,如果相同则strcmp返回0
  1. if(strcmp(p->ui.username,name) == 0)
  1. {
  1. is_found = 1;
  1. break;
  1. }
  1. p = p->next;
  1. }
  1. if(is_found)
  1. {
  1. return p;
  1. }
  1. return NULL;
  1. }

到此为止,图书管理系统的三大功能模块:登录管理模块,图书信息管理模块和用户信息管理模块已基本实现完毕,接下来是系统操作过程分析,具体情况请转入:<< C项目实践--图书管理系统(4)>>
.csharpcode, .csharpcode pre
{
font-size: small;
color: black;
font-family: consolas, "Courier New", courier, monospace;
background-color: #ffffff;
/*white-space: pre;*/
}
.csharpcode pre { margin: 0em; }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000ff; }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
{
background-color: #f4f4f4;
width: 100%;
margin: 0em;
}
.csharpcode .lnum { color: #606060; }

C项目实践--图书管理系统(3)的更多相关文章

  1. C项目实践--图书管理系统(1)

    1.功能需求分析 图书管理系统主要用于对大量的图书信息,包括书名.作者.出版社.出版日期.ISBN(书号)等进行增.删.改.查以及保存等操作.同时也包括对用户的管理,用户包括管理员和普通用户两种权限, ...

  2. C项目实践--图书管理系统(2)

    前面在<<C项目实践-图书管理系统(1)>>中把系统中的三大功能模块中可能涉及到的常量,结构体及相关函数进行了声明定义,下来就来实现它们. 执行系统首先从登录到系统开始,所以首 ...

  3. C项目实践--图书管理系统(4)

    前面已经把图书管理系统的所有功能模块都已实现完毕了,下面通过运行来分析该系统的操作流程并检验是否符合逻辑设计要求. 3.系统操作过程 F5 运行 1.登录系统 系统运行之后,提示输入用户名和密码,系统 ...

  4. javaWeb项目之图书管理系统(附视频讲解)

    视频播放地址:javaWeb图书系统 本系统为"Swing项目之图书管理系统"(此源码已共享)的Web版,网页框架用采用EasyUI 数据库为MysqL,写Web项目摒弃了火狐浏览 ...

  5. 新建Django项目示例--图书管理系统

    知识点: Django 1. 安装 1. Django版本 1.11.xx 2. 安装方式 1. 命令行 --> Python环境(双版本,pip的使用) 2. PyCharm安装 2. 创建D ...

  6. Java小项目迷你图书管理系统

    package 迷你图书管理系统; import java.util.Scanner; public class BookMgr { public static void main(String[] ...

  7. 【WPF on .NET Core 3.0】 Stylet演示项目 - 简易图书管理系统(3) - 使用Conductor切换页面

    前两章中, 我们已经实现了这个图书管理系统的登录窗口, 并实施了完善的单元测试. 该是时候回过头来关注我们的主窗口了. 一个功能丰富的系统一般会有多个页面, 我们图书管理系统虽然是"简易&q ...

  8. 【WPF on .NET Core 3.0】 Stylet演示项目 - 简易图书管理系统(1)

    .NET Core 3.0已经发布了,除了一大堆令人激动的功能以外,也增加了对WPF的正式支持, 那么WPF在.NET Core 3.0下的开发体验如何呢? 本文利用了Stylet框架开发.NET C ...

  9. 【WPF on .NET Core 3.0】 Stylet演示项目 - 简易图书管理系统(4) - 图书列表界面

    在前三章中我们完成了登录窗口, 并掌握了使用Conductor来切换窗口, 但这些其实都是在为我们的系统打基础. 而本章中我们就要开始开发系统的核心功能, 即图书管理功能了. 通过本章, 我们会接触到 ...

随机推荐

  1. 南邮CTF--SQL注入题

    南邮CTF--SQL注入题 题目:GBK SQL injection 解析: 1.判断注入点:加入单引号发现被反斜杠转移掉了,换一个,看清题目,GBK,接下来利用宽字节进行注入 2.使用'%df' ' ...

  2. MyISAM和InnoDB索引实现对比

    MyISAM索引实现 MyISAM引擎使用B+Tree作为索引结构,叶节点的data域存放的是数据记录的地址.如图:  这里设表一共有三列,假设我们以Col1为主键,则上图是一个MyISAM表的主索引 ...

  3. Nginx与python web服务配置(Uwsgi& FastCGI)

    Uwsgi start uswgi uwsgi --harakiri 360000 --body-read-warning=10000 --max-fd=65536 -b 1000000 --http ...

  4. &quot;转成"

    在java中这样转 StringEscapeUtils.unescapeHtml(soapResponseData); 在js中这样转 str.replace(""",& ...

  5. [codeforces722C]Destroying Array

    [codeforces722C]Destroying Array 试题描述 You are given an array consisting of n non-negative integers a ...

  6. codeforces 315B

    #include<stdio.h> int main() { int n,k,i,flag=0; while(scanf("%d%d",&n,&k)!= ...

  7. java遍历文件夹及所有子文件

    以前写代码循环文件夹和子文件时,总是自己写递归访问,今天研究lucene时,发现JDK给我们已经提供了访问遍历的方法,上代码: String str = "C:\\Users\\LLY\\D ...

  8. nginx学习网站收录

    1.菜鸟教程 2. Nginx中文 3. Nginx官网 参考:http://www.cnblogs.com/knowledgesea/p/5175711.html

  9. [Android] 随时拍图像处理部分总结及源码分享

    http://blog.csdn.net/eastmount/article/details/45492065#comments [Android] 图像各种处理系列文章合集 http://blog. ...

  10. PAT (Advanced Level) 1034. Head of a Gang (30)

    简单DFS. #include<cstdio> #include<cstring> #include<cmath> #include<vector> # ...