[集群聊天服务器]----(五)User类、UserModel类

2024-05-25 08:52

本文主要是介绍[集群聊天服务器]----(五)User类、UserModel类,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

接着上文[集群聊天服务器]----(四)MySQL数据库模块,接下来我们对User类、UserModel类进行剖析,User表和UserModel类是项目最基本也是最重要的部分,通过它我们对用户的id,用户名,密码,状态相关信息进行存储,也决定了登录成功与否以及后续的聊天等内容。

User表设计

在这里插入图片描述
创建 User 类:

#ifndef USER_H
#define USER_H#include <string>
using namespace std;//匹配user表的ORM类
class User {
public:User(int id=-1,string name="", string pwd="",string state="offline"){this->id=id;this->name=name;this->password=password;this->state=state;}void setId(int id) {this->id=id;}void setName(string name) {this->name=name;}void setPwd(string password) {this->password=password;}void setState(string state) {this->state=state;}int getId() {return this->id;}string getName() {return this->name;}string getPwd() {return this->password;}string getState() {return this->state;}private:int id;string name;string password;string state;};#endif
  • 由于user的id是填入表格以后,数据库自动创建的,所以初始时赋予-1,并提供了设置/获取id,用户名,用户密码,用户状态的相关函数。

创造UserModel类对User表进行数据操作

成员函数

    //user表的增加方法bool insert(User &user);//根据用户号码查询用户信息 User query(int id);//更新用户的状态信息bool updateState(User &user);//重置用户的状态信息void resetState();

