当前位置: 首页 > news >正文

Qt第十九章 网络编程

文章目录

  • 主机(Host)
    • QHostInfo
    • QHostAddress
    • QNetworkInterface
  • 低级接口
    • QAbstractSocket
    • QTcpServer
    • QTcpSocket
    • QUdpSocket
      • 单播
      • 多播
      • 广播
  • 网络访问
    • QNetworkAccessManager
    • QNetworkRequest
    • QNetworkReply
    • 实操

主机(Host)

QHostInfo

    // 阻塞获取网址信息QHostInfo info = QHostInfo::fromName("www.bilibili.com");qDebug() << info.hostName(); // 主机名即域名qDebug() << info.addresses(); // Ip地址// 异步获取,如果网址不存在会报错QHostInfo::lookupHost("www.baidu.com", &a, [=](const QHostInfo info1) { // a是 QCoreApplication a(argc, argv)qDebug() << info1.hostName();qDebug() << info1.addresses();});// 获取本地主机名qDebug() << "本地主机名" << QHostInfo::localHostName();

QHostAddress

枚举描述相当于
QHostAddress::Null空地址对象QHostAddress()
QHostAddress::LocalHostIPv4本地主机地址QHostAddress(127.0.0.1)
QHostAddress::LocalHostIPv6IPv6本地主机地址QHostAddress(“::1”)
QHostAddress::BroadcastIPv4广播地址QHostAddress(“255.255.255.255”)
QHostAddress::AnyIPv4任意IPv4地址,与此绑定的套接字将只侦听iPV4接口QHostAddress(“0.0.0.0”)
QHostAddress::AnyIPv6任意IPv6地址QHostAddress(“::”)
QHostAddress::Any双栈任意地址。

QNetworkInterface

    QList<QNetworkInterface> netlist = QNetworkInterface::allInterfaces();for (auto& net : netlist) {if (!net.isValid())continue;qDebug() << "名称" << net.name();qDebug() << "描述" << net.humanReadableName();qDebug() << "类型" << net.type();qDebug() << "mac地址" << net.hardwareAddress();for (auto& ip : net.addressEntries())qDebug() << ip.ip();qDebug() << "==========================";        }

在这里插入图片描述

低级接口

QAbstractSocket

QTcpServer

创建服务器

