自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

從零實(shí)現(xiàn)基于Linux socket聊天室-增加數(shù)據(jù)庫Sqlite功能-5

系統(tǒng) Linux
本文一口君會在原有代碼基礎(chǔ)上增加數(shù)據(jù)庫操作功能,后續(xù)文章還會增加文件傳輸功能。本文需要增加數(shù)據(jù)庫功能,關(guān)于數(shù)據(jù)庫的基礎(chǔ)知識點(diǎn),表的創(chuàng)建、增刪改查等操作。

[[435067]]

之前更新過從0實(shí)現(xiàn)聊天室的4篇文章,很多粉絲朋友還是覺得內(nèi)容相對簡單,本文一口君會在原有代碼基礎(chǔ)上增加數(shù)據(jù)庫操作功能,后續(xù)文章還會增加文件傳輸功能。

本文需要增加數(shù)據(jù)庫功能,關(guān)于數(shù)據(jù)庫的基礎(chǔ)知識點(diǎn),表的創(chuàng)建、增刪改查等操作,以及對應(yīng)的庫函數(shù)的使用請參考以下3篇文章:

  • 《嵌入式數(shù)據(jù)庫sqlite3【基礎(chǔ)篇】-基本命令操作,小白一看就懂》
  • 《嵌入式數(shù)據(jù)庫sqlite3【進(jìn)階篇】-子句和函數(shù)的使用,小白一文入門》
  • 《如何用C語言操作sqlite3,一文搞懂》

全部掌握后,開始進(jìn)入本篇。

一. 調(diào)整目錄結(jié)構(gòu)

為了方便編譯,現(xiàn)在我們將前面文章的代碼結(jié)構(gòu)做如下調(diào)整。

  1. root@ubuntu:/mnt/hgfs/code/chat# tree . 
  2. ├── chat_client 
  3. │   ├── include 
  4. │   ├── Makefile 
  5. │   ├── obj 
  6. │   │   └── Makefile 
  7. │   └── src 
  8. │       ├── client.c 
  9. │       └── Makefile 
  10. ├── chat.h 
  11. ├── chat_server 
  12. │   ├── bin 
  13. │   │   └── server 
  14. │   ├── data 
  15. │   ├── include 
  16. │   ├── Makefile 
  17. │   ├── obj 
  18. │   │   └── server.o 
  19. │   └── src 
  20. │       ├── Makefile 
  21. │       └── server.c 
  22. └── gcc.sh 
  23.  
  24. 10 directories, 15 files 

最終增加了數(shù)據(jù)的文件目錄如下:

  1. peng@ubuntu:/mnt/hgfs/code/chat-sqlite$ tree . 
  2. ├── chat_client 
  3. │   ├── include 
  4. │   ├── Makefile 
  5. │   ├── obj 
  6. │   │   └── Makefile 
  7. │   └── src 
  8. │       ├── client.c 
  9. │       └── Makefile 
  10. ├── chat.h 
  11. ├── chat_server 
  12. │   ├── data 
  13. │   ├── include 
  14. │   │   └── data.h 
  15. │   ├── Makefile 
  16. │   ├── obj 
  17. │   │   └── Makefile 
  18. │   └── src 
  19. │       ├── data.c 
  20. │       ├── Makefile 
  21. │       └── server.c 
  22. ├── clean.sh 
  23. ├── gcc.sh 
  24. ├── user.db 
  25. └── 解壓密碼.txt 
  26.  
  27. 9 directories, 17 files 

clean.sh 用于清除臨時文件gcc.sh 用于編譯整個工程

服務(wù)端代碼放置到chat_server目錄下;客戶端代碼放置到chat_client目錄下;

數(shù)據(jù)庫相關(guān)代碼放在chat_server/data下。

chat.h是所有客戶端和服務(wù)器都會用到的頭文件,所以放置在根目錄下。

后續(xù)增加功能后,新增的頭文件和C文件分別添加到對應(yīng)工程目錄的include和src目錄下即可。

