从零实现基于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

2015-07-06 10:42:18

PHP聊天室应用

2023-02-10 08:16:48

WebSocket简易聊天室

2020-06-08 14:36:50

数据中心端口密度网络

2014-02-18 13:40:23

Office 365数字签名

2023-01-13 00:02:41

2023-01-05 09:17:58

2022-07-26 14:53:10

WebSocket网络通信协议

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-04-05 13:46:21

日志数据库系统

2022-12-01 08:25:23

eTsTCP聊天室

2011-07-04 18:02:29

QT Sqlite 数据库
点赞
收藏

51CTO技术栈公众号