QT网络调试助手

 1.开发流程

在这里插入图片描述

 2.QTtcp服务器

	1.添加网络访问权限
	 QT += network
	2.创建一个新对象
    server = new QTcpServer(this);
    3.当监听按钮按下后开始监听
void Widget::on_btnListen_clicked()
{
    //2.监听:bool QTcpServer::listen(const QHostAddress &address = QHostAddress::Any, quint16 port = 0)   8888-15000
    //QHostAddress addr("192.168.0.101");
    port = ui->lineEditPort->text().toUInt();
    if(!server->listen(QHostAddress(ui->comboBoxAddr->currentText()),port)){    //自动检测ip地址:QHostAddress::Any
        QMessageBox msgBox;
        msgBox.setWindowTitle("监听失败");
        msgBox.setText("端口号被占用");
        msgBox.exec();
        return;
    }
    ui->btnListen->setEnabled(false);
    ui->btnLineOut->setEnabled(true);
    ui->btnStopListen->setEnabled(true);
    ui->btnSend->setEnabled(true);
    //qDebug() << QHostAddress(ui->comboBoxAddr->currentText());
}
	4.监听到新的newConnection()信号后对新的连接进行处理
	connect(server,SIGNAL(newConnection()),this,SLOT(on_newClient_connect()));
	
void Widget::on_newClient_connect()
{
    //所有的数据操作都是TcpSocket进行
    //bool QTcpServer::hasPendingConnections() const    有新的连接返回True
    if(server->hasPendingConnections()){
        //QTcpSocket *QTcpServer::nextPendingConnection()   返回下个连接来的connect
        QTcpSocket *connection = server->nextPendingConnection(); //获得到的客户端连接信息都在connection里,并将信息也保存在server中
        qDebug() << "client addr: " <<connection->peerAddress().toString() <<",port: " << connection->peerPort();
        ui->textEditRev->insertPlainText("客户端地址:" + connection->peerAddress().toString()+
                                         "\n客户端端口号:" + QString::number(connection->peerPort())+ "\n");

        connect(connection,SIGNAL(readyRead()),this,SLOT(on_readyRead_handler()));

        //断开后信号:void QAbstractSocket::disconnected()
        //connect(connection,SIGNAL(disconnected()),this,SLOT(mdisconnected()));

        //void QAbstractSocket::stateChanged(QAbstractSocket::SocketState socketState)


        connect(connection,SIGNAL(stateChanged(QAbstractSocket::SocketState)),
                this,SLOT(mstateChanged(QAbstractSocket::SocketState)));

        ui->comboBoxChildren->addItem(QString::number(connection->peerPort()));
        ui->comboBoxChildren->setCurrentText(QString::number(connection->peerPort()));
        if(!ui->btnSend->isEnabled()){
            ui->btnSend->setEnabled(true);
        }
    }
}

   1.1 服务端数据读取

	connect(connection,SIGNAL(readyRead()),this,SLOT(on_readyRead_handler())void Widget::on_readyRead_handler()
{
    QTcpSocket *tmpSocket = qobject_cast<QTcpSocket *>(sender());  //获得信号的发出者
    QByteArray RevData = tmpSocket->readAll();
    ui->textEditRev->insertPlainText("客户端:" + RevData + '\n');
    ui->textEditRev->moveCursor(QTextCursor::End);  //将读取光标移动至尾部
    ui->textEditRev->ensureCursorVisible(); //确定光标可见
}

   1.2 服务端发送数据-所有客户端

on_newClient_connect()中
	QTcpSocket *connection = server->nextPendingConnection(); 会将信息也保存在server中,server是全局变量,对server来说,每一个socket都是server的child
	所以通过其父类QObject的FindChildren可以找到所有的socket
}

