C語(yǔ)言利用數(shù)組和文件實(shí)現(xiàn)登錄注冊(cè)功能
C語(yǔ)言利用文件系統(tǒng)實(shí)現(xiàn)簡(jiǎn)單的用戶登錄和注冊(cè)功能
版本一:利用數(shù)組
最近有個(gè)朋友讓我?guī)退鲆粋€(gè)C語(yǔ)言的登錄注冊(cè)功能,考慮到他沒有學(xué)到數(shù)據(jù)庫(kù)于是想到了存入文件
此版本使用的數(shù)組,第二個(gè)版本使用的是鏈表,鏈表是一個(gè)很好的數(shù)據(jù)結(jié)構(gòu),推薦大家用鏈表
第二版:鏈接
話不多說(shuō)上代碼
#include <stdio.h>
#include <stdlib.h>
#define USER_MAX 20
//此系統(tǒng)能存放最多的用戶數(shù)
typedef struct
{
char name[10];
char password[10];
} User;
//定義一個(gè)存放用戶的結(jié)構(gòu)體
User list[USER_MAX];
//定義一個(gè)全局?jǐn)?shù)組,類型是User,大小是USER_MAX
char* filename = "user.txt";
//需要在你的程序目錄下新建一個(gè)user.txt文件
//登錄函數(shù)
User login()
{
char name[10];
char password[10];
User lg;
printf("enter name:");
scanf("%s",name);
strcpy(lg.name , name);
printf("enter password:");
scanf("%s",password);
strcpy(lg.password,password);
return lg;
}
//寫入txt文件,每一行存在一個(gè)用戶
void writeToFile(User u)
{
FILE *fw = fopen(filename,"a+");
fprintf(fw,u.name);
fprintf(fw,"\t");
fprintf(fw,u.password);
fprintf(fw,"\n");
}
//判斷是否存在該用戶
int exist(User u)
{
int i;
for(i=0; i<USER_MAX; i++)
{
if(0==strcmp(list[i].name ,u.name) && 0==strcmp(list[i].password ,u.password))
{
return 1;
}
}
return -1;
}
//注冊(cè)用戶
void registerUser()
{
char name[10];
char password[10];
User user;
int i;
printf("enter your name:");
scanf("%s",name);
strcpy(user.name , name);
//判斷注冊(cè)的用戶是否已存在
for(i=0; i<USER_MAX; i++)
{
if(0==strcmp(list[i].name ,name))
{
printf("USER ALREADY EXIST");
return;
}
}
printf("enter your password:");
scanf("%s",password);
strcpy(user.password , password);
writeToFile(user);
}
int menu()
{
int choice;
printf("1.login\n");
printf("2.register\n");
printf("#.exit\n");
printf("enter your choice:");
scanf("%d",&choice);
return choice;
}
int main()
{
User test[USER_MAX];
FILE *fp = fopen(filename,"r");
int i=0;
User u;
if(NULL == fp)
{
printf("FILE NOT FOUND");
return -1;
}
for(i=0; i<USER_MAX; i++)
{
char uname[10];
char upassword[10];
fscanf(fp,"%s%s",uname,upassword);
strcpy(list[i].name , uname);
strcpy(list[i].password , upassword);
}
int choice = menu();
if(1 == choice)
{
system("cls");
u=login();
if(1 == exist(u))
{
printf("success");
}
else
{
printf("WRONG USER OR PASS");
}
}
else if(2 == choice)
{
system("cls");
registerUser();
}
else
{
return 0;
}
}
運(yùn)行結(jié)果
菜單,比較簡(jiǎn)陋,可以根據(jù)自己需求加?xùn)|西
PS我并未寫循環(huán)語(yǔ)句,只是簡(jiǎn)單實(shí)現(xiàn)功能,所以讀者可根據(jù)需求寫菜單的循環(huán)

注冊(cè)

看一下文件

登錄

異常路徑(登錄失?。?/p>

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
C++實(shí)現(xiàn)圖書管理系統(tǒng)源碼
這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)圖書管理系統(tǒng)源碼,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-03-03
C++初階之list的模擬實(shí)現(xiàn)過(guò)程詳解
在C++中我們經(jīng)常使用STL,那個(gè)在那些我們常用的數(shù)據(jù)結(jié)構(gòu)vector,list的背后,又是如何實(shí)現(xiàn)的呢?這篇文章主要給大家介紹了關(guān)于C++初階之list的模擬實(shí)現(xiàn)的相關(guān)資料,需要的朋友可以參考下2021-08-08
QT編寫地圖實(shí)現(xiàn)設(shè)備點(diǎn)位的示例代碼
在地圖應(yīng)用的相關(guān)項(xiàng)目中,在地圖上標(biāo)識(shí)一些設(shè)備點(diǎn),并對(duì)點(diǎn)進(jìn)行交互這個(gè)功能用的最多的,于是需要一套機(jī)制可以動(dòng)態(tài)的添加、刪除、清空、重置。本文將詳細(xì)介紹這些功能如何實(shí)現(xiàn),需要的可以參考一下2022-01-01
C++實(shí)現(xiàn)LeetCode(10.正則表達(dá)式匹配)
這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(10.正則表達(dá)式匹配),本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-07-07
C++中靜態(tài)初始化數(shù)組與動(dòng)態(tài)初始化數(shù)組詳解
今天小編就為大家分享一篇C++中靜態(tài)初始化數(shù)組與動(dòng)態(tài)初始化數(shù)組詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-07-07
C++?ffmpeg實(shí)現(xiàn)將視頻幀轉(zhuǎn)換成jpg或png等圖片
有時(shí)播放實(shí)時(shí)流的時(shí)候有截圖的需求,需要將解碼出來(lái)的圖片保存本地或上傳服務(wù)器,這時(shí)就需要將avframe中的數(shù)據(jù)編碼成png、jpg等格式的圖片,我們使用ffmpeg的相關(guān)編碼器就可以實(shí)現(xiàn)功能,下面就來(lái)講講具體實(shí)現(xiàn)方法吧2023-03-03
用代碼和UML圖化解設(shè)計(jì)模式之橋接模式的深入分析
本篇文章是對(duì)橋接模式進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05
c語(yǔ)言實(shí)現(xiàn)整蠱朋友小程序(附源碼)
這篇文章主要給大家介紹了關(guān)于c語(yǔ)言實(shí)現(xiàn)整蠱朋友小程序的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-02-02
C++一個(gè)函數(shù)如何調(diào)用其他.cpp文件中的函數(shù)
這篇文章主要介紹了C++一個(gè)函數(shù)如何調(diào)用其他.cpp文件中的函數(shù)問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-02-02
C++詳細(xì)講解模擬實(shí)現(xiàn)位圖和布隆過(guò)濾器的方法
位圖(bitset)是一種常用的數(shù)據(jù)結(jié)構(gòu),常用在給一個(gè)很大范圍的數(shù),判斷其中的一個(gè)數(shù)是不是在其中。在索引、數(shù)據(jù)壓縮方面有很大的應(yīng)用。布隆過(guò)濾器是由布隆提出的,它實(shí)際上是一個(gè)很長(zhǎng)的二進(jìn)制向量和一系列隨機(jī)映射函數(shù)。布隆過(guò)濾器可以用于檢索一個(gè)元素是否在一個(gè)集合中2022-06-06