二、 設(shè)計(jì)數(shù)據(jù)庫表

我們之前維護(hù)的所有客戶端的信息是用一個全局?jǐn)?shù)組,并且沒有保存功能,現(xiàn)在我們要把所有客戶端的信息全部保存到數(shù)據(jù)庫中。

數(shù)據(jù)庫存儲的目錄

  1. chat_server/data 

數(shù)據(jù)庫名:

  1. user.db 

存儲用戶信息的表名:

  1. user 

表user格式如下:

三、 主要功能操作的語句及函數(shù)

數(shù)據(jù)庫操作最重要的就是語句,下面講解針對不同的功能對應(yīng)的實(shí)現(xiàn)語句

1.創(chuàng)建表user

  1. CREATE TABLE IF NOT EXISTS user(name TEXT PRIMARY KEY  NOT NULL,passwd TEXT NOT NULL,fd INT NOT NULL,regist INT  NOT NULL); 

2.增加一個用戶

客戶端發(fā)送注冊請求后,服務(wù)器端注冊用戶信息到數(shù)據(jù)庫中

數(shù)據(jù)庫操作語句如下:

  1. insert into user values('一口Linux''123456',-1, 1) 

功能函數(shù)如下:

  1. int db_add_user(char name[],char passwd[]) 
  1. 功能: 
  2. 增加一個用戶,執(zhí)行該函數(shù)前需要先判斷該用戶名是否存在 
  3.  
  4. 參數(shù): 
  5. name:用戶名 
  6. passwd:密碼 
  7.  
  8. 返回值: 
  9. -1:失敗 
  10. 1:成功 

3.判斷用戶是否在線

客戶端發(fā)送登陸命令后,服務(wù)器通過該函數(shù)判斷該用戶是否已經(jīng)登陸成功

數(shù)據(jù)庫操作語句如下:

  1. select fd from user where name='一口Linux' 

功能函數(shù)如下:

  1. int db_user_if_online(char *name,char *passwd) 
  1. 功能: 
  2. 判斷用戶是否在線,該函數(shù)主要根據(jù)fd的值來判斷用戶是否在線 
  3.  
  4. 參數(shù): 
  5. name:用戶名 
  6. passwd:密碼   
  7.  
  8. 返回值: 
  9. 1:在線 
  10. -1:不在線 
  11. -2:用戶不存在 

4.判斷某個用戶名是否注冊

用戶發(fā)送注冊命令,服務(wù)器需要判斷該用戶名是否已經(jīng)被注冊過

數(shù)據(jù)庫操作語句如下:

  1. select regist from user where name='一口Linux' 