void Widget::on_btnSend_clicked()
{
    //QTcpSocket *connection = server->nextPendingConnection(); //获得到的客户端连接信息都在connection里,并将信息也保存在server中
    QList<QTcpSocket *> tcpSocketClients = server->findChildren<QTcpSocket *>();
    for(QTcpSocket *tmp : tcpSocketClients){
        //ui->textEditSend->toPlainText().toStdString().c_str()--先将QString转换成标准的c++字符串,再转换成const char*型
        tmp->write(ui->textEditSend->toPlainText().toStdString().c_str());
    }
}

   1.3 服务端自动刷新ip地址

	QNetworkInterface
	QList<QHostAddress> QNetworkInterface::allAddresses()

    //QList<QHostAddress> QNetworkInterface::allAddresses()
    QList<QHostAddress> address = QNetworkInterface::allAddresses();    //获取地址
    for(QHostAddress tmp : address){
        if(tmp.protocol() == QAbstractSocket::IPv4Protocol) //将ipv4的地址刷入combox
            ui->comboBoxAddr->addItem(tmp.toString());
    }

   1.4 服务端检测客户端断开状态

注:每次一断开之后必须清空通道即deleteLater();
	否则server中会一直保留该通道
	1.信号:void QAbstractSocket::disconnected()	
	connect(connection,SIGNAL(disconnected()),this,SLOT(mdisconnected()));
	void Widget::mdisconnected()
{
    QTcpSocket *tmpSocket = qobject_cast<QTcpSocket *>(sender());  //获得信号的发出者
    qDebug() << "client Out";
    ui->textEditRev->insertPlainText("客户端断开! ");
    tmpSocket->deleteLater();

}

	2.信号:void QAbstractSocket::stateChanged(QAbstractSocket::SocketState socketState)
	void Widget::mstateChanged(QAbstractSocket::SocketState socketState)
{
    QTcpSocket *tmpSocket = qobject_cast<QTcpSocket *>(sender());  //获得信号的发出者
    switch(socketState){
    case QAbstractSocket::ClosingState:
        //case QAbstractSocket::UnconnectedState:
        ui->textEditRev->insertPlainText("客户端断开! ");
        tmpSocket->deleteLater();
        break;
    }
}

   1.5 服务端发送数据-指定特定客户端发送数据

	1.因为ComboBox不提供鼠标点击刷新事件,因此需要重写ComboBox的鼠标点击事件和信号
	void MyComboBox::mousePressEvent(QMouseEvent *e)
{
    if(e->button() == Qt::LeftButton){
        emit ComboBox_clicked();
    }
    QComboBox::mousePressEvent(e);
}
	2.将控件提升为MyComboBox,并绑定信号与槽
	connect(ui->comboBoxChildren,&MyComboBox::ComboBox_clicked,this,&Widget::MyComboBox_refresh);
	//刷新ComboBox控件内容---为ComboBox添加接入的端口
	void Widget::MyComboBox_refresh()
{
    ui->comboBoxChildren->clear();
    QList<QTcpSocket *> tcpSocketClients = server->findChildren<QTcpSocket *>();
    for(QTcpSocket *tmp : tcpSocketClients){
        ui->comboBoxChildren->addItem(QString::number(tmp->peerPort()));
    }
    ui->comboBoxChildren->addItem("all");
}
	2.重写发送
void Widget::on_btnSend_clicked()
{
    //QTcpSocket *connection = server->nextPendingConnection(); //获得到的客户端连接信息都在connection里,并将信息也保存在server中
    QList<QTcpSocket *> tcpSocketClients = server->findChildren<QTcpSocket *>();
    if(tcpSocketClients.isEmpty()){
        QMessageBox msg;
        msg.setText("当前无连接");
        msg.exec();
        ui->btnSend->setEnabled(false);
        return ;
    }


    if(ui->comboBoxChildren->currentText() != "all"){
        QString currentname = ui->comboBoxChildren->currentText();
        for(QTcpSocket *tmp :tcpSocketClients){
            if(QString::number(tmp->peerPort()) == currentname){
                tmp->write(ui->textEditSend->toPlainText().toStdString().c_str());
            }

        }
    }else{
        for(QTcpSocket *tmp : tcpSocketClients){
            //ui->textEditSend->toPlainText().toStdString().c_str()--先将QString转换成标准的c++字符串,再转换成const char*型
            tmp->write(ui->textEditSend->toPlainText().toStdString().c_str());
        }
    }
}


   1.6 服务端停止监听和断开

