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://www.mzph.cn/bicheng/9900.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Aapache Tomcat AJP 文件包含漏洞(CVE-2020-1938)

1 漏洞描述 CVE-2020-1938 是 Apache Tomcat 中的一个严重安全漏洞&#xff0c;该漏洞涉及到 Tomcat 的 AJP&#xff08;Apache JServ Protocol&#xff09;连接器。由于 AJP 协议在处理请求时存在缺陷&#xff0c;攻击者可以利用此漏洞读取服务器上的任意文件&#xff0c;甚至…

【Linux】Linux——Centos7安装Nginx

不需要安装包 1.安装依赖 #查看 C 环境是否安装gcc -v #查看 zlib 是否安装cat /usr/lib64/pkgconfig/zlib.pc #查看 pcre 是否安装pcre-config --version 2.安装C #安装C yum install gcc-c 3.安装pcre yum install -y pcre pcre-devel 4.安装zlib #安装 yum install -y zlib…

该问题未得到解决(仅记录)

https://releases.ubuntu.com/bionic/进入网页下载ubuntu 选择烧录软件将下载的Ubuntu烧录到U盘中 之前用这个U盘烧录过一次&#xff0c;成功了&#xff0c;后来应该是U盘受损或者是什么其他原因使得用这个U盘总是烧录失败

ChatGLM大模型简介

ChatGLM系列是国产大语言模型中性能最好、回答准确率最高的大模型。如果有毕业论文、课题研究的需要&#xff0c;可以关注一下这个大模型。 清华大学和智谱AI的第一代ChatGLM-6B在2023年3月份推出&#xff0c;开源模型推出之后不久就获得了很多的关注和使用。3个月后的2023年6…

快速上手文心一言指令

人不走空 &#x1f308;个人主页&#xff1a;人不走空 &#x1f496;系列专栏&#xff1a;算法专题 ⏰诗词歌赋&#xff1a;斯是陋室&#xff0c;惟吾德馨 目录 &#x1f308;个人主页&#xff1a;人不走空 &#x1f496;系列专栏&#xff1a;算法专题 ⏰诗词歌…

【NPM】Nginx Proxy Manager 一键申请 SSL 证书,自动续期,解决阿里云SSL免费证书每3个月失效问题

文章目录 1、NPM 简介2、实战Step 1&#xff1a;环境搭建 也可以看作者安装笔记 Step 2&#xff1a;创建容器 2.1 在系统任意位置创建一个文件夹&#xff0c;此文档以~/nginx-proxy-manager为例。2.2 创建docker-compose.yaml2.3 启动NPM服务 Step 3&#xff1a;配置反向代理3…

搭建知识库必备:12个开源 Wiki 软件工具盘点

在任何成功的公司中&#xff0c;部门间的知识共享是至关重要的。如果没有一个简单的信息交流方法&#xff0c;团队怎样才能有效合作呢&#xff1f;Wiki软件提供了一种创建、组织及在全公司范围内分享知识的直接方法。但是&#xff0c;哪一种Wiki软件是最佳的选择呢&#xff1f;…

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

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

Java入门基础学习笔记13——数据类型

数据类型的分类&#xff1a; 基本数据类型 引用数据类型 基本数据类型&#xff1a;4大类8种类型&#xff1a; 定义整形用int&#xff0c;再大的数用long。 package cn.ensource.variable;public class VariableDemo2 {public static void main(String[] args) {//目标&#x…

Android11 InputDispatcher 分发事件流程分析

在 Android11 InputReader分析 一文中分析到&#xff0c;InputReader将数据放入iq队列后&#xff0c;唤醒InputDispatcher线程&#xff0c;执行InputDispatcher的dispatchOnce方法 //frameworks\native\services\inputflinger\dispatcher\InputDispatcher.cpp void InputDispa…

【js】将一维数组处理成树形数据并且实现模糊查询

项目中由于数据量不大&#xff0c;后台并未做处理&#xff0c;因此前端拿到返回的Table数据需要处理成树形数据再渲染到表格中 原始数据 const dataList[{"id": 44,"seedlingName": "测试2","seedlingType": "测试2",&quo…

一文读懂开源大数据OLAP

企业需要从海量数据中提取有价值的信息&#xff0c;以支持决策制定和提高运营效率&#xff0c;数据已成为企业最宝贵的资产之一。OLAP&#xff08;在线分析处理&#xff09;技术&#xff0c;作为数据仓库解决方案的核心组成部分&#xff0c;提供了一种强大的工具&#xff0c;帮…

java-springboot项目添加swagger2/Knife4j,附注解

文章目录 添加依赖config工作包中新增SwaggerConfig报错注解 环境&#xff1a; jdk1.8 java8 springboot2.6.13 swagger2.9.2 添加依赖 pom.xml <!-- 添加swagger2--><dependency><groupId>io.springfox</groupId><artifactId>springfo…

【C++】list的使用与模拟实现

&#x1f525;个人主页&#xff1a;北辰水墨 &#x1f525;专栏&#xff1a;C学习仓 本节内容我们来讲解list的使用和模拟实现。 本节难点&#xff1a;list迭代器的模拟实现。 一、list的介绍&#xff1a; 列表 列表是一种序列容器&#xff0c;允许在序列的任何位置进行时间复…

基于springboot+mybatis+vue的项目实战之页面参数传递

如图所示&#xff0c;删除操作可以用按钮实现&#xff0c;也可以用超链接来实现。 1、第一种情况&#xff0c;用按钮实现。 html页面相关&#xff1a; <button type"button" click"deleteId(peot.id)">删除</button> <script>new Vue(…

【算法与数据结构】数组

文章目录 前言数组数组的定义数组的基本操作增加元素删除元素修改元素查找元素 C STL 中的数组arrayvector Python3 中的列表访问更改元素值遍历列表检查列表中是否存在某元素增加元素删除元素拷贝列表总结 Python3 列表的常用操作 参考资料写在最后 前言 本系列专注更新基本数…

从0开始Jmeter接口测试实战

在之前的文章中给大家介绍过接口测试文档和接口测试用例示例&#xff0c;本文基于Jmeter工具给大家介绍一下如何实现接口测试用例&#xff1a;包括发起Http请求&#xff0c;绕过登陆&#xff0c;验证响应。JMeter是Apache组织开发的基于Java的压力测试工具。具有开源免费、框架…

Leetcode—2105. 给植物浇水 II【中等】

2024每日刷题&#xff08;131&#xff09; Leetcode—2105. 给植物浇水 II 实现代码 class Solution { public:int minimumRefill(vector<int>& plants, int capacityA, int capacityB) {int size plants.size();int i 0;int j size - 1;int capA capacityA;in…

【Linux】Linux安装JDK

一、卸载Linux自带的JDK #查询已有的JDK rpm -qa | grep jdk ①将查询到的JDK全部卸载掉 #直接复制一整行的JDK名称 yum -y remove java-1.7.0-openjdk-headless-1.7.0.261-2.6.22.2.el7_8.x86_64 ②卸载完第一个后再次查询 ③继续卸载&#xff0c;卸载完成后再次查询 ④查询…

Flask-大体了解介绍

初识Flask Flask是使用 Python编写的Web微框架。Web框架可以让我们不用关心底层的请求响应处理&#xff0c;更方便高效地编写Web程序。 Flask主要有两个依赖&#xff0c;一个是WSGI&#xff08;Web Server Gateway Interface&#xff0c;Web服务器网关接口&#xff09;工具集…