//此代碼為注冊功能
void create_regtable()
{
int rc; //rc為返回值,判斷函數是否執行成功 rc=0函數執行成功,rc !=0函數執行失敗
sqlite3 *db; //SQLite數據庫指針 數據庫結構體指針sqlite3為結構體
char *pFileName = "users.db"; //數據庫文件名
char *zErr;
rc = sqlite3_open(pFileName, &db); /*打開數據庫*/
if(rc) /*假,關閉數據庫*/
{
cleardevice();
setmode();
outtextxy(170,200,"打開數據庫失敗!");
Sleep(1000);
main();
sqlite3_close(db);
}
char *pSQL="create table users(id int , pwd int ,primary key(id,pwd))";
rc = sqlite3_exec(db, pSQL, 0,0, &zErr); /* sqlite執行接口實現表的創建*/
if(rc!=SQLITE_OK)
{
if (zErr!=NULL)
{
cleardevice();
setmode();
outtextxy(170,200,"SQL錯誤!");
Sleep(1000);
main();
sqlite3_free(zErr); /* 釋放錯誤信息所占用的空間*/
}
}
sqlite3_close(db);
}
void reg_Insert()
{
users a;
int rc;
char No_id[10]={0,0,0,0,0,0,0,0,0,0};
char code[6]={"12345"};
char incode[6];
sqlite3 *db; //SQLite數據庫指針
char *pSQL;
char * zErr; /* 定義返回錯誤信息的變量*/
char *pFileName = "users.db"; //數據庫文件名
rc = sqlite3_open(pFileName, &db); /*打開數據庫*/
if(rc) /*假,關閉數據庫*/
{
cleardevice();
setmode();
outtextxy(170,200,"打開數據庫失敗!");
voice_name_error();
main();
sqlite3_close(db);
}
InputBox(incode,6,"驗證注冊編號,非教師人員不允許注冊");
if(strcmp(incode,code)==0)
{
InputBox(a.id,10,"請輸入賬號");
outtextxy(295,270,a.id);
if(strcmp(a.id,No_id)==0)
{
cleardevice();
setmode();
outtextxy(170,200,"用戶名不能為空,請重新注冊!");
voice_name_error();
main();
}
else {
InputBox(a.pwd,10,"請輸入密碼");
outtextxy(293,339,"********");
Sleep(1000);
pSQL=sqlite3_mprintf("insert into users values('%s','%s')",a.id,a.pwd);
rc = sqlite3_exec(db,pSQL,0,0,&zErr);
if(rc) //rc=1
{
cleardevice();
setmode();
outtextxy(220, 200, "帳號注冊失敗!");
voice_register_ok();
main();
sqlite3_close(db);
}
else
{
outtextxy(220, 200, rc);
cleardevice();
setmode();
outtextxy(220, 200, "帳號注冊成功!");
voice_register_ok();
main();
sqlite3_close(db);
}
}
} else{ cleardevice();main();}
}
//此代碼為實現賬號密碼登錄驗證
void Login()
{
users a;
int rc;
sqlite3 *db; //SQLite數據庫指針 sqlite3結構體 *db指向sqlite3結構體的指針
const char *pFileName = "users.db";
char * zErr; /* 定義返回錯誤信息的變量*/
rc = sqlite3_open(pFileName, &db); /*打開數據庫*/
if(rc) /*假,關閉數據庫*/
{
cleardevice();
setmode();
settextstyle(30, 0, "楷體");
settextcolor(RGB(0,500,0));
outtextxy(220, 200, "打開數據庫失敗!");
voice_No_name();
main();
sqlite3_close(db);
}
InputBox(a.id,10,"請輸入賬號");
outtextxy(295,270,a.id);
InputBox(a.pwd,10,"請輸入密碼");
outtextxy(293,339,"********");
Sleep(1500);
char *pSQL=sqlite3_mprintf("insert into users(id,pwd)values('%s','%s')",a.id,a.pwd);
//主要是獲取rc返回值,進行判斷
// id和pwd共同組成一個表的主鍵(聯合主鍵) id/pwd誰都不能插入重復的 rc==1 錯誤 if取反rc==0登陸成功
//插入的id不同pwd不同 插入成功 rc==0 if取反rc==1登陸失敗
//相當於用戶名不能有重復的,用戶名跟密碼不能一樣,增強賬號的安全性。
rc = sqlite3_exec(db, pSQL, NULL, NULL, &zErr);
//!rc==1; error
if (!rc)
{ //刪除多余的數據
char *pSQL=sqlite3_mprintf("delete from users where id = '%s' and pwd = '%s' ",a.id,a.pwd);
rc = sqlite3_exec(db, pSQL, NULL, NULL, &zErr);
cleardevice();
setmode();
settextstyle(30, 0, "楷體");
settextcolor(RGB(255,0,0));
outtextxy(250, 200, "登錄失敗!");
Sleep(1000);
cleardevice();
main();
}
else ///rc=0 ok
{
cleardevice();
setmode();
settextstyle(30, 0, "楷體");
settextcolor(RGB(0,500,0));
outtextxy(250, 200, "登錄成功,歡迎使用!");
voice_succeed();
cleardevice();
option_Menu();
}
sqlite3_close(db);
}