QT--5

1> 将网络聊天室重新实现一遍

服务器端

#include "widget.h"
#include "ui_widget.h"Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget)
{ui->setupUi(this);ser = new QTcpServer(this);
}Widget::~Widget()
{delete ui;
}void Widget::on_startBtn_clicked()
{if(ui->startBtn->text() == "启动"){quint16 port = ui->lineEdit->text().toUInt();if(ser->listen(QHostAddress::Any,port)==true){QMessageBox::information(this,"成功","服务器启动成功");}else{QMessageBox::information(this,"失败","服务器启动失败");}//当启动服务器后,如果有客户端发来连接请求,那么该服务器端就会自动化发送一个newConnection信号//我们可以将信号,连接到对应的槽函数connect(ser,&QTcpServer::newConnection,this,&Widget::newconnection_slot);ui->startBtn->setText("关闭");}else{ser->close();ui->startBtn->setText("启动");}
}
//关于readyread信号对应的槽函数的定义
void Widget::readyread_slots()
{//判断客户端容器中,是否已经有退出的客户端,或者无效的客户端,或者无效的客户端,如果有,将其进行移除for(int i=0;i<cliList.length();i++){if(cliList[i]->state() == QTcpSocket::UnconnectedState){//功能:判断当前套接字的状态//参数:无//返回值:readyread_slots表示无效的客服端cliList.removeAt(i);}}for(int i=0;i<cliList.length();i++){if(cliList[i]->bytesAvailable()!=0){//获取当前套接字中套接字中的待读数据的个数//参数:无//返回值:返回套接字中待读//如果不等于0;表示有数据可读,可以使用readall读取数据QByteArray msg = cliList[i]->readAll();ui->msgWidget->addItem(QString::fromLocal8Bit(msg));for(int j=0;j<cliList.length();j++){if(i!=j){cliList[j]->write(msg);}}}}}
void Widget::newconnection_slot()
{qDebug() << "有客户端发来连接请求";QTcpSocket *socket = ser->nextPendingConnection();cliList.append(socket);//当有客户端向服务器发来数据时候,当前客户端套接字就会自动发送一个readyread信号//我们就可以connect(socket,&QTcpSocket::readyRead,this,&Widget::readyread_slots);}

客户端 

#include "widget.h"
#include "ui_widget.h"Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget)
{ui->setupUi(this);this->resize(800,600);this->setFixedSize(800,600);this->setWindowTitle("网络聊天室");list = new QListWidget(this);list->resize(800,400);edtsend = new QLineEdit(this);edtsend->setPlaceholderText("发送消息");edtsend->resize(450,80);edtsend->move(50,420);edtname = new QLineEdit(this);edtname->setPlaceholderText("用户名");edtname->resize(100,50);edtname->move(50,500);edtip = new QLineEdit(this);edtip->setPlaceholderText("ip");edtip->resize(300,50);edtip->move(150,500);edtport = new QLineEdit(this);edtport->setPlaceholderText("port");edtport->resize(300,50);edtport->move(100,550);btnsend = new QPushButton("发送",this);btnsend->resize(100,50);btnsend->move(600,450);btnlink = new QPushButton("连接服务器",this);btnlink->resize(100,50);btnlink->move(600,550);cli = new QTcpSocket(this);connect(cli,&QTcpSocket::connected,this,&Widget::connected_slot);connect(cli,&QTcpSocket::readyRead,this,&Widget::readyread_slot);connect(cli,&QTcpSocket::disconnected,this,&Widget::disconnectes_slot);connect(btnlink,&QPushButton::clicked,this,&Widget::on_connectBtn_clicked);connect(btnsend,&QPushButton::clicked,this,&Widget::on_sendBtn_clicked);// connect(btn,&QPushButton::clicked,this,&Widget::cliked_slot);
}Widget::~Widget()
{delete ui;
}void Widget::connected_slot()
{QMessageBox::information(this,"连接","连接服务器成功");}void Widget::readyread_slot()
{QByteArray msg = cli->readAll();list->addItem(QString::fromLocal8Bit(msg));}void Widget::disconnectes_slot()
{QMessageBox::information(this, "断开", "断开服务器成功");
}
//信息发送按钮对应的槽函数
void Widget::on_sendBtn_clicked()
{//1、将ui界面上的文本信息获取下来QString msg = userName + ":" + edtsend->text();//2、将该消息发送给服务器cli->write(msg.toLocal8Bit());//3、清空航编辑器中的内容edtsend->clear();//将消息放入ui界面中QListWidgetItem *item = new QListWidgetItem(msg);item->setTextAlignment(Qt::AlignRight);list->addItem(item);
}
//连接服务器按钮对应的槽函数
void Widget::on_connectBtn_clicked()
{if(btnlink->text() == "连接服务器"){userName = edtname->text();         //用户名QString ip = edtip->text();            //ip地址quint16 port = edtport->text().toUInt();   //端口号cli->connectToHost(ip, port);btnlink->setText("断开服务器");}else{QString msg = userName + ": 离开聊天室";cli->write(msg.toLocal8Bit());cli->disconnectFromHost();btnlink->setText("连接服务器");}
}

2> 将数据库管理系统,进行完善

#include "widget.h"
#include "ui_widget.h"Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget)
{ui->setupUi(this);//判断当前数据库操作对象中,是否包含了要处理的数据库if(!db.contains("mydb.db")){//添加一个数据库到当前数据库对象中db = QSqlDatabase::addDatabase("QSQLITE");//给数据库设置名字db.setDatabaseName("mydb.db");}//此时,已经创建了一个数据库,但是没有打开if(!db.open()){QMessageBox::information(this,"失败","数据库打开失败");return;}//程序执行至此,数据库打开成功//准备sql语句QString sql = "create table if not exists Stu(numb int , name char , sex char , score double)";//实例化一个sql语句的的执行者QSqlQuery query;if(!query.exec(sql)){QMessageBox::information(this,"提示","创建数据表失败");return;}}Widget::~Widget()
{delete ui;
}//添加学院信息按钮对应的槽函数
void Widget::on_pushButton_clicked()
{//将ui界面上的相关信息获取下来int ui_numb = ui->lineEdit->text().toUInt();QString ui_name = ui->lineEdit_2->text();QString ui_sex = ui->lineEdit_3->text();double ui_score = ui->lineEdit_4->text().toDouble();if(ui_sex==NULL || ui_numb==0 || ui_score==0 || ui_name==NULL){QMessageBox::information(this,"提示","请将信息填写完整");return;}//准备sql语句QString sql = QString("insert into Stu values(%1,'%2','%3',%4)").arg(ui_numb).arg(ui_name).arg(ui_sex).arg(ui_score);//执行sql语句QSqlQuery query;if(!query.exec(sql)){QMessageBox::information(this,"提示","添加数据表失败");return;}else{QMessageBox::information(this,"提示","添加数据表成功");}
}
//删除按钮对应的槽函数
void Widget::on_pushButton_2_clicked()
{QString sql;if(ui->lineEdit_2->text() == NULL){sql = "delete * from Stu";}else{sql = QString("delete  from Stu where name='%1'").arg(ui->lineEdit_2->text());}//执行sql语句QSqlQuery query;if(!query.exec(sql)){QMessageBox::information(this,"提示","删除数据表失败");return;}else{QMessageBox::information(this,"提示","删除数据表成功");}//将查询结果展示到ui上int i = 0;while(query.next()){//通过条用Qsqlrecord类的成员函数:valuefor(int j=0;j<query.record().count();j++){//qDebug() << query.record().value(j).toString();QTableWidgetItem *item = new QTableWidgetItem(query.record().value(j).toString());item->setTextAlignment(Qt::AlignCenter);//将数据库中的数据依次存放到ui界面中 ui->tableWidget->setItem(i,j,item);}i++;}
}
//修改
void Widget::on_pushButton_3_clicked()
{QString sql;if(ui->lineEdit_2->text() == NULL){sql = "delete * from Stu";}else{sql = QString("update stu set name='%1' from Stu where numb='%2'").arg(ui->lineEdit_2->text()).arg(ui->lineEdit->text());}//执行sql语句QSqlQuery query;if(!query.exec(sql)){QMessageBox::information(this,"提示","更新数据表失败");return;}else{QMessageBox::information(this,"提示","更新数据表成功");}}
//查找按钮对应的槽函数
void Widget::on_pushButton_4_clicked()
{QString sql;if(ui->lineEdit_2->text() == NULL){sql = "select * from Stu";}else{sql = QString("select * from Stu where name='%1'").arg(ui->lineEdit_2->text());}//执行sql语句QSqlQuery query;if(!query.exec(sql)){QMessageBox::information(this,"提示","查询数据表失败");return;}else{QMessageBox::information(this,"提示","查询数据表成功");}//将查询结果展示到ui上int i = 0;while(query.next()){//这里面是任意一个查询的结果。query对象中保存的是当前的一个记录//可以通过成员函数recordqDebug() << query.record().value(1).toString(); //每一次转变成字符串的值//通过条用Qsqlrecord类的成员函数:valuefor(int j=0;j<query.record().count();j++){//qDebug() << query.record().value(j).toString();QTableWidgetItem *item = new QTableWidgetItem(query.record().value(j).toString());item->setTextAlignment(Qt::AlignCenter);//将数据库中的数据依次存放到ui界面中ui->tableWidget->setItem(i,j,item);}i++;}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://xiahunao.cn/news/3029949.html

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

### 【数据结构】线性表--顺序表(二)

文章目录 1、什么是线性表2、线性表的基本操作3、顺序表3.1、顺序表的定义3.2、顺序表的实现方式&#xff1a;静态分配3.3、顺序表的实现方式&#xff1a;动态分配3.4、顺序表的特点3.5、顺序表的初始化与插入操作3.6、顺序表的删除与查询 1、什么是线性表 ​ 线性表是具有相同…

Selenium web 网页测试自动化需要哪些技术?

引言&#xff1a; 在当今互联网时代&#xff0c;网页测试自动化成为了确保软件质量和提高效率的重要手段之一。Selenium是一种功能强大且广泛应用的工具&#xff0c;可用于实现网页测试自动化。本文将带您了解Selenium Web网页测试自动化所需的技术和步骤&#xff0c;以便您从…

生成式AI+跨境电商有哪些新玩法?店匠科技与亚马逊云科技已经在路上

导读 跨境电商一直是生成式AI最热门的应用领域之一。 生成式AI在跨境电商行业的核心应用场景有哪些&#xff1f;AI跨境电商又有哪些新玩法&#xff1f; 根据海关数据&#xff0c;2023年我国跨境电商进出口总额达2.38万亿元&#xff0c;增长15.6%。我国跨境电商主体已超10万家…

Set接口

Set接口的介绍 Set接口基本介绍 无序&#xff08;添加和取出的顺序不一致&#xff09;&#xff0c;没有索引不允许重复元素&#xff0c;所以最多包含一个nullJDK API中Set接口的实现类&#xff1a;主要有HashSet&#xff1b;TreeSet Set接口的常用方法 和List 接口一样&am…

【Linux】从零开始认识动静态库 - 静态库

送给大家一句话: 永不言弃&#xff0c;就是我的魔法&#xff01; ——阿斯塔《黑色四叶草》 ଘ(੭ˊ꒳​ˋ)੭✧ଘ(੭ˊ꒳​ˋ)੭✧ଘ(੭ˊ꒳​ˋ)੭✧ ଘ(੭ˊ꒳​ˋ)੭✧ଘ(੭ˊ꒳​ˋ)੭✧ଘ(੭ˊ꒳​ˋ)੭✧ ଘ(੭ˊ꒳​ˋ)੭✧ଘ(੭ˊ꒳​ˋ)੭✧ଘ(੭ˊ꒳​ˋ)੭✧ 从零…

案例研究|硬之城借助DataEase以数据驱动供应链精细化管理

深圳硬之城信息技术有限公司&#xff08;以下简称为“硬之城”&#xff09;成立于2015年&#xff0c;专注电子元件供应链领域&#xff0c;定位于电子产业供应链与智造平台。硬之城通过名为“Allchips”的集成式服务平台&#xff0c;为客户提供一站式的电子元件采购和供应链管理…

走进C++:C到C++的过渡

目录 什么是C呢&#xff1f; C的发展史 多了一些吃前来很香的“语法糖”。 语法糖一&#xff1a;命名空间 命名空间有个强大的功能 如何使用 语法糖二&#xff1a;缺省参数 语法糖三&#xff1a;函数重载 语法糖四&#xff1a;引用 引用传参 引用返回 引用和…

自托管站点监控工具 Uptime Kuma 搭建与使用

本文首发于只抄博客&#xff0c;欢迎点击原文链接了解更多内容。 前言 Uptime Kuma 是一个类似 Uptime Robot 的站点监控工具&#xff0c;它可以自托管在自己的 Nas 或者 VPS 上&#xff0c;用来监控各类站点、数据库等 监控类型&#xff1a;支持监控 HTTP(s) / TCP / HTTP(s…

服务丢在tomcat中启动war包,需要在tomcat中配置Java环境吗?

一般来说&#xff0c;部署在 Tomcat 上的 WAR 包启动时不需要在 Tomcat 中单独配置 Java 环境&#xff0c;因为 Tomcat 启动本身就需要依赖 Java 环境。以下是确保 Tomcat 正常运行与部署 WAR 包的基本步骤&#xff1a; 安装 Java 环境&#xff1a; 首先&#xff0c;确保你的系…

springboot增删改查

我的记录 RestController RequestMapping("/user") public class UserController {Autowiredprivate UserService userService;GetMapping("/list")public List<User> list(){return userService.list();}//新增PostMapping("/save")publi…

stm32 FOC系列 直流无刷6步换向控制原理

1、直流无刷电机的简介 直流无刷电机 (Brushless Direct Current Motor&#xff0c;简称 BLDCM) &#xff0c; 其最大的特点就是取消 了传统有刷电机中的电刷和换向器等结构。 因此线圈绕组不参与旋转&#xff0c;而是作为定子&#xff0c;永磁 体作为转子&#xff0c;所以需要…

vue3 antd-vue 超简单方式实现a-table跨页勾选

一、效果如下&#xff1a; 第一页勾选了2&#xff0c; 3&#xff0c; 4 翻到第三页勾选24&#xff0c; 25 回显&#xff0c;如比返回第一页的时候触发分页改变&#xff0c; 在映射中的第一页的数据给到a-table绑定的state.selectedRowKeys即可&#xff0c;如下方法 二、勾选思路…

luceda ipkiss教程 69:导出器件或者线路的三维模型

ipkiss 3.12版加入write_obj函数&#xff0c;可以直接输出器件的三维模型。 如&#xff0c;输出自定义的mmi的三维模型&#xff1a; 代码如下&#xff1a; from si_fab import all as pdk from ipkiss3 import all as i3class MMI1x2(i3.PCell):"""MMI with …

给网络镜像模式下的 WSL2 使用 127.0.0.1代理的方法

网络镜像模式下的WSL2虽然复制了宿主机windows的ip&#xff0c;但是仍然无法访问127.0.0.1的代理。经过调查&#xff0c;发现因为WSL2从应用商店下载而来&#xff0c;所以可能是UWP应用&#xff0c;所以需要用工具解除环回代理限制。

【吃透Java手写】4-Tomcat-简易版

【吃透Java手写】Tomcat-简易版-源码解析 1 准备工作1.1 引入依赖1.2 创建一个Tomcat的启动类 2 线程池技术回顾2.1 线程池的使用流程2.2 线程池的参数2.2.1 任务队列&#xff08;workQueue&#xff09;2.2.2 线程工厂&#xff08;threadFactory&#xff09;2.2.3 拒绝策略&…

idea运行SpringBoot项目爆红提示出现:Java HotSpot(TM) 64-Bit Server VM warning...让我来看看~

在运行SpringBoot项目的时候&#xff0c;发现总有这个警告提示出现&#xff0c;有点强迫症真的每次运行项目都很难受啊&#xff01;那么今天便来解决这个问题&#xff01; 先来看一下提示内容&#xff1a;Java HotSpot(TM) 64-Bit Server VM warning: Options -Xverify:none an…

智慧公厕:让厕所管理变得更智慧、高效、舒适!

公共厕所是城市的重要组成部分&#xff0c;但常常被忽视。它们的管理和养护往往面临着许多问题&#xff0c;例如卫生状况不佳、环境畏畏缩缩、设施老旧等。为了解决这些问题&#xff0c;智慧公厕应运而生。智慧公厕是一种全方位的应用解决方案&#xff0c;将科技与公共厕所管理…

centos安装mysql-client

直接安装&#xff1a; yum install mysql-community-client报了错误No package mysql-community-client available. 原因&#xff1a;CentOS/RHEL系统默认的软件源中并不包含MySQL软件包&#xff0c;需要通过添加第三方存储库来获取MySQL相关软件 添加源 安装MySQL官方的Yum…

Box86源码解读记录

1. 背景说明 Github地址&#xff1a;https://github.com/ptitSeb/box86 官方推荐的视频教程&#xff1a;Box86/Box64视频教程网盘 2. 程序执行主体图 Box86版本: Box86 with Dynarec v0.3.4 主函数会执行一大堆的初始化工作&#xff0c;包括但不限于&#xff1a;BOX上下文 …

docker端口映射成功,docker端口不生效的问题解决,外界无法访问docker映射端口

docker端口映射不生效的问题解决 问题 使用docker run -p 88848:8848后&#xff0c;显示容器启动正常&#xff0c;并且使用docker logs –f xxx能够看到容器可以正常启用&#xff0c;docker ps 可以看到容器启动成功&#xff0c;并且端口已经映射,但是在浏览器访问相关地址&am…