功能函數(shù)如下:

  1. int db_user_if_reg(char *name
  1. 功能: 
  2. 判斷某個用戶名是否注冊過 
  3.  
  4. 參數(shù): 
  5. name:用戶名 
  6.  
  7. 返回值: 
  8.  1:注冊過 
  9. -1:沒有注冊過 

5.判斷用戶名密碼是否正確

用戶發(fā)送登陸命令,需要判斷用戶名密碼是否正確

數(shù)據(jù)庫操作語句如下:

  1. select * from user where name='一口Linux' and passwd='123456' 

功能函數(shù)如下:

  1. int db_user_pwd_corrct(char *name,char* passwd) 
  1. 功能: 
  2. 判斷客戶端發(fā)送的用戶名密碼是否正確 
  3.  
  4. 參數(shù): 
  5. name:用戶名 
  6. passwd:密碼 
  7.  
  8. 返回值: 
  9.  1:正確 
  10. -1:用戶名或者密碼不正確 

6.用戶上線、下線

用戶登陸成功后,或者發(fā)送下線申請,或者異常掉線,需要更新數(shù)據(jù)庫的狀態(tài)。

數(shù)據(jù)庫操作語句如下:

  1. UPDATE  user set fd=-1 where name='一口Linux' 

fd的值是套接字描述符,下線設(shè)置為-1,上線設(shè)置為對應(yīng)的>0的值

功能函數(shù)如下:

  1. int db_user_on_off(int fd,char *name,unsigned int on_off)  
  1. 功能: 
  2. 更新數(shù)據(jù)庫中用戶的fd字段 
  3.  
  4. 參數(shù): 
  5. fd:套接字描述符 
  6. name:用戶名 
  7. on_off:上線還是下線 
  8.  
  9. 返回值: 
  10.  1:正確 
  11. -1:失敗 

7. 顯示在線用戶

用戶發(fā)送顯示在線用戶命令后,服務(wù)器從數(shù)據(jù)庫當(dāng)中查找所有在線用戶,并將姓名循環(huán)發(fā)送給客戶端

  1. int db_list_online_user(int fd) 

四、運(yùn)行結(jié)果編譯

  1. ./gcc.sh 

1.服務(wù)器啟動

  1. ./server 9999 

端口號設(shè)定為9999

2. 客戶端注冊

客戶端啟動

  1. ./client 127.0.0.1 9999 

選擇1 注冊,輸入用戶名密碼即可。

3. 用戶登錄

輸入選項(xiàng)2,輸入剛才注冊的用戶名密碼,如果不一致會提示錯誤

登錄成功:

4. 注冊登錄其他幾個用戶

注冊并登錄新的用戶111、222、333

 

5. 公聊

選擇選項(xiàng)3,即進(jìn)入公聊, 用戶yikou向所有用戶說:hello!

可見所有用戶均收到信息。

6. 私聊

用戶yikou向用戶111發(fā)送信息:

由下圖可知,只有用戶111收到該信息,其他用戶均沒有收到信息。

7. 顯示在線用戶

8. 查看最終數(shù)據(jù)庫信息

五、代碼說明

為方便讀者學(xué)習(xí)增加數(shù)據(jù)庫和去掉數(shù)據(jù)之間的差別,

用git維護(hù)版本。

切換到?jīng)]有數(shù)據(jù)庫的版本,執(zhí)行下面命令即可。

  1. git reset --hard  597330ae0a183c9db8f68b7c9f60df94f8965778 

要切回有數(shù)據(jù)庫的版本執(zhí)行下面的命令:

  1. git reset --hard 10bfbfaf2d09ae895313273c960ecfd84663f9fd 

使用數(shù)據(jù)庫后,數(shù)據(jù)的存儲管理更加方便,數(shù)據(jù)類型更易于擴(kuò)充, 邏輯關(guān)系也更加清晰。

 本文轉(zhuǎn)載自微信公眾號「一口Linux」

 

責(zé)任編輯:姜華 來源: 一口Linux
相關(guān)推薦

2009-09-04 17:53:23

C#增加數(shù)據(jù)庫數(shù)據(jù)

2009-04-21 08:53:18

iphone新特性移動OS

2011-12-15 11:11:51

JavaNIO

2015-07-06 10:42:18

PHP聊天室應(yīng)用

2023-02-10 08:16:48

WebSocket簡易聊天室

2020-06-08 14:36:50

數(shù)據(jù)中心端口密度網(wǎng)絡(luò)

2014-02-18 13:40:23

Office 365數(shù)字簽名

2022-07-26 14:53:10

WebSocket網(wǎng)絡(luò)通信協(xié)議

2023-01-13 00:02:41

2023-01-05 09:17:58

2015-08-12 13:44:13

數(shù)據(jù)中心

2011-06-09 15:44:29

Spring

2014-11-14 15:21:54

CommVault

2021-11-16 09:38:10

鴻蒙HarmonyOS應(yīng)用

2021-08-04 05:49:40

數(shù)據(jù)庫數(shù)時序數(shù)據(jù)庫技術(shù)

2019-12-09 10:03:40

MySQLSQL數(shù)據(jù)庫

2022-11-14 08:01:48

2022-04-05 13:46:21

日志數(shù)據(jù)庫系統(tǒng)

2022-12-01 08:25:23

eTsTCP聊天室

2020-09-22 10:13:54

開源技術(shù) 趨勢
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號