#include <QCoreApplication>
#include <QHostInfo>
#include <QTcpServer>
#include <QTcpSocket>int main(int argc, char* argv[])
{QCoreApplication a(argc, argv);QTcpServer* server = new QTcpServer;server->listen(QHostAddress::LocalHost, 6666);QObject::connect(server, &QTcpServer::newConnection, [=] {while (server->hasPendingConnections()) { // 如果有连接,读取套接字QTcpSocket* socket = server->nextPendingConnection();socket->write("hello world!");qDebug() << "有新的连接来了";}});return a.exec();
}

在这里插入图片描述

QTcpSocket

// 创建客户端

    QTcpSocket* tcp = new QTcpSocket;QObject::connect(tcp, &QTcpSocket::errorOccurred, [=](QAbstractSocket::SocketError err) {qDebug() << err << '\t' << tcp->errorString();}); // 连接发生错误,报错误原因QObject::connect(tcp, &QTcpSocket::stateChanged, [=](auto state) {qDebug() << state;});QObject::connect(tcp, &QTcpSocket::connected, [] { qDebug("连接成功"); });QObject::connect(tcp, &QTcpSocket::readyRead, [=] {if (tcp->bytesAvailable() > 0)qDebug() << tcp->readAll();}); // 如果有可读取数据,读取所有并输出tcp->connectToHost(QHostAddress::LocalHost, 6666); // 连接本地地址,端口0-1023是被占用的,程序员可用1024-65535

在这里插入图片描述

QUdpSocket

单播

#include <QCoreApplication>
#include <QNetworkDatagram>
#include <QUdpSocket>int main(int argc, char* argv[])
{QCoreApplication a(argc, argv);QUdpSocket* udp1 = new QUdpSocket;QUdpSocket* udp2 = new QUdpSocket;udp2->bind(QHostAddress::LocalHost, 6666); // 绑定端口号QObject::connect(udp2, &QUdpSocket::readyRead, [=] {while (udp2->hasPendingDatagrams()) {qDebug() << udp2->receiveDatagram().data();}}); // 如果udp2里有接收到数据报,就打印udp1->writeDatagram("hello,world", QHostAddress::LocalHost, 6666); // 发送数据return a.exec();
}

多播

多播是一对多,与单播步骤是一样的,只有IP地址有区别
多播的地址是D类地址,即224.0.0.0到239.255.255.255之间的IP地址,并被划分为局部连接多播地址预留多播地址管理权限多播地址3类

  1. 局部多播地址:224.0.0.0~224.0.0.255之间,这是为路由协议和其他用途保留的地址,路由器并不转发此范围的IP包
  2. 预留多播地址:224.0.1.0~238.255.255.255之间,可用于全球范围(如Internet)或网络协议。
  3. 管理权限多播地址:239.0.0.0~239.255.255.255之间,可供组织内部使用,类似于私有IP地址,不能用于Internet,可限制多播范围。
#include <QCoreApplication>
#include <QNetworkDatagram>
#include <QUdpSocket>int main(int argc, char* argv[])
{QCoreApplication a(argc, argv);QUdpSocket* udp1 = new QUdpSocket;QUdpSocket* udp2 = new QUdpSocket;// 组播udp2->bind(QHostAddress::AnyIPv4, 6666, QUdpSocket::ShareAddress | QUdpSocket::ReuseAddressHint);udp2->joinMulticastGroup(QHostAddress("224.1.1.1"));QObject::connect(udp2, &QUdpSocket::readyRead, [=] {while (udp2->hasPendingDatagrams()) {qDebug() << udp2->receiveDatagram().data();}}); // 如果udp2里有接收到数据报,就打印udp1->writeDatagram("hello,world", QHostAddress("224.1.1.1"), 6666); // 发送数据return a.exec();
}

广播

广播就是把多播发送地址改成255.255.255.255,并且客户端 不需要加入多播组,其他操作一样

#include <QCoreApplication>
#include <QNetworkDatagram>
#include <QUdpSocket>int main(int argc, char* argv[])
{QCoreApplication a(argc, argv);// 广播QUdpSocket* udp1 = new QUdpSocket;QUdpSocket* udp2 = new QUdpSocket;udp2->bind(QHostAddress::AnyIPv4, 6666, QUdpSocket::ShareAddress | QUdpSocket::ReuseAddressHint);QObject::connect(udp2, &QUdpSocket::readyRead, [=] {while (udp2->hasPendingDatagrams()) {qDebug() << udp2->receiveDatagram().data();}}); // 如果udp2里有接收到数据报,就打印udp1->writeDatagram("hello,world", QHostAddress("255.255.255.255"), 6666); // 发送数据return a.exec();
}

网络访问

QNetworkAccessManager

QNetworkRequest

QNetworkReply

实操

类似于python爬虫的request请求

#include <QCoreApplication>
#include <QNetworkAccessManager>
#include <QNetworkReply>
#include <QNetworkRequest>int main(int argc, char* argv[])
{QCoreApplication a(argc, argv);QNetworkAccessManager* manager = new QNetworkAccessManager;QNetworkRequest request;request.setUrl(QUrl("https://baike.baidu.com/item/12/1016?fr=ge_ala"));manager->get(request);QObject::connect(manager, &QNetworkAccessManager::finished, [=](QNetworkReply* reply) {qDebug() << QString::fromUtf8(reply->readAll());});return a.exec();
}

在这里插入图片描述


http://www.mrgr.cn/news/13601.html

相关文章:

  • vim 简易配置
  • Disassembly窗口信息解读
  • 数据结构(Java实现):栈和队列相关练习题题解
  • Ruff :是一个用Rust编写的极快的 Python linter 和代码格式化程序
  • 推荐一款强大的 macOS 剪贴板增强工具:CleanClip
  • 大数据-105 Spark GraphX 基本概述 与 架构基础 概念详解 核心数据结构
  • src-登陆框的常见测试思路
  • 【leetcode_C++_string】387.字符串中的第一个唯一字符
  • 怎么检测电脑的RAM?丨什么是RAM?
  • 正则表达式(java)
  • 保存和加载工作区变量
  • wordpress安装完访问时提示“不安全”
  • 【Java】数据类型与变量(二)
  • 什么是美颜SDK?视频美颜API集成与优化技术探索
  • openGauss在龙芯平台部署的实践
  • 游戏开发设计模式之模板方法模式
  • Leetcode面试经典150题-122.买卖股票的最佳时机II
  • [LeetCode]139.单词拆分(C++)
  • 使用ffmpeg+node-media-server实现从rtsp服务器拉流再推送至rtmp服务器,实现http+flv进行web播放
  • 【Go语言成长之路】泛型入门