精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

從零實現基于Linux socket聊天室-增加數據庫Sqlite功能-5

系統 Linux
本文一口君會在原有代碼基礎上增加數據庫操作功能,后續文章還會增加文件傳輸功能。本文需要增加數據庫功能,關于數據庫的基礎知識點,表的創建、增刪改查等操作。

[[435067]]

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

本文需要增加數據庫功能,關于數據庫的基礎知識點,表的創建、增刪改查等操作,以及對應的庫函數的使用請參考以下3篇文章:

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

全部掌握后,開始進入本篇。

一. 調整目錄結構

為了方便編譯,現在我們將前面文章的代碼結構做如下調整。

  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 

最終增加了數據的文件目錄如下:

  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 用于編譯整個工程

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

數據庫相關代碼放在chat_server/data下。

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

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

二、 設計數據庫表

我們之前維護的所有客戶端的信息是用一個全局數組,并且沒有保存功能,現在我們要把所有客戶端的信息全部保存到數據庫中。

數據庫存儲的目錄

  1. chat_server/data 

數據庫名:

  1. user.db 

存儲用戶信息的表名:

  1. user 

表user格式如下:

三、 主要功能操作的語句及函數

數據庫操作最重要的就是語句,下面講解針對不同的功能對應的實現語句

1.創建表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.增加一個用戶

客戶端發送注冊請求后,服務器端注冊用戶信息到數據庫中

數據庫操作語句如下:

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

功能函數如下:

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

3.判斷用戶是否在線

客戶端發送登陸命令后,服務器通過該函數判斷該用戶是否已經登陸成功

數據庫操作語句如下:

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

功能函數如下:

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

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

用戶發送注冊命令,服務器需要判斷該用戶名是否已經被注冊過

數據庫操作語句如下:

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

功能函數如下:

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

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

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

數據庫操作語句如下:

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

功能函數如下:

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

6.用戶上線、下線

用戶登陸成功后,或者發送下線申請,或者異常掉線,需要更新數據庫的狀態。

數據庫操作語句如下:

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

fd的值是套接字描述符,下線設置為-1,上線設置為對應的>0的值

功能函數如下:

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

7. 顯示在線用戶

用戶發送顯示在線用戶命令后,服務器從數據庫當中查找所有在線用戶,并將姓名循環發送給客戶端

  1. int db_list_online_user(int fd) 

四、運行結果編譯

  1. ./gcc.sh 

1.服務器啟動

  1. ./server 9999 

端口號設定為9999

2. 客戶端注冊

客戶端啟動

  1. ./client 127.0.0.1 9999 

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

3. 用戶登錄

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

登錄成功:

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

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

 

5. 公聊

選擇選項3,即進入公聊, 用戶yikou向所有用戶說:hello!

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

6. 私聊

用戶yikou向用戶111發送信息:

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

7. 顯示在線用戶

8. 查看最終數據庫信息

五、代碼說明

為方便讀者學習增加數據庫和去掉數據之間的差別,

用git維護版本。

切換到沒有數據庫的版本,執行下面命令即可。

  1. git reset --hard  597330ae0a183c9db8f68b7c9f60df94f8965778 

要切回有數據庫的版本執行下面的命令:

  1. git reset --hard 10bfbfaf2d09ae895313273c960ecfd84663f9fd 

使用數據庫后,數據的存儲管理更加方便,數據類型更易于擴充, 邏輯關系也更加清晰。

 本文轉載自微信公眾號「一口Linux」

 

責任編輯:姜華 來源: 一口Linux
相關推薦

2009-09-04 17:53:23

C#增加數據庫數據

2009-04-21 08:53:18

iphone新特性移動OS

2011-12-15 11:11:51

JavaNIO

2023-02-10 08:16:48

WebSocket簡易聊天室

2015-07-06 10:42:18

PHP聊天室應用

2020-06-08 14:36:50

數據中心端口密度網絡

2022-07-26 14:53:10

WebSocket網絡通信協議

2023-01-13 00:02:41

2023-01-05 09:17:58

2014-02-18 13:40:23

Office 365數字簽名

2025-05-09 08:35:00

聊天室FastAPIWebSocket

2015-08-12 13:44:13

數據中心

2011-06-09 15:44:29

Spring

2014-11-14 15:21:54

CommVault

2021-11-16 09:38:10