user表的增加方法

 bool UserModel::insert(User &user){//组装sql语句char sql[1024] = {0};sprintf(sql,"insert into user(name,password,state) values('%s','%s','%s')",user.getName().c_str(),user.getPwd().c_str(),user.getState().c_str()); MySQL mysql;//连接数据库if(mysql.connect()){//更新数据库语句if(mysql.update(sql)){//获取插入成功的用户数据生成的主键iduser.setId(mysql_insert_id(mysql.getConnection()));return true;}}return false;
}
  • 首先组装sql语句;
  • 创建数据库对象,并连接数据库,根据sql语句进行更新user表,其中user为表格名字,user()括号中的为要插入的内容标题,values为对应的值,注意,表格名字以及对应的内容标题一定要和表格对应,否则插入失败
  • 更新成功会生成用户id,调用mysql_insert_id()函数在user中进行设置,(mysql.getConnection()作用是获取mysql的连接

根据用户号码查询用户信息

User UserModel::query(int id)
{char sql[1024] = {0};sprintf(sql,"select * from user where id =%d",id);MySQL mysql;//连接数据库if(mysql.connect()){//更新数据库语句MYSQL_RES *res = mysql.query(sql); //指针 内部动态内存开辟 需要释放资源if(res != nullptr){//获取行 根据主键查MYSQL_ROW row = mysql_fetch_row(res);if(row != nullptr){User user;user.setId(atoi(row[0]));user.setName(row[1]);user.setPwd(row[2]);user.setState(row[3]);mysql_free_result(res);return user;}}}return User();
}
  • 组装sql语句,select * from user where id =%d是对user进行查找id;
  • 连接数据库,并根据sql语句调用mysql_use_result()函数(属于MYSQL_RES类型)逐行进行查询,在调用mysql_fetch_row()读取结果;
  • 创建一个User对象,并根据查找结果设置其相应值,返回User对象
  • 注意res为内部动态内存开辟,需要释放资源

更新用户的状态信息

bool UserModel::updateState(User &user)
{char sql[1024] = {0};sprintf(sql,"update user set state = '%s' where id = %d",user.getState().c_str(),user.getId()); MySQL mysql;//连接数据库if(mysql.connect()){//更新数据库语句if(mysql.update(sql)){return true;}}return false;
}
  • 组装sql语句,根据id,更新 user表中的状态;
  • 连接数据库进行更新

重置用户的状态信息

void UserModel::resetState()
{char sql[1024] = "update user set state = 'offline' where state = 'online'";MySQL mysql;//连接数据库if(mysql.connect()){//更新数据库语句mysql.update(sql);}}
  • 组装sql语句,这个函数主要是针对捕捉到服务器ctrl+c异常结束后,重置user的状态信息,将表格中online用户的状态都改为offline;
  • 连接数据库进行更新

好了~ 关于集群聊天服务器中的User类和UserModel类的剖析就到此结束了,接下来我们将进入业务模块正题,用户注册、登录、退出以及客户端异常退出回调函数,下一节见~

这篇关于[集群聊天服务器]----(五)User类、UserModel类的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1001042

相关文章

Prometheus+cpolar如何在手机上也能监控服务器状态?

《Prometheus+cpolar如何在手机上也能监控服务器状态?》本文强调了通过Cpolar这一内网穿透工具,轻松突破Prometheus仅限于局域网访问的限制,实现外网随时随地访问监控数据,教你... 目录前言1.安装prometheus2.安装cpolar实现随时随地开发3.配置公网地址4.保留固定

MySQL MHA集群详解(数据库高可用)

《MySQLMHA集群详解(数据库高可用)》MHA(MasterHighAvailability)是开源MySQL高可用管理工具,用于自动故障检测与转移,支持异步或半同步复制的MySQL主从架构,本... 目录mysql 高可用方案:MHA 详解与实战1. MHA 简介2. MHA 的组件组成(1)MHA

Linux服务器数据盘移除并重新挂载的全过程

《Linux服务器数据盘移除并重新挂载的全过程》:本文主要介绍在Linux服务器上移除并重新挂载数据盘的整个过程,分为三大步:卸载文件系统、分离磁盘和重新挂载,每一步都有详细的步骤和注意事项,确保... 目录引言第一步:卸载文件系统第二步:分离磁盘第三步:重新挂载引言在 linux 服务器上移除并重新挂p

Apache服务器IP自动跳转域名的问题及解决方案

《Apache服务器IP自动跳转域名的问题及解决方案》本教程将详细介绍如何通过Apache虚拟主机配置实现这一功能,并解决常见问题,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,... 目录​​问题背景​​解决方案​​方法 1:修改 httpd-vhosts.conf(推荐)​​步骤

golang实现nacos获取配置和服务注册-支持集群详解

《golang实现nacos获取配置和服务注册-支持集群详解》文章介绍了如何在Go语言中使用Nacos获取配置和服务注册,支持集群初始化,客户端结构体中的IpAddresses可以配置多个地址,新客户... 目录golang nacos获取配置和服务注册-支持集群初始化客户端可选参数配置new一个客户端 支

MySQL集群高可用架构的两种使用小结

《MySQL集群高可用架构的两种使用小结》本文介绍了MySQL的两种高可用解决方案:组复制(MGR)和MasterHighAvailability(MHA),文中通过示例代码介绍的非常详细,对大家的学... 目录一、mysql高可用之组复制(MGR)1.1 组复制核心特性与优势1.2 组复制架构原理1.3

Docker + Redis 部署集群的实现步骤

《Docker+Redis部署集群的实现步骤》本文详细介绍了在三台服务器上部署高可用Redis集群的完整流程,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋... 目录一、环境准备1. 服务器规划(3 台服务器)2. 防火墙配置(三台服务器均执行)3. 安装 docke

springBoot (springCloud2025)集成redisCluster 集群的操作方法

《springBoot(springCloud2025)集成redisCluster集群的操作方法》文章介绍了如何使用SpringBoot集成RedisCluster集群,并详细说明了pom.xm... 目录pom.XMLapplication.yamlcluster配置类其他配置类连接池配置类Redis

Linux云服务器手动配置DNS的方法步骤

《Linux云服务器手动配置DNS的方法步骤》在Linux云服务器上手动配置DNS(域名系统)是确保服务器能够正常解析域名的重要步骤,以下是详细的配置方法,包括系统文件的修改和常见问题的解决方案,需要... 目录1. 为什么需要手动配置 DNS?2. 手动配置 DNS 的方法方法 1:修改 /etc/res

Nginx屏蔽服务器名称与版本信息方式(源码级修改)

《Nginx屏蔽服务器名称与版本信息方式(源码级修改)》本文详解如何通过源码修改Nginx1.25.4,移除Server响应头中的服务类型和版本信息,以增强安全性,需重新配置、编译、安装,升级时需重复... 目录一、背景与目的二、适用版本三、操作步骤修改源码文件四、后续操作提示五、注意事项六、总结一、背景与