diff --git a/nettool/api/app.cpp b/nettool/api/app.cpp index e32e911..64f82af 100644 --- a/nettool/api/app.cpp +++ b/nettool/api/app.cpp @@ -21,9 +21,19 @@ bool App::HexReceiveTcpServer = false; bool App::AsciiTcpServer = false; bool App::DebugTcpServer = false; bool App::AutoSendTcpServer = false; -bool App::SelectAllTcpServer = false; int App::IntervalTcpServer = 1000; +QString App::TcpListenIP = "127.0.0.1"; int App::TcpListenPort = 6000; +bool App::SelectAllTcpServer = false; + +bool App::HexSendUdpClient = false; +bool App::HexReceiveUdpClient = false; +bool App::AsciiUdpClient = false; +bool App::DebugUdpClient = false; +bool App::AutoSendUdpClient = false; +int App::IntervalUdpClient = 1000; +QString App::UdpServerIP = "127.0.0.1"; +int App::UdpServerPort = 6000; bool App::HexSendUdpServer = false; bool App::HexReceiveUdpServer = false; @@ -31,9 +41,9 @@ bool App::AsciiUdpServer = false; bool App::DebugUdpServer = false; bool App::AutoSendUdpServer = false; int App::IntervalUdpServer = 1000; +QString App::UdpListenIP = "127.0.0.1"; int App::UdpListenPort = 6000; -QString App::UdpServerIP = "127.0.0.1"; -int App::UdpServerPort = 6000; +bool App::SelectAllUdpServer = false; void App::readConfig() { @@ -63,10 +73,22 @@ void App::readConfig() App::HexReceiveTcpServer = set.value("HexReceiveTcpServer").toBool(); App::AsciiTcpServer = set.value("AsciiTcpServer").toBool(); App::DebugTcpServer = set.value("DebugTcpServer").toBool(); - App::AutoSendTcpServer = set.value("AutoSendTcpServer").toBool(); - App::SelectAllTcpServer = set.value("SelectAllTcpServer").toBool(); - App::IntervalTcpServer = set.value("IntervalTcpServer").toInt(); + App::AutoSendTcpServer = set.value("AutoSendTcpServer").toBool(); + App::IntervalTcpServer = set.value("IntervalTcpServer").toInt(); + App::TcpListenIP = set.value("TcpListenIP").toString(); App::TcpListenPort = set.value("TcpListenPort").toInt(); + App::SelectAllTcpServer = set.value("SelectAllTcpServer").toBool(); + set.endGroup(); + + set.beginGroup("UdpClientConfig"); + App::HexSendUdpClient = set.value("HexSendUdpClient").toBool(); + App::HexReceiveUdpClient = set.value("HexReceiveUdpClient").toBool(); + App::AsciiUdpClient = set.value("AsciiUdpClient").toBool(); + App::DebugUdpClient = set.value("DebugUdpClient").toBool(); + App::AutoSendUdpClient = set.value("AutoSendUdpClient").toBool(); + App::IntervalUdpClient = set.value("IntervalUdpClient").toInt(); + App::UdpServerIP = set.value("UdpServerIP").toString(); + App::UdpServerPort = set.value("UdpServerPort").toInt(); set.endGroup(); set.beginGroup("UdpServerConfig"); @@ -75,10 +97,10 @@ void App::readConfig() App::AsciiUdpServer = set.value("AsciiUdpServer").toBool(); App::DebugUdpServer = set.value("DebugUdpServer").toBool(); App::AutoSendUdpServer = set.value("AutoSendUdpServer").toBool(); - App::IntervalUdpServer = set.value("IntervalUdpServer").toInt(); - App::UdpServerIP = set.value("UdpServerIP").toString(); - App::UdpServerPort = set.value("UdpServerPort").toInt(); + App::IntervalUdpServer = set.value("IntervalUdpServer").toInt(); + App::UdpListenIP = set.value("UdpListenIP").toString(); App::UdpListenPort = set.value("UdpListenPort").toInt(); + App::SelectAllUdpServer = set.value("SelectAllUdpServer").toBool(); set.endGroup(); } @@ -104,10 +126,21 @@ void App::writeConfig() set.setValue("HexSendTcpServer", App::HexSendTcpServer); set.setValue("HexReceiveTcpServer", App::HexReceiveTcpServer); set.setValue("DebugTcpServer", App::DebugTcpServer); - set.setValue("AutoSendTcpServer", App::AutoSendTcpServer); - set.setValue("SelectAllTcpServer", App::SelectAllTcpServer); - set.setValue("IntervalTcpServer", App::IntervalTcpServer); + set.setValue("AutoSendTcpServer", App::AutoSendTcpServer); + set.setValue("IntervalTcpServer", App::IntervalTcpServer); + set.setValue("TcpListenIP", App::TcpListenIP); set.setValue("TcpListenPort", App::TcpListenPort); + set.setValue("SelectAllTcpServer", App::SelectAllTcpServer); + set.endGroup(); + + set.beginGroup("UdpClientConfig"); + set.setValue("HexSendUdpClient", App::HexSendUdpClient); + set.setValue("HexReceiveUdpClient", App::HexReceiveUdpClient); + set.setValue("DebugUdpClient", App::DebugUdpClient); + set.setValue("AutoSendUdpClient", App::AutoSendUdpClient); + set.setValue("IntervalUdpClient", App::IntervalUdpClient); + set.setValue("UdpServerIP", App::UdpServerIP); + set.setValue("UdpServerPort", App::UdpServerPort); set.endGroup(); set.beginGroup("UdpServerConfig"); @@ -115,11 +148,11 @@ void App::writeConfig() set.setValue("HexReceiveUdpServer", App::HexReceiveUdpServer); set.setValue("DebugUdpServer", App::DebugUdpServer); set.setValue("AutoSendUdpServer", App::AutoSendUdpServer); - set.setValue("IntervalUdpServer", App::IntervalUdpServer); - set.setValue("UdpServerIP", App::UdpServerIP); - set.setValue("UdpServerPort", App::UdpServerPort); + set.setValue("IntervalUdpServer", App::IntervalUdpServer); + set.setValue("UdpListenIP", App::UdpListenIP); set.setValue("UdpListenPort", App::UdpListenPort); - set.endGroup(); + set.setValue("SelectAllUdpServer", App::SelectAllUdpServer); + set.endGroup(); } void App::newConfig() diff --git a/nettool/api/app.h b/nettool/api/app.h index dd91669..1094a6c 100644 --- a/nettool/api/app.h +++ b/nettool/api/app.h @@ -28,9 +28,20 @@ public: static bool AsciiTcpServer; //ASCII模式 static bool DebugTcpServer; //启用数据调试 static bool AutoSendTcpServer; //自动发送数据 - static bool SelectAllTcpServer; //选中所有 - static int IntervalTcpServer; //发送数据间隔 + static int IntervalTcpServer; //发送数据间隔 + static QString TcpListenIP; //监听地址 static int TcpListenPort; //监听端口 + static bool SelectAllTcpServer; //选中所有 + + //UDP客户端配置参数 + static bool HexSendUdpClient; //16进制发送 + static bool HexReceiveUdpClient; //16进制接收 + static bool AsciiUdpClient; //ASCII模式 + static bool DebugUdpClient; //启用数据调试 + static bool AutoSendUdpClient; //自动发送数据 + static int IntervalUdpClient; //发送数据间隔 + static QString UdpServerIP; //服务器IP + static int UdpServerPort; //服务器端口 //UDP服务器配置参数 static bool HexSendUdpServer; //16进制发送 @@ -38,10 +49,10 @@ public: static bool AsciiUdpServer; //ASCII模式 static bool DebugUdpServer; //启用数据调试 static bool AutoSendUdpServer; //自动发送数据 - static int IntervalUdpServer; //发送数据间隔 - static QString UdpServerIP; //服务器IP - static int UdpServerPort; //服务器端口 + static int IntervalUdpServer; //发送数据间隔 + static QString UdpListenIP; //监听地址 static int UdpListenPort; //监听端口 + static bool SelectAllUdpServer; //选中所有 //读写配置参数及其他操作 static void readConfig(); //读取配置参数 diff --git a/nettool/api/quiwidget.cpp b/nettool/api/quiwidget.cpp index 3153671..095955c 100644 --- a/nettool/api/quiwidget.cpp +++ b/nettool/api/quiwidget.cpp @@ -17,7 +17,7 @@ QUIWidget::QUIWidget(QWidget *parent) : QDialog(parent) } QUIWidget::~QUIWidget() -{ +{ } bool QUIWidget::eventFilter(QObject *watched, QEvent *event) @@ -369,7 +369,7 @@ void QUIWidget::setIconMain(const QChar &str, quint32 size) void QUIWidget::setPixmap(QUIWidget::Widget widget, const QString &file, const QSize &size) { //按照宽高比自动缩放 - QPixmap pix = QPixmap(file); + QPixmap pix = QPixmap(file); pix = pix.scaled(size, Qt::KeepAspectRatio); if (widget == QUIWidget::Lab_Ico) { this->labIco->setPixmap(pix); @@ -454,12 +454,12 @@ void QUIWidget::setExitAll(bool exitAll) void QUIWidget::setMainWidget(QWidget *mainWidget) { //一个QUI窗体对象只能设置一个主窗体 - if (this->mainWidget == 0) { + if (this->mainWidget == 0) { //将子窗体添加到布局 this->widget->layout()->addWidget(mainWidget); //自动设置大小 resize(mainWidget->width(), mainWidget->height() + this->widgetTitle->height()); - this->mainWidget = mainWidget; + this->mainWidget = mainWidget; } } @@ -917,6 +917,7 @@ void QUITipBox::initControl() sizePolicy1.setVerticalStretch(0); sizePolicy1.setHeightForWidth(labTime->sizePolicy().hasHeightForWidth()); labTime->setSizePolicy(sizePolicy1); + labTime->setAlignment(Qt::AlignCenter); horizontalLayout2->addWidget(labTime); widgetMenu = new QWidget(widgetTitle); @@ -943,6 +944,7 @@ void QUITipBox::initControl() btnMenu_Close->setFocusPolicy(Qt::NoFocus); btnMenu_Close->setFlat(true); + widgetTitle->setMinimumHeight(TitleMinSize); horizontalLayout->addWidget(btnMenu_Close); horizontalLayout2->addWidget(widgetMenu); verticalLayout->addWidget(widgetTitle); @@ -1039,7 +1041,7 @@ void QUITipBox::setTip(const QString &title, const QString &tip, bool fullScreen this->labInfo->setAlignment(center ? Qt::AlignCenter : Qt::AlignLeft); this->setWindowTitle(this->labTitle->text()); - QRect rect = fullScreen ? qApp->desktop()->availableGeometry() : qApp->desktop()->geometry(); + QRect rect = fullScreen ? qApp->desktop()->geometry() : qApp->desktop()->availableGeometry(); int width = rect.width(); int height = rect.height(); int x = width - this->width(); diff --git a/nettool/api/tcpserver.cpp b/nettool/api/tcpserver.cpp index 9dd7490..1eb3aac 100644 --- a/nettool/api/tcpserver.cpp +++ b/nettool/api/tcpserver.cpp @@ -89,6 +89,7 @@ void TcpServer::incomingConnection(int handle) connect(client, SIGNAL(receiveData(QString, int, QString)), this, SIGNAL(receiveData(QString, int, QString))); QString ip = client->peerAddress().toString(); + ip = ip.replace("::ffff:", ""); int port = client->peerPort(); client->setIP(ip); client->setPort(port); @@ -113,12 +114,7 @@ void TcpServer::disconnected() bool TcpServer::start() { -#if (QT_VERSION > QT_VERSION_CHECK(5,0,0)) - bool ok = listen(QHostAddress::AnyIPv4, App::TcpListenPort); -#else - bool ok = listen(QHostAddress::Any, App::TcpListenPort); -#endif - + bool ok = listen(QHostAddress(App::TcpListenIP), App::TcpListenPort); return ok; } diff --git a/nettool/form/form.pri b/nettool/form/form.pri index 1dbadcf..b5f01bb 100644 --- a/nettool/form/form.pri +++ b/nettool/form/form.pri @@ -1,17 +1,20 @@ -FORMS += \ +FORMS += \ $$PWD/frmmain.ui \ $$PWD/frmtcpclient.ui \ $$PWD/frmtcpserver.ui \ + $$PWD/frmudpclient.ui \ $$PWD/frmudpserver.ui -HEADERS += \ +HEADERS += \ $$PWD/frmmain.h \ $$PWD/frmtcpclient.h \ $$PWD/frmtcpserver.h \ + $$PWD/frmudpclient.h \ $$PWD/frmudpserver.h -SOURCES += \ +SOURCES += \ $$PWD/frmmain.cpp \ $$PWD/frmtcpclient.cpp \ $$PWD/frmtcpserver.cpp \ + $$PWD/frmudpclient.cpp \ $$PWD/frmudpserver.cpp diff --git a/nettool/form/frmmain.ui b/nettool/form/frmmain.ui index 3df2b09..8da74e2 100644 --- a/nettool/form/frmmain.ui +++ b/nettool/form/frmmain.ui @@ -47,6 +47,11 @@ TCP服务器 + + + UDP客户端 + + UDP服务器 @@ -75,6 +80,12 @@
frmudpserver.h
1 + + frmUdpClient + QWidget +
frmudpclient.h
+ 1 +
diff --git a/nettool/form/frmtcpclient.cpp b/nettool/form/frmtcpclient.cpp index b9c3d5c..a81cd65 100644 --- a/nettool/form/frmtcpclient.cpp +++ b/nettool/form/frmtcpclient.cpp @@ -6,7 +6,7 @@ frmTcpClient::frmTcpClient(QWidget *parent) : QWidget(parent), ui(new Ui::frmTcp { ui->setupUi(this); this->initForm(); - this->initConfig(); + this->initConfig(); } frmTcpClient::~frmTcpClient() @@ -56,8 +56,7 @@ void frmTcpClient::initConfig() ui->txtServerPort->setText(QString::number(App::TcpServerPort)); connect(ui->txtServerPort, SIGNAL(textChanged(QString)), this, SLOT(saveConfig())); - timer->setInterval(App::IntervalTcpClient); - App::AutoSendTcpClient ? timer->start() : timer->stop(); + this->changeTimer(); } void frmTcpClient::saveConfig() @@ -72,8 +71,21 @@ void frmTcpClient::saveConfig() App::TcpServerPort = ui->txtServerPort->text().trimmed().toInt(); App::writeConfig(); + this->changeTimer(); +} + +void frmTcpClient::changeTimer() +{ timer->setInterval(App::IntervalTcpClient); - App::AutoSendTcpClient ? timer->start() : timer->stop(); + if (App::AutoSendTcpClient) { + if (!timer->isActive()) { + timer->start(); + } + } else { + if (timer->isActive()) { + timer->stop(); + } + } } void frmTcpClient::append(int type, const QString &data, bool clear) diff --git a/nettool/form/frmtcpclient.h b/nettool/form/frmtcpclient.h index fa66b2e..c8b5fec 100644 --- a/nettool/form/frmtcpclient.h +++ b/nettool/form/frmtcpclient.h @@ -27,6 +27,7 @@ private slots: void initForm(); void initConfig(); void saveConfig(); + void changeTimer(); void append(int type, const QString &data, bool clear = false); void connected(); diff --git a/nettool/form/frmtcpclient.ui b/nettool/form/frmtcpclient.ui index 13e2bfa..a54a6a6 100644 --- a/nettool/form/frmtcpclient.ui +++ b/nettool/form/frmtcpclient.ui @@ -102,7 +102,7 @@ - 服务器IP地址 + 服务器地址 diff --git a/nettool/form/frmtcpserver.cpp b/nettool/form/frmtcpserver.cpp index 1d98426..e40d828 100644 --- a/nettool/form/frmtcpserver.cpp +++ b/nettool/form/frmtcpserver.cpp @@ -6,6 +6,7 @@ frmTcpServer::frmTcpServer(QWidget *parent) : QWidget(parent), ui(new Ui::frmTcp { ui->setupUi(this); this->initForm(); + this->initIP(); this->initConfig(); } @@ -31,6 +32,38 @@ void frmTcpServer::initForm() QUIHelper::setLabStyle(ui->labCount, 3); } +void frmTcpServer::initIP() +{ + //获取本机所有IP + QStringList ips; + QList netInterfaces = QNetworkInterface::allInterfaces(); + foreach(const QNetworkInterface &netInterface, netInterfaces) { + //移除虚拟机和抓包工具的虚拟网卡 + QString humanReadableName = netInterface.humanReadableName().toLower(); + if(humanReadableName.startsWith("vmware network adapter") || humanReadableName.startsWith("npcap loopback adapter")) { + continue; + } + + //过滤当前网络接口 + bool flag = (netInterface.flags() == (QNetworkInterface::IsUp | QNetworkInterface::IsRunning | QNetworkInterface::CanBroadcast | QNetworkInterface::CanMulticast)); + if(flag) { + QList addrs = netInterface.addressEntries(); + foreach(QNetworkAddressEntry addr, addrs) { + //只取出IPV4的地址 + if(addr.ip().protocol() == QAbstractSocket::IPv4Protocol) { + QString ip4 = addr.ip().toString(); + if(ip4 != "127.0.0.1") { + ips.append(ip4); + } + } + } + } + } + + ui->cboxListenIP->addItems(ips); + ui->cboxListenIP->addItem("127.0.0.1"); +} + void frmTcpServer::initConfig() { ui->ckHexSend->setChecked(App::HexSendTcpServer); @@ -46,19 +79,21 @@ void frmTcpServer::initConfig() connect(ui->ckDebug, SIGNAL(stateChanged(int)), this, SLOT(saveConfig())); ui->ckAutoSend->setChecked(App::AutoSendTcpServer); - connect(ui->ckAutoSend, SIGNAL(stateChanged(int)), this, SLOT(saveConfig())); - - ui->ckSelectAll->setChecked(App::SelectAllTcpServer); - connect(ui->ckSelectAll, SIGNAL(stateChanged(int)), this, SLOT(saveConfig())); + connect(ui->ckAutoSend, SIGNAL(stateChanged(int)), this, SLOT(saveConfig())); ui->cboxInterval->setCurrentIndex(ui->cboxInterval->findText(QString::number(App::IntervalTcpServer))); connect(ui->cboxInterval, SIGNAL(currentIndexChanged(int)), this, SLOT(saveConfig())); + ui->cboxListenIP->setCurrentIndex(ui->cboxListenIP->findText(App::TcpListenIP)); + connect(ui->cboxListenIP, SIGNAL(currentIndexChanged(int)), this, SLOT(saveConfig())); + ui->txtListenPort->setText(QString::number(App::TcpListenPort)); connect(ui->txtListenPort, SIGNAL(textChanged(QString)), this, SLOT(saveConfig())); - timer->setInterval(App::IntervalTcpServer); - App::AutoSendTcpServer ? timer->start() : timer->stop(); + ui->ckSelectAll->setChecked(App::SelectAllTcpServer); + connect(ui->ckSelectAll, SIGNAL(stateChanged(int)), this, SLOT(saveConfig())); + + this->changeTimer(); } void frmTcpServer::saveConfig() @@ -67,14 +102,28 @@ void frmTcpServer::saveConfig() App::HexReceiveTcpServer = ui->ckHexReceive->isChecked(); App::AsciiTcpServer = ui->ckAscii->isChecked(); App::DebugTcpServer = ui->ckDebug->isChecked(); - App::AutoSendTcpServer = ui->ckAutoSend->isChecked(); - App::SelectAllTcpServer = ui->ckSelectAll->isChecked(); + App::AutoSendTcpServer = ui->ckAutoSend->isChecked(); App::IntervalTcpServer = ui->cboxInterval->currentText().toInt(); + App::TcpListenIP = ui->cboxListenIP->currentText(); App::TcpListenPort = ui->txtListenPort->text().trimmed().toInt(); + App::SelectAllTcpServer = ui->ckSelectAll->isChecked(); App::writeConfig(); + this->changeTimer(); +} + +void frmTcpServer::changeTimer() +{ timer->setInterval(App::IntervalTcpServer); - App::AutoSendTcpServer ? timer->start() : timer->stop(); + if (App::AutoSendTcpServer) { + if (!timer->isActive()) { + timer->start(); + } + } else { + if (timer->isActive()) { + timer->stop(); + } + } } void frmTcpServer::append(int type, const QString &data, bool clear) @@ -117,25 +166,11 @@ void frmTcpServer::append(int type, const QString &data, bool clear) currentCount++; } -void frmTcpServer::sendData(const QString &data) -{ - if (ui->ckSelectAll->isChecked()) { - tcpServer->writeData(data); - } else { - int row = ui->listWidget->currentRow(); - if (row >= 0) { - QString str = ui->listWidget->item(row)->text(); - QStringList list = str.split(":"); - tcpServer->writeData(list.at(0), list.at(1).toInt(), data); - } - } -} - void frmTcpServer::clientConnected(const QString &ip, int port) { QString str = QString("%1:%2").arg(ip).arg(port); ui->listWidget->addItem(str); - ui->labCount->setText(QString("共 %1 个连接").arg(ui->listWidget->count())); + ui->labCount->setText(QString("共 %1 个客户端").arg(ui->listWidget->count())); } void frmTcpServer::clientDisconnected(const QString &ip, int port) @@ -150,7 +185,7 @@ void frmTcpServer::clientDisconnected(const QString &ip, int port) } delete ui->listWidget->takeItem(row); - ui->labCount->setText(QString("共 %1 个连接").arg(ui->listWidget->count())); + ui->labCount->setText(QString("共 %1 个客户端").arg(ui->listWidget->count())); } void frmTcpServer::sendData(const QString &ip, int port, const QString &data) @@ -214,7 +249,16 @@ void frmTcpServer::on_btnSend_clicked() return; } - sendData(data); + if (ui->ckSelectAll->isChecked()) { + tcpServer->writeData(data); + } else { + int row = ui->listWidget->currentRow(); + if (row >= 0) { + QString str = ui->listWidget->item(row)->text(); + QStringList list = str.split(":"); + tcpServer->writeData(list.at(0), list.at(1).toInt(), data); + } + } } void frmTcpServer::on_btnClose_clicked() diff --git a/nettool/form/frmtcpserver.h b/nettool/form/frmtcpserver.h index 7a12a53..e43a544 100644 --- a/nettool/form/frmtcpserver.h +++ b/nettool/form/frmtcpserver.h @@ -25,13 +25,12 @@ private: private slots: void initForm(); + void initIP(); void initConfig(); void saveConfig(); + void changeTimer(); void append(int type, const QString &data, bool clear = false); -private slots: - void sendData(const QString &data); - void clientConnected(const QString &ip, int port); void clientDisconnected(const QString &ip, int port); void sendData(const QString &ip, int port, const QString &data); diff --git a/nettool/form/frmtcpserver.ui b/nettool/form/frmtcpserver.ui index 958e7a8..beb7d7a 100644 --- a/nettool/form/frmtcpserver.ui +++ b/nettool/form/frmtcpserver.ui @@ -99,6 +99,16 @@ + + + + 监听地址 + + + + + + @@ -152,7 +162,7 @@ QFrame::Sunken - 共 0 个连接 + 共 0 个客户端 Qt::AlignCenter @@ -165,7 +175,7 @@ - 对所有已连接客户端 + 对所有客户端发送 @@ -224,6 +234,26 @@
+ + txtMain + ckHexReceive + ckHexSend + ckAscii + ckShow + ckDebug + ckAutoSend + cboxInterval + cboxListenIP + txtListenPort + btnListen + btnSave + btnClear + btnClose + listWidget + ckSelectAll + cboxData + btnSend + diff --git a/nettool/form/frmudpclient.cpp b/nettool/form/frmudpclient.cpp new file mode 100644 index 0000000..66dc84c --- /dev/null +++ b/nettool/form/frmudpclient.cpp @@ -0,0 +1,214 @@ +#include "frmudpclient.h" +#include "ui_frmudpclient.h" +#include "quiwidget.h" + +frmUdpClient::frmUdpClient(QWidget *parent) : QWidget(parent), ui(new Ui::frmUdpClient) +{ + ui->setupUi(this); + this->initForm(); + this->initConfig(); +} + +frmUdpClient::~frmUdpClient() +{ + delete ui; +} + +void frmUdpClient::initForm() +{ + udpSocket = new QUdpSocket(this); + connect(udpSocket, SIGNAL(readyRead()), this, SLOT(readData())); + + timer = new QTimer(this); + connect(timer, SIGNAL(timeout()), this, SLOT(on_btnSend_clicked())); + + ui->cboxInterval->addItems(App::Intervals); + ui->cboxData->addItems(App::Datas); +} + +void frmUdpClient::initConfig() +{ + ui->ckHexSend->setChecked(App::HexSendUdpClient); + connect(ui->ckHexSend, SIGNAL(stateChanged(int)), this, SLOT(saveConfig())); + + ui->ckHexReceive->setChecked(App::HexReceiveUdpClient); + connect(ui->ckHexReceive, SIGNAL(stateChanged(int)), this, SLOT(saveConfig())); + + ui->ckAscii->setChecked(App::AsciiUdpClient); + connect(ui->ckAscii, SIGNAL(stateChanged(int)), this, SLOT(saveConfig())); + + ui->ckDebug->setChecked(App::DebugUdpClient); + connect(ui->ckDebug, SIGNAL(stateChanged(int)), this, SLOT(saveConfig())); + + ui->ckAutoSend->setChecked(App::AutoSendUdpClient); + connect(ui->ckAutoSend, SIGNAL(stateChanged(int)), this, SLOT(saveConfig())); + + ui->cboxInterval->setCurrentIndex(ui->cboxInterval->findText(QString::number(App::IntervalUdpClient))); + connect(ui->cboxInterval, SIGNAL(currentIndexChanged(int)), this, SLOT(saveConfig())); + + ui->txtServerIP->setText(App::UdpServerIP); + connect(ui->txtServerIP, SIGNAL(textChanged(QString)), this, SLOT(saveConfig())); + + ui->txtServerPort->setText(QString::number(App::UdpServerPort)); + connect(ui->txtServerPort, SIGNAL(textChanged(QString)), this, SLOT(saveConfig())); + + this->changeTimer(); +} + +void frmUdpClient::saveConfig() +{ + App::HexSendUdpClient = ui->ckHexSend->isChecked(); + App::HexReceiveUdpClient = ui->ckHexReceive->isChecked(); + App::AsciiUdpClient = ui->ckAscii->isChecked(); + App::DebugUdpClient = ui->ckDebug->isChecked(); + App::AutoSendUdpClient = ui->ckAutoSend->isChecked(); + App::IntervalUdpClient = ui->cboxInterval->currentText().toInt(); + App::UdpServerIP = ui->txtServerIP->text().trimmed(); + App::UdpServerPort = ui->txtServerPort->text().trimmed().toInt(); + App::writeConfig(); + + this->changeTimer(); +} + +void frmUdpClient::changeTimer() +{ + timer->setInterval(App::IntervalUdpClient); + if (App::AutoSendUdpClient) { + if (!timer->isActive()) { + timer->start(); + } + } else { + if (timer->isActive()) { + timer->stop(); + } + } +} + +void frmUdpClient::append(int type, const QString &data, bool clear) +{ + static int currentCount = 0; + static int maxCount = 100; + + if (clear) { + ui->txtMain->clear(); + currentCount = 0; + return; + } + + if (currentCount >= maxCount) { + ui->txtMain->clear(); + currentCount = 0; + } + + if (ui->ckShow->isChecked()) { + return; + } + + //过滤回车换行符 + QString strData = data; + strData = strData.replace("\r", ""); + strData = strData.replace("\n", ""); + + //不同类型不同颜色显示 + QString strType; + if (type == 0) { + strType = "发送"; + ui->txtMain->setTextColor(QColor("darkgreen")); + } else { + strType = "接收"; + ui->txtMain->setTextColor(QColor("red")); + } + + strData = QString("时间[%1] %2: %3").arg(TIMEMS).arg(strType).arg(strData); + ui->txtMain->append(strData); + currentCount++; +} + +void frmUdpClient::readData() +{ + QHostAddress host; + quint16 port; + QByteArray data; + QString buffer; + + while (udpSocket->hasPendingDatagrams()) { + data.resize(udpSocket->pendingDatagramSize()); + udpSocket->readDatagram(data.data(), data.size(), &host, &port); + + if (App::HexReceiveUdpClient) { + buffer = QUIHelper::byteArrayToHexStr(data); + } else if (App::AsciiUdpClient) { + buffer = QUIHelper::byteArrayToAsciiStr(data); + } else { + buffer = QString(data); + } + + QString ip = host.toString(); + ip = ip.replace("::ffff:", ""); + if (ip.isEmpty()) { + continue; + } + + QString str = QString("[%1:%2] %3").arg(ip).arg(port).arg(buffer); + append(1, str); + + if (App::DebugUdpClient) { + int count = App::Keys.count(); + for (int i = 0; i < count; i++) { + if (App::Keys.at(i) == buffer) { + sendData(ip, port, App::Values.at(i)); + break; + } + } + } + } +} + +void frmUdpClient::sendData(const QString &ip, int port, const QString &data) +{ + QByteArray buffer; + if (App::HexSendUdpClient) { + buffer = QUIHelper::hexStrToByteArray(data); + } else if (App::AsciiUdpClient) { + buffer = QUIHelper::asciiStrToByteArray(data); + } else { + buffer = data.toLatin1(); + } + + udpSocket->writeDatagram(buffer, QHostAddress(ip), port); + + QString str = QString("[%1:%2] %3").arg(ip).arg(port).arg(data); + append(0, str); +} + +void frmUdpClient::on_btnSave_clicked() +{ + QString data = ui->txtMain->toPlainText(); + if (data.length() <= 0) { + return; + } + + QString fileName = QString("%1/%2.txt").arg(QUIHelper::appPath()).arg(STRDATETIME); + QFile file(fileName); + if (file.open(QFile::WriteOnly | QFile::Text)) { + file.write(data.toUtf8()); + file.close(); + } + + on_btnClear_clicked(); +} + +void frmUdpClient::on_btnClear_clicked() +{ + append(0, "", true); +} + +void frmUdpClient::on_btnSend_clicked() +{ + QString data = ui->cboxData->currentText(); + if (data.length() <= 0) { + return; + } + + sendData(App::UdpServerIP, App::UdpServerPort, data); +} diff --git a/nettool/form/frmudpclient.h b/nettool/form/frmudpclient.h new file mode 100644 index 0000000..8f468fd --- /dev/null +++ b/nettool/form/frmudpclient.h @@ -0,0 +1,41 @@ +#ifndef FRMUDPCLIENT_H +#define FRMUDPCLIENT_H + +#include +#include + +namespace Ui { +class frmUdpClient; +} + +class frmUdpClient : public QWidget +{ + Q_OBJECT + +public: + explicit frmUdpClient(QWidget *parent = 0); + ~frmUdpClient(); + +private: + Ui::frmUdpClient *ui; + + QUdpSocket *udpSocket; + QTimer *timer; + +private slots: + void initForm(); + void initConfig(); + void saveConfig(); + void changeTimer(); + void append(int type, const QString &data, bool clear = false); + + void readData(); + void sendData(const QString &ip, int port, const QString &data); + +private slots: + void on_btnSave_clicked(); + void on_btnClear_clicked(); + void on_btnSend_clicked(); +}; + +#endif // FRMUDPCLIENT_H diff --git a/nettool/form/frmudpclient.ui b/nettool/form/frmudpclient.ui new file mode 100644 index 0000000..fd04640 --- /dev/null +++ b/nettool/form/frmudpclient.ui @@ -0,0 +1,194 @@ + + + frmUdpClient + + + + 0 + 0 + 800 + 600 + + + + Form + + + + + + true + + + + + + + + 170 + 0 + + + + + 170 + 16777215 + + + + QFrame::Box + + + QFrame::Sunken + + + + + + 16进制接收 + + + + + + + 16进制发送 + + + + + + + Ascii控制字符 + + + + + + + 暂停显示 + + + + + + + 模拟设备 + + + + + + + 定时发送 + + + + + + + + + + 远程地址 + + + + + + + + + + 远程端口 + + + + + + + + + + 保存 + + + + + + + 清空 + + + + + + + Qt::Vertical + + + + 20 + 40 + + + + + + + + + + + + 0 + + + 0 + + + 0 + + + 0 + + + + + + 0 + 0 + + + + true + + + + + + + + 80 + 0 + + + + + 80 + 16777215 + + + + 发送 + + + + + + + + + + + diff --git a/nettool/form/frmudpserver.cpp b/nettool/form/frmudpserver.cpp index 3c9f30d..2787a31 100644 --- a/nettool/form/frmudpserver.cpp +++ b/nettool/form/frmudpserver.cpp @@ -6,6 +6,7 @@ frmUdpServer::frmUdpServer(QWidget *parent) : QWidget(parent), ui(new Ui::frmUdp { ui->setupUi(this); this->initForm(); + this->initIP(); this->initConfig(); } @@ -24,6 +25,39 @@ void frmUdpServer::initForm() ui->cboxInterval->addItems(App::Intervals); ui->cboxData->addItems(App::Datas); + QUIHelper::setLabStyle(ui->labCount, 3); +} + +void frmUdpServer::initIP() +{ + //获取本机所有IP + QStringList ips; + QList netInterfaces = QNetworkInterface::allInterfaces(); + foreach(const QNetworkInterface &netInterface, netInterfaces) { + //移除虚拟机和抓包工具的虚拟网卡 + QString humanReadableName = netInterface.humanReadableName().toLower(); + if(humanReadableName.startsWith("vmware network adapter") || humanReadableName.startsWith("npcap loopback adapter")) { + continue; + } + + //过滤当前网络接口 + bool flag = (netInterface.flags() == (QNetworkInterface::IsUp | QNetworkInterface::IsRunning | QNetworkInterface::CanBroadcast | QNetworkInterface::CanMulticast)); + if(flag) { + QList addrs = netInterface.addressEntries(); + foreach(QNetworkAddressEntry addr, addrs) { + //只取出IPV4的地址 + if(addr.ip().protocol() == QAbstractSocket::IPv4Protocol) { + QString ip4 = addr.ip().toString(); + if(ip4 != "127.0.0.1") { + ips.append(ip4); + } + } + } + } + } + + ui->cboxListenIP->addItems(ips); + ui->cboxListenIP->addItem("127.0.0.1"); } void frmUdpServer::initConfig() @@ -46,17 +80,16 @@ void frmUdpServer::initConfig() ui->cboxInterval->setCurrentIndex(ui->cboxInterval->findText(QString::number(App::IntervalUdpServer))); connect(ui->cboxInterval, SIGNAL(currentIndexChanged(int)), this, SLOT(saveConfig())); - ui->txtServerIP->setText(App::UdpServerIP); - connect(ui->txtServerIP, SIGNAL(textChanged(QString)), this, SLOT(saveConfig())); - - ui->txtServerPort->setText(QString::number(App::UdpServerPort)); - connect(ui->txtServerPort, SIGNAL(textChanged(QString)), this, SLOT(saveConfig())); + ui->cboxListenIP->setCurrentIndex(ui->cboxListenIP->findText(App::UdpListenIP)); + connect(ui->cboxListenIP, SIGNAL(currentIndexChanged(int)), this, SLOT(saveConfig())); ui->txtListenPort->setText(QString::number(App::UdpListenPort)); connect(ui->txtListenPort, SIGNAL(textChanged(QString)), this, SLOT(saveConfig())); - timer->setInterval(App::IntervalUdpServer); - App::AutoSendUdpServer ? timer->start() : timer->stop(); + ui->ckSelectAll->setChecked(App::SelectAllUdpServer); + connect(ui->ckSelectAll, SIGNAL(stateChanged(int)), this, SLOT(saveConfig())); + + this->changeTimer(); } void frmUdpServer::saveConfig() @@ -67,13 +100,26 @@ void frmUdpServer::saveConfig() App::DebugUdpServer = ui->ckDebug->isChecked(); App::AutoSendUdpServer = ui->ckAutoSend->isChecked(); App::IntervalUdpServer = ui->cboxInterval->currentText().toInt(); - App::UdpServerIP = ui->txtServerIP->text().trimmed(); - App::UdpServerPort = ui->txtServerPort->text().trimmed().toInt(); + App::UdpListenIP = ui->cboxListenIP->currentText(); App::UdpListenPort = ui->txtListenPort->text().trimmed().toInt(); + App::SelectAllUdpServer = ui->ckSelectAll->isChecked(); App::writeConfig(); + this->changeTimer(); +} + +void frmUdpServer::changeTimer() +{ timer->setInterval(App::IntervalUdpServer); - App::AutoSendUdpServer ? timer->start() : timer->stop(); + if (App::AutoSendUdpServer) { + if (!timer->isActive()) { + timer->start(); + } + } else { + if (timer->isActive()) { + timer->stop(); + } + } } void frmUdpServer::append(int type, const QString &data, bool clear) @@ -136,12 +182,14 @@ void frmUdpServer::readData() } QString ip = host.toString(); + ip = ip.replace("::ffff:", ""); if (ip.isEmpty()) { continue; } QString str = QString("[%1:%2] %3").arg(ip).arg(port).arg(buffer); append(1, str); + clientConnected(ip, port); if (App::DebugUdpServer) { int count = App::Keys.count(); @@ -170,17 +218,27 @@ void frmUdpServer::sendData(const QString &ip, int port, const QString &data) QString str = QString("[%1:%2] %3").arg(ip).arg(port).arg(data); append(0, str); +} +void frmUdpServer::clientConnected(const QString &ip, int port) +{ + //先过滤重复的 + QString str = QString("%1:%2").arg(ip).arg(port); + for (int i = 0; i < ui->listWidget->count(); i++) { + QString s = ui->listWidget->item(i)->text(); + if (str == s) { + return; + } + } + + ui->listWidget->addItem(str); + ui->labCount->setText(QString("共 %1 个客户端").arg(ui->listWidget->count())); } void frmUdpServer::on_btnListen_clicked() { if (ui->btnListen->text() == "监听") { -#if (QT_VERSION > QT_VERSION_CHECK(5,0,0)) - bool ok = udpSocket->bind(QHostAddress::AnyIPv4, App::UdpListenPort); -#else - bool ok = udpSocket->bind(QHostAddress::Any, App::UdpListenPort); -#endif + bool ok = udpSocket->bind(QHostAddress(App::UdpListenIP), App::UdpListenPort); if (ok) { ui->btnListen->setText("关闭"); append(0, "监听成功"); @@ -220,5 +278,18 @@ void frmUdpServer::on_btnSend_clicked() return; } - sendData(App::UdpServerIP, App::UdpServerPort, data); + if (ui->ckSelectAll->isChecked()) { + for (int i = 0; i < ui->listWidget->count(); i++) { + QString str = ui->listWidget->item(i)->text(); + QStringList list = str.split(":"); + sendData(list.at(0), list.at(1).toInt(), data); + } + } else { + int row = ui->listWidget->currentRow(); + if (row >= 0) { + QString str = ui->listWidget->item(row)->text(); + QStringList list = str.split(":"); + sendData(list.at(0), list.at(1).toInt(), data); + } + } } diff --git a/nettool/form/frmudpserver.h b/nettool/form/frmudpserver.h index 6704a85..d65b505 100644 --- a/nettool/form/frmudpserver.h +++ b/nettool/form/frmudpserver.h @@ -24,12 +24,15 @@ private: private slots: void initForm(); + void initIP(); void initConfig(); void saveConfig(); + void changeTimer(); void append(int type, const QString &data, bool clear = false); void readData(); void sendData(const QString &ip, int port, const QString &data); + void clientConnected(const QString &ip, int port); private slots: void on_btnListen_clicked(); diff --git a/nettool/form/frmudpserver.ui b/nettool/form/frmudpserver.ui index 3e25117..13746ec 100644 --- a/nettool/form/frmudpserver.ui +++ b/nettool/form/frmudpserver.ui @@ -41,7 +41,7 @@ QFrame::Sunken - + @@ -88,24 +88,14 @@ - + - 远程IP地址 + 监听地址 - - - - - - 远程端口 - - - - - + @@ -139,17 +129,36 @@ - - - Qt::Vertical - - + + - 20 - 40 + 0 + 25 - + + QFrame::Box + + + QFrame::Sunken + + + 共 0 个客户端 + + + Qt::AlignCenter + + + + + + + + + + 对所有客户端发送 + + @@ -206,6 +215,23 @@ + + txtMain + ckHexReceive + ckHexSend + ckAscii + ckShow + ckDebug + ckAutoSend + cboxInterval + cboxListenIP + txtListenPort + btnListen + btnSave + btnClear + cboxData + btnSend + diff --git a/nettool/main.cpp b/nettool/main.cpp index 0f71fc7..322fe9b 100644 --- a/nettool/main.cpp +++ b/nettool/main.cpp @@ -24,7 +24,7 @@ int main(int argc, char *argv[]) App::readDeviceData(); frmMain w; - w.setWindowTitle(QString("网络调试助手V2019 本机IP: %1 QQ: 517216493").arg(QUIHelper::getLocalIP())); + w.setWindowTitle(QString("网络调试助手V2020 本机IP: %1 QQ: 517216493").arg(QUIHelper::getLocalIP())); w.show(); return a.exec(); diff --git a/nettool/readme.txt b/nettool/readme.txt index c7cb8b0..596b92a 100644 --- a/nettool/readme.txt +++ b/nettool/readme.txt @@ -11,7 +11,7 @@ 6ɶԵӷݣҲɹѡȫз͡ 7ֶ֧ͻӲ 8õ̡߳ -9ģʽtcptcpͻˡudpudpͻˡ +9ģʽtcpͻˡtcpudpͻˡudp 뽫ԴµfileĿ¼еļƵִļͬһĿ¼ иõĽQ(517216493)лл \ No newline at end of file diff --git a/nettool/snap/QQ截图20180514145725.jpg b/nettool/snap/QQ截图20180514145725.jpg new file mode 100644 index 0000000..6d7fa5e Binary files /dev/null and b/nettool/snap/QQ截图20180514145725.jpg differ diff --git a/nettool/snap/QQ截图20180514145729.jpg b/nettool/snap/QQ截图20180514145729.jpg new file mode 100644 index 0000000..4a408fe Binary files /dev/null and b/nettool/snap/QQ截图20180514145729.jpg differ diff --git a/nettool/snap/QQ截图20180514145732.jpg b/nettool/snap/QQ截图20180514145732.jpg new file mode 100644 index 0000000..0258092 Binary files /dev/null and b/nettool/snap/QQ截图20180514145732.jpg differ diff --git a/nettool/snap/QQ截图20180514145909.jpg b/nettool/snap/QQ截图20180514145909.jpg new file mode 100644 index 0000000..39d0cbe Binary files /dev/null and b/nettool/snap/QQ截图20180514145909.jpg differ