void Widget::on_btnStopListen_clicked()
{
    QList<QTcpSocket *> tcpSocketClients = server->findChildren<QTcpSocket *>();
    for(QTcpSocket *tmp : tcpSocketClients){
        tmp->close();
    }
    server->close();
    ui->btnListen->setEnabled(true);
    ui->btnLineOut->setEnabled(false);
    ui->btnStopListen->setEnabled(false);
}

void Widget::on_btnLineOut_clicked()
{
    on_btnStopListen_clicked();
    delete server;
    this->close();
}

 3.QTtcp客户端

	客户端逻辑相对简单直接上代码:
void Widget::on_pushButtonConnect_clicked()
{
    //void connectToHost(const QHostAddress &address, quint16 port, QIODevice::OpenMode openMode = ReadWrite)
    client->connectToHost(ui->lineEditIp->text(),ui->lineEditPort->text().toUInt());	//连接服务器


    timer = new QTimer(this);
    timer->setSingleShot(1);
    timer->setInterval(5000);
    connect(timer,SIGNAL(timeout()),this,SLOT(onTimerOut()));



    connect(client,SIGNAL(connected()),this,SLOT(onConnected()));

    //void QAbstractSocket::error(QAbstractSocket::SocketError socketError)
    connect(client,SIGNAL(error(QAbstractSocket::SocketError)),this,SLOT(onError(QAbstractSocket::SocketError)));

    this->setEnabled(false);
    timer->start();
}

void Widget::mread_data_from_server()
{
    setInsertColor(Qt::black, "服务器:"+ client->readAll());
}

void Widget::on_btnSend_clicked()
{
    QByteArray sendData = ui->textEditSend->toPlainText().toStdString().c_str();
    client->write(sendData);
    setInsertColor(Qt::red,"客户端:" + sendData);
}

void Widget::on_pushButtonOut_clicked()
{
    client->close();
    ui->textEditRev->append("断开连接\n");
    ui->pushButtonConnect->setEnabled(true);
    ui->lineEditIp->setEnabled(true);
    ui->lineEditPort->setEnabled(true);
    ui->pushButtonOut->setEnabled(false);
    ui->btnSend->setEnabled(false);
}

void Widget::onConnected()
{
    timer->stop();
    this->setEnabled(true);
    ui->textEditRev->insertPlainText("连接成功\n");
    ui->pushButtonConnect->setEnabled(false);
    ui->lineEditIp->setEnabled(false);
    ui->lineEditPort->setEnabled(false);
    ui->pushButtonOut->setEnabled(true);
    ui->btnSend->setEnabled(true);
}

void Widget::onError(QAbstractSocket::SocketError error)
{
    this->setEnabled(true);
    on_pushButtonOut_clicked();
}

void Widget::onTimerOut()
{
    ui->textEditRev->insertPlainText("连接超时!");
    client->abort(); //放弃当前连接
    this->setEnabled(true);


}

void Widget::setInsertColor(Qt::GlobalColor color, QString str)
{
    QTextCursor cursor = ui->textEditRev->textCursor();
    QTextCharFormat format;
    QBrush brush(color);
    format.setForeground(brush);
    cursor.setCharFormat(format);
    cursor.insertText(str+'\n');
    ui->textEditRev->moveCursor(QTextCursor::End);  //将光标移动至尾部
    ui->textEditRev->ensureCursorVisible(); //确定光标可见
}

