C語(yǔ)言利用數(shù)組和文件實(shí)現(xiàn)登錄注冊(cè)功能
C語(yǔ)言利用文件系統(tǒng)實(shí)現(xiàn)簡(jiǎn)單的用戶登錄和注冊(cè)功能
版本一:利用數(shù)組
最近有個(gè)朋友讓我?guī)退鲆粋€(gè)C語(yǔ)言的登錄注冊(cè)功能,考慮到他沒(méi)有學(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; } //寫(xiě)入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我并未寫(xiě)循環(huán)語(yǔ)句,只是簡(jiǎn)單實(shí)現(xiàn)功能,所以讀者可根據(jù)需求寫(xiě)菜單的循環(huán)
注冊(cè)
看一下文件
登錄
異常路徑(登錄失?。?/p>
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
C++實(shí)現(xiàn)圖書(shū)管理系統(tǒng)源碼
這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)圖書(shū)管理系統(tǒng)源碼,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-03-03C++初階之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-08QT編寫(xiě)地圖實(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-01C++實(shí)現(xiàn)LeetCode(10.正則表達(dá)式匹配)
這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(10.正則表達(dá)式匹配),本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-07-07C++中靜態(tài)初始化數(shù)組與動(dòng)態(tài)初始化數(shù)組詳解
今天小編就為大家分享一篇C++中靜態(tài)初始化數(shù)組與動(dòng)態(tài)初始化數(shù)組詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-07-07C++?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-05c語(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-02C++一個(gè)函數(shù)如何調(diào)用其他.cpp文件中的函數(shù)
這篇文章主要介紹了C++一個(gè)函數(shù)如何調(diào)用其他.cpp文件中的函數(shù)問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-02-02C++詳細(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