鴻蒙HarmonyOS應用

2021-08-04 05:49:40

數據庫數時序數據庫技術

2019-12-09 10:03:40

MySQLSQL數據庫

2022-11-14 08:01:48

2022-12-01 08:25:23

eTsTCP聊天室

2022-04-05 13:46:21

日志數據庫系統
點贊
收藏

51CTO技術棧公眾號

丁香婷婷激情网| 日韩jizzz| 99精品视频99| 美女毛片一区二区三区四区| 午夜私人影院久久久久| 日韩国产欧美精品| 亚洲精品综合网| 久久久久综合| 久久99精品久久久久久青青91| 中文字幕中文字幕在线中一区高清| 久久久久99精品成人片试看| 婷婷亚洲精品| 欧美一区二区三区视频免费| 国产 福利 在线| av网址在线| 久久精品视频一区二区| 成人精品福利视频| 五月激情六月丁香| 欧美日韩ab| 国产亚洲精品日韩| 9.1在线观看免费| 成人18视频在线观看| 亚洲成人自拍偷拍| youjizz.com亚洲| 日本福利片高清在线观看| 国产一区二区三区免费观看| 日本精品性网站在线观看| 黄页网站免费观看| 国产精品91一区二区三区| 极品少妇xxxx精品少妇偷拍| 欧美丰满片xxx777| 日韩一区二区三区四区视频| 日韩高清电影免费| 精品国产99国产精品| 亚洲一区二区福利视频| 成人国产激情| 在线精品亚洲一区二区不卡| 青娱乐自拍偷拍| 日本片在线观看| 亚洲男人的天堂在线观看| 日韩欧美亚洲在线| 风间由美一区| 国产日韩欧美综合一区| 久久国产精品久久精品国产| 亚洲国产福利视频| 国产精品亚洲一区二区三区妖精| 欧美裸身视频免费观看| 人妻aⅴ无码一区二区三区 | 中文字幕欧美激情一区| 精品一区日韩成人| 无码精品黑人一区二区三区| 成人精品视频.| 亚洲自拍偷拍色图| 国产三级视频在线播放| 精品一区二区久久| 91系列在线观看| 99久久精品国产成人一区二区| 午夜天堂精品久久久久| 日韩在线观看免费av| 欧美福利在线视频| 欧美韩国日本在线观看| 久久黄色av网站| 免费在线观看一级片| 97偷自拍亚洲综合二区| 久久香蕉国产线看观看网| 三级影片在线观看| 欧美fxxxxxx另类| 欧美国产日韩xxxxx| 日本在线免费观看| 国产伦理一区| 国产精品久久久久久久av大片| 69av视频在线| 亚洲婷婷免费| 欧美孕妇性xx| 亚洲一级片免费看| 国产精品正在播放| 国产精品一区二| 香蕉视频免费看| 中文字幕第一区综合| 日本丰满少妇黄大片在线观看| 日本在线视频1区| 国产亚洲人成网站| 亚洲人久久久| 三级资源在线| 色综合久久久久久久久久久| 可以看污的网站| 66精品视频在线观看| 日韩精品免费在线视频观看| 亚洲精品国产熟女久久久| 91免费精品| 91国产中文字幕| 亚洲av无码乱码国产精品fc2| 国产精品呻吟| 国产欧美日韩丝袜精品一区| 国产女人18毛片水真多| 99国产精品国产精品毛片| 欧美二区三区在线| 激情在线小视频| 欧美日韩美女在线观看| 色天使在线观看| 青青操综合网| 久久九九有精品国产23| 久久久久久久久影院| 精品一区二区在线视频| 国产乱码精品一区二区三区五月婷| 97久久精品人人做人人爽50路| 成人xxxxx| 丰满少妇在线观看bd| 久久久久久久久久久久久夜| 少妇高潮流白浆| 性国裸体高清亚洲| 56国语精品自产拍在线观看| 天堂久久久久久| 中文无码久久精品| 国产精品va在线播放| 丰满人妻一区二区三区无码av| 国产成人精品亚洲日本在线桃色| 亚洲aⅴ男人的天堂在线观看| 一区二区视频网| 成人av先锋影音| 在线免费观看一区二区三区| 亚洲天堂手机| 精品久久久久久最新网址| 日本猛少妇色xxxxx免费网站| 菠萝蜜一区二区| 97超级碰碰碰久久久| 国产伦精品一区二区三区免.费| 国内精品久久久久影院一蜜桃| 成人两性免费视频| 蜜桃视频在线免费| 国产精品久久久久久久久晋中| 熟女熟妇伦久久影院毛片一区二区| 免费黄色电影在线观看| 欧美日韩一区二区在线| 欧美老女人bb| 久久精品一区二区不卡| 国产精品久久久久一区二区| 亚洲欧洲成人在线| 亚洲电影中文字幕在线观看| 日本精品一区在线| 日韩免费久久| 国产精品亚洲一区二区三区| 黑人与亚洲人色ⅹvideos| 懂色av中文一区二区三区天美| 婷婷激情四射五月天| 欧美调教在线| 欧美一区二粉嫩精品国产一线天| 中文天堂在线资源| 久久午夜老司机| 国产淫片免费看| 欧美亚洲色图校园春色| 97国产精品久久| 深爱五月激情五月| 午夜精品视频一区| 激情综合丁香五月| 校园春色综合网| 欧美精品久久| 成人免费一区| 按摩亚洲人久久| a片在线免费观看| 欧美激情一区二区三区| 久久黄色片网站| 自拍日韩欧美| 国产精品国产三级欧美二区| yellow在线观看网址| 日韩av在线免费| 亚洲欧美日韩激情| 国产午夜精品久久| 天堂视频免费看| 欧美日韩国产高清| 国产自产精品| 日韩免费va| 久久精品99久久久香蕉| www.国产.com| 欧美日韩综合视频| 极品久久久久久久| 国产精品456| 欧美老熟妇喷水| 第一sis亚洲原创| 亚洲影院在线看| 国产在线天堂www网在线观看| 欧美一个色资源| 日韩欧美亚洲国产| 久久久久久黄色| 国产精品自在自线| 狠狠干综合网| 欧美一区二区三区精美影视 | 99久久精品情趣| 国产美女三级视频| 三区四区不卡| 国产一区二区三区高清视频| 欧美二三四区| 欧美成人精品在线观看| 婷婷色在线视频| 欧美日韩激情在线| 国产精品99精品| 国产精品妹子av| 给我免费观看片在线电影的| 日本美女一区二区| 激情五月婷婷六月| 日本久久精品| 国产主播一区二区三区四区| 欧美性www| 欧美亚洲另类制服自拍| 国产精品久久麻豆| 亚洲一二三在线| 亚洲欧美激情在线观看| 欧美日韩精品一区二区三区蜜桃 | 天堂av中文字幕| 欧美日韩一区久久| 欧美videossex极品| 一区二区高清在线| 国产精品69久久久久孕妇欧美| 美洲天堂一区二卡三卡四卡视频 | 在线免费看黄色片| 开心九九激情九九欧美日韩精美视频电影 | 国产一二三在线视频| 久久亚洲在线| 欧美日韩精品一区| 风间由美一区二区av101| 国产啪精品视频| 外国成人直播| 国内精品久久久久久久久| 国产日产一区二区| 在线看日韩欧美| 免费人成黄页在线观看忧物| 精品国产一区二区三区不卡| 一二区在线观看| 色综合久久久网| 精品人妻一区二区三区免费看| 日本一区二区免费在线| 人妻无码中文久久久久专区| 国产成人a级片| 污视频在线观看免费网站| 免费欧美在线视频| 日韩免费高清在线| 免费久久99精品国产自在现线| 日韩免费一区二区三区| 亚洲免费福利一区| 激情伦成人综合小说| 丁香婷婷成人| 国产伦精品一区二区三区照片91| 深夜成人在线| 久久免费国产视频| 美女尤物在线视频| 欧美激情乱人伦| 国精一区二区三区| 欧美乱妇高清无乱码| 香蕉久久aⅴ一区二区三区| 精品国产依人香蕉在线精品| 青青影院在线观看| 久久人人爽人人爽爽久久| 黄色免费在线看| 久久国产精品久久久久久| 中文字幕在线观看网站| 欧美成人手机在线| 青春草在线视频| 久久久久久一区二区三区| 免费男女羞羞的视频网站在线观看 | 亚洲曰韩产成在线| 久久久久无码国产精品不卡| 亚洲激情成人在线| 福利一区二区三区四区| 欧美视频第一页| 久草视频在线免费| 欧美日韩和欧美的一区二区| 在线观看免费高清视频| 欧美一级在线免费| 色欲av永久无码精品无码蜜桃 | 欧美在线观看在线观看| 亚洲精品国精品久久99热| 日韩精品系列| 主播福利视频一区| 中文字幕免费高清电视剧网站在线观看| 亚洲免费av网址| 婷婷在线视频观看| 欧美裸体xxxx极品少妇| 亚洲插插视频| 国产免费一区视频观看免费| 欧美久久一区二区三区| 国产一区在线观| 波多野结衣在线观看一区二区| 久久综合福利| 色综合咪咪久久网| 视色,视色影院,视色影库,视色网 日韩精品福利片午夜免费观看 | 日韩一区二区三区四区视频| 一区二区三区在线观看网站| 国产成人无码精品亚洲| 在线免费精品视频| 国产99视频在线| 亚洲女人天堂色在线7777| 求av网址在线观看| 91禁国产网站| 国产毛片精品久久| 精品日产一区2区三区黄免费| 第四色中文综合网| 亚洲欧美日韩精品在线| 亚洲激情欧美| 污视频网站观看| 成人免费视频国产在线观看| 丁香激情五月少妇| 亚洲成人精品在线观看| 伊人免费在线观看| 亚洲精品suv精品一区二区| 在线中文资源天堂| 欧美有码在线观看视频| 欧美三级一区| 亚洲欧美日韩在线综合 | 欧洲熟妇精品视频| 国产99久久久国产精品免费看| 性生活一级大片| 久久久精品免费网站| 国产亚洲欧美精品久久久www| 夜夜嗨av一区二区三区中文字幕| 黄色一级视频免费| 欧美无砖砖区免费| 手机看片一区二区| 欧美精品在线看| 久久久久伊人| 欧洲一区二区日韩在线视频观看免费| 国产99久久久国产精品成人免费 | 国产精品视频在线观看| 国产精品极品在线观看| 亚洲最大色综合成人av| 久久综合九色综合欧美狠狠| 国产一级黄色录像| 一区二区三区中文字幕精品精品 | 日韩电影在线免费观看| 国产一级免费片| 亚洲久草在线视频| 亚洲综合精品国产一区二区三区| 欧美一级夜夜爽| 在线视频1区2区| 国产精品一区二区久久| 黑丝美女一区二区| 久久精品一区二| 久久久亚洲综合| av大全在线观看| 日韩毛片在线观看| 午夜av不卡| 六月婷婷久久| 亚洲在线网站| 偷拍女澡堂一区二区三区| 精品美女久久久久久免费| 日韩有码第一页| 孩xxxx性bbbb欧美| 一区二区在线视频观看| 国产专区在线视频| 国产成人8x视频一区二区| 精品无码av在线| 日韩av在线最新| 91精品论坛| 亚洲不卡1区| 日本不卡免费在线视频| 日本污视频网站| 欧美精品三级在线观看| av片在线观看| 国产精品久久久久久久久婷婷| 成人区精品一区二区婷婷| 日日噜噜噜噜久久久精品毛片| 国产成人av电影在线| 久久午夜无码鲁丝片午夜精品| 欧美视频一区二区三区在线观看| 超碰福利在线观看| 久久人人爽人人| 日本妇女一区| 人人爽人人av| 中文字幕亚洲电影| www.亚洲欧美| 欧日韩不卡在线视频| 精品国产一区二区三区四区| 日本高清久久久| 亚洲一区二区精品视频| 亚洲欧美丝袜中文综合| 国产精品视频不卡| 欧美日韩一区二区国产| av网站有哪些| 欧美日韩电影在线| 成人性生交大片免费看网站| 欧美不卡三区| 国产一区二区不卡老阿姨| 中文字幕一区二区三区手机版| 欧美刺激脚交jootjob| 日韩精品av| 在线免费一区| 久久综合国产精品| 中文字幕一区二区三区人妻四季| 国产亚洲欧美aaaa| 成人在线视频国产| 成人在线免费在线观看 | 久久亚洲无码视频| 5566中文字幕一区二区电影| 欧美亚洲日本精品| 老司机av福利| caoporn国产精品| 一级片视频播放| 情事1991在线| 国内精品99| 欧美性猛交xxxx乱大交少妇| 亚洲精品久久久久中文字幕欢迎你|