QT 实现仿制 网络调试器(未实现连接唯一性) QT5.12.3环境 C++实现

news/2024/11/23 20:03:28/

网络调试助手:


提前准备:在编写代码前,要在.pro工程文件中,添加network模块。


服务端:

代码:

widget.h
#ifndef WIDGET_H
#define WIDGET_H#include <QWidget>
#include <QtWidgets>
#include <QTcpServer> // 监听套接字
#include <QTcpSocket> // 通讯套接字
namespace Ui {
class Widget;
}class Widget : public QWidget
{Q_OBJECTpublic:explicit Widget(QWidget *parent = nullptr);~Widget();private slots:void on_start_button_clicked(); // 启动按钮slotvoid new_connection_slot(); // 连接slotvoid ready_read_slot(); // 可读slotvoid on_send_button_clicked(); // 发送按钮slotprivate:Ui::Widget *ui;QTcpServer *tcp_server; // 服务端QTcpSocket *tcp_socket; // socket
};#endif // WIDGET_H
widget.cpp
#include "widget.h"
#include "ui_widget.h"Widget::Widget(QWidget *parent) :QWidget(parent),ui(new Ui::Widget)
{ui->setupUi(this);this->setWindowTitle("网络调试器服务端"); // 标题// 实例化监听套接字tcp_server = new QTcpServer(this);tcp_socket = nullptr;connect(tcp_server,&QTcpServer::newConnection,this,&Widget::new_connection_slot);
}Widget::~Widget()
{delete ui;
}void Widget::on_start_button_clicked()
{// 监听( bind() + listen() )if(ui->start_button->text() == "启动"){QString ip = ui->ip_edit->text(); // 读取ipQString port = ui->port_edit->text(); // 读取portif(!tcp_server->listen(QHostAddress(ip),port.toUShort())){ui->plainTextEdit->setPlainText("服务端启动失败....");}else{ui->plainTextEdit->setPlainText("服务端启动成功....");ui->start_button->setText("断开"); // 改变按钮文本}}else if(ui->start_button->text() == "断开"){tcp_server->close(); // 关闭ui->plainTextEdit->appendPlainText("服务器断开成功....");ui->start_button->setText("启动"); // 改变按钮文本}
}void Widget::new_connection_slot()
{tcp_socket = tcp_server->nextPendingConnection();QString client_ip = tcp_socket->peerAddress().toString(); // 获取客户端ip(转换成QString)quint16 client_port = tcp_socket->peerPort();ui->plainTextEdit->appendPlainText(QString("客户端 IP: %1  PORT:%2 连接成功").arg(client_ip).arg(client_port));connect(tcp_socket,&QTcpSocket::readyRead,this,&Widget::ready_read_slot);
}void Widget::ready_read_slot()
{QByteArray buf = tcp_socket->readAll(); // 读数据QString s = QString::fromLocal8Bit(buf); // 编码转换ui->plainTextEdit->appendPlainText(QString("服务端发来数据:%1").arg(QString(s))); // 显示
}void Widget::on_send_button_clicked()
{QString buf = ui->send_edit->text(); // 读数据tcp_socket->write(buf.toLocal8Bit()); // 发送数据ui->plainTextEdit->appendPlainText(QString("服务端发送数据:%1").arg(buf)); // 显示}
widget.ui


输出:


客户端:

代码:

widget.h
#ifndef WIDGET_H
#define WIDGET_H#include <QWidget>
#include <QTcpSocket>
namespace Ui {
class Widget;
}class Widget : public QWidget
{Q_OBJECTpublic:explicit Widget(QWidget *parent = nullptr);~Widget();private slots:void on_start_button_clicked(); // 连接按钮slotvoid ready_read_slot(); // 可读slotvoid on_send_button_clicked(); // 发送按钮slotprivate:Ui::Widget *ui;QTcpSocket *tcp_sock; // socket
};#endif // WIDGET_H
widget.cpp
#include "widget.h"
#include "ui_widget.h"Widget::Widget(QWidget *parent) :QWidget(parent),ui(new Ui::Widget)
{ui->setupUi(this);tcp_sock = new QTcpSocket(this);this->setWindowTitle("网络调试器客户端"); // 标题connect(tcp_sock,&QTcpSocket::readyRead,this,&Widget::ready_read_slot);
}Widget::~Widget()
{delete ui;
}void Widget::on_start_button_clicked()
{QString ip = ui->ip_edit->text(); // 获取ipQString port = ui->port_edit->text(); // 获取portif(ui->start_button->text() == "连接"){tcp_sock->connectToHost(ip,port.toUShort()); // 连接if(tcp_sock->waitForConnected()){ui->plainTextEdit->setPlainText("连接服务器成功...");ui->start_button->setText("断开"); // 改变按钮文本}else{ui->plainTextEdit->setPlainText("连接服务器失败...");}}else if(ui->start_button->text() == "断开"){tcp_sock->close(); // 关闭ui->plainTextEdit->appendPlainText("客户端断开成功....");ui->start_button->setText("连接"); // 改变按钮文本}
}void Widget::ready_read_slot(){QByteArray buf = tcp_sock->readAll(); // 读数据QString data = QString::fromLocal8Bit(buf); // 编码转换ui->plainTextEdit->appendPlainText(QString("服务端发来数据 %1").arg(data));
}void Widget::on_send_button_clicked()
{QString buf = ui->send_edit->text(); // 获取数据tcp_sock->write(buf.toLocal8Bit()); // 编码转换ui->plainTextEdit->appendPlainText(QString("服务端发送数据 %1").arg(buf));
}
widget.ui


输出:


测试:

同时打开服务端和客户端

启动服务端并连接客户端

发送文本测试

断开连接


http://www.ppmy.cn/news/1549357.html

相关文章

cocos creator 3.8 一些简单的操作技巧,材质的创建 1

这是一个飞机的3D模型与贴图 导入到cocos中&#xff0c;法线模型文件中已经包含了mesh、material、prefab&#xff0c;也就是模型、材质与预制。界面上创建一个空节点Plane&#xff0c;将模型直接拖入到Plane下。新建材质如图下 Effect属性选择builtin-unlit&#xff0c;不需…

谈谈Mysql的常见基础问题

一.为什么Mysql选择B树作为索引&#xff1f; 索引(Index)是帮助MySQL高效获取数据的数据结构&#xff1b; 但是索引的数据结构有多种&#xff0c;如MySQL的InnoDB存储引擎支持B树索引还有哈希索引(可以理解为简单的HashMap)。 而针对关系型的数据&#xff0c;如果选用哈希索引…

【C++】几个基本容器的模拟实现(string,vector,list,stack,queue,priority_queue)

目录 一.string 二.vector 三.list 四.stack 五.queue 六.priority_queue 一.string #pragma oncenamespace hebre {class string{public:typedef char* iterator;typedef const char* const_iterator;//Member functionsstring():_str(new char[1]{\0}),_size(0),_capac…

Jetpack Compose 如何适配不同分辨率设备

文章目录 前言1、获取屏幕信息2、使用响应式布局适配屏幕2.1 动态调整布局 3、 精准适配特定分辨率4、多分辨率预览5、针对屏幕密度的适配6、 实战&#xff1a;流式网格布局适配(例子)总结 前言 在移动开发中&#xff0c;适配不同分辨率和屏幕大小是不可避免的挑战。Jetpack C…

解决BUG: Since 17.0, the “attrs“ and “states“ attributes are no longer used.

从Odoo 17.0开始&#xff0c;attrs和states属性不再使用&#xff0c;取而代之的是使用depends和domain属性来控制字段的可见性和其他行为。如果您想要在选择国家之后继续选择州&#xff0c;并且希望在选择了国家之后才显示州字段&#xff0c;您可以使用depends属性来实现这一点…

C++语言之模版与类型转换

模版 C的泛型编程 可以将数据类型作为参数进行传递 关键字: C模版的语法使用"<>"来表示泛型类型,并使用关键字template来定义和声明模版 分类: 模版函数 模版类 模版函数 语法: template<class 假设的类型1,class 假设的类型2,.......> 或 template<t…

aws建立多区域只读库

文章目录 一、Aurora数据库创建多区域注意项&#xff1a;二、aws-rds多区域只读库建立三、cli 创建实例: 一、Aurora数据库创建多区域注意项&#xff1a; aurora数据库 开启跨区域必须是主库不低于db.r5.large规格, 目标区域規格使用db.r5.large&#xff0c;使用低于此规格的将…

8年测试工程师 —— 如何使用Playwright优化测试性能!

优化Playwright测试性能是确保自动化测试快速、可靠地执行的重要环节。以下是一些具体的策略和技术&#xff0c;可以帮助你提高Playwright测试的性能&#xff1a; 1. 减少不必要的页面加载 避免重定向&#xff1a;确保测试URL直接指向最终页面&#xff0c;避免不必要的重定向。…