链接:https://pan.baidu.com/s/1uI_bhvufjcuW1R6CrR9P7g
提取码:3urt
–来自百度网盘超级会员V5的分享

  • 10
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: QT网络调试助手是一款基于QT平台开发网络调试工具。它的主要功能是辅助开发人员进行网络调试工作,能够对HTTP、TCP、UDP、WebSocket等协议进行解析和分析,提供可视化的界面展示,便于开发人员快速定位和解决问题。 QT网络调试助手具有以下几个主要特点: 1. 集成多种协议支持:QT网络调试助手支持HTTP、TCP、UDP、WebSocket等多种协议,能够解析协议包,展示数据信息。通过这些数据信息,可以快速定位和解决网络开发中出现的各种问题。 2. 监听端口支持:QT网络调试助手还支持监听指定端口,能够实时获取网络数据流,方便进行数据分析。同时,它还提供了响应数据修改的功能,可以在不影响源数据的情况下,对数据进行调整和修改。 3. 界面友好:QT网络调试助手提供了直观、友好的界面,包含请求列表、响应列表、WebSocket列表等多种显示模式,以及自定义筛选条件,让开发人员可以更加方便地操作和查看数据信息。 4. 精简实用:QT网络调试助手的设计十分精简实用,针对网络调试的核心需求进行了精心设计,避免了繁琐的操作过程和不必要的功能干扰。 总之,QT网络调试助手是一个功能强大、易于操作、界面友好的网络调试工具,可以帮助开发人员快速发现和解决网络开发中出现的各种问题。 ### 回答2: Qt网络调试助手是一款基于Qt框架开发网络调试工具,它可以帮助开发人员在网络通信过程中对报文进行捕获、分析和调试Qt网络调试助手主要包括以下几个功能: 1. 报文捕获功能:Qt网络调试助手可以捕获网络通信过程中的请求报文和响应报文,并以可视化的方式展示出来。这对于开发人员来说非常重要,因为它可以帮助他们快速找到报文中的问题。 2. 报文分析功能:Qt网络调试助手可以对捕获的报文进行分析,包括解析HTTP协议、分析应用层协议等。开发人员可以通过这个功能更深入地了解网络通信的过程,更快地解决问题。 3. 报文编辑功能:Qt网络调试助手还可以对捕获的报文进行编辑,包括修改请求参数、请求头、响应参数、响应头等。这对于开发人员进行网络调试非常方便。 4. 报文保存功能:Qt网络调试助手还可以将捕获的报文保存到本地文件中,以便于之后的查看和分析。 总体来说,Qt网络调试助手是一款非常实用的网络调试工具,它为开发人员提供了捕获、分析、编辑和保存网络报文的功能,让开发人员更快地找到网络通信中的问题,并解决它们。同时它也是一款开源工具,可以帮助开源社区的发展。 ### 回答3: Qt网络调试助手是一款功能强大的网络调试工具。它能够帮助开发者快速识别和解决网络问题,是一个必备的调试工具。 Qt网络调试助手具有以下主要特点: 1. 支持多个网络协议 Qt网络调试助手支持常见的网络协议,如HTTP/HTTPS、TCP/UDP、WebSocket等。可以轻松地在这些协议之间进行切换,并查看它们的详细信息。 2. 支持数据的查看和编辑 在调试过程中,开发者可以实时查看请求和响应的数据,同时也可以编辑这些数据来模拟各种情况。 3. 支持数据的保存和发送 Qt网络调试助手也支持将数据保存到本地,以便后续分析。同时还可以发送数据到指定的地址,以便测试网络性能和稳定性。 4. 支持用户名和密码的验证 如果需要验证用户名和密码,Qt网络调试助手也可以轻松地完成验证过程。这非常有用,减少了开发人员的负担。 总之,Qt网络调试助手是一款十分实用的网络调试工具。它可以帮助开发人员快速定位和解决网络问题,提高工作效率。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值