Qt网络编程:QNetworkAccessManager、QNetworkConfiguration

QNetworkAccessManager

一、描述

1、Qt网络访问 API 是围绕 QNetworkAccessManager 对象构建的,该对象保存它发送的请求的通用配置和设置。一个 QNetworkAccessManager 实例应该足以满足整个 Qt 应用程序网络访问的需求。 由于 QNetworkAccessManager 是基于 QObject 的,所以只能在它所属的线程中使用。

2、一旦创建了 QNetworkAccessManager 对象,应用程序就可以使用它通过网络发送请求。它提供了一组标准函数,它们接受一个请求和可选数据,每个函数都返回一个 QNetworkReply 对象。返回的对象用于获取响应相应请求而返回的任何数据。

可以通过以下方式完成简单的网络下载:

QNetworkAccessManager *manager = new QNetworkAccessManager(this);
connect(manager, &QNetworkAccessManager::finished, this, &MyClass::replyFinished);
manager->get(QNetworkRequest(QUrl("http://qt-project.org")));

3、QNetworkAccessManager 有一个异步 API。 当上面的 replyFinished 槽函数被调用时,它采用的参数是 QNetworkReply 对象,包含下载的数据以及元数据(标题等)。

注意:请求完成后,用户有责任在适当的时候删除 QNetworkReply 对象。不要在连接到finished()的slot里面直接删除,可以使用 deleteLater() 函数。

注意: QNetworkAccessManager 将它收到的请求排入队列。 并行执行的请求数量取决于协议。 目前,对于桌面平台上的 HTTP 协议,一个主机/端口组合并行执行 6 个请求。

一个更复杂的例子:

QNetworkRequest request;
request.setUrl(QUrl("http://qt-project.org"));
request.setRawHeader("User-Agent", "MyOwnBrowser 1.0");

QNetworkReply *reply = manager->get(request);
connect(reply, &QIODevice::readyRead, this, &MyClass::slotReadyRead);
connect(reply, &QNetworkReply::errorOccurred,this, &MyClass::slotError);
connect(reply, &QNetworkReply::sslErrors,this, &MyClass::slotSslErrors);

二、类型成员

1、enum QNetworkAccessManager::Operation:指示回复正在处理的操作。

  • HeadOperation:检索headers操作(使用 head() 创建)
  • GetOperation:检索headers和下载内容(使用 get() 创建)
  • PutOperation:上传内容操作(使用 put() 创建)
  • PostOperation:发送 HTML 表单的内容以通过 HTTP POST 进行处理(使用 post() 创建)
  • DeleteOperation:删除内容操作(使用 deleteResource() 创建)
  • CustomOperation:自定义操作(使用 sendCustomRequest() 创建)

三、成员函数

1、[signal] void authenticationRequired(QNetworkReply *reply, QAuthenticator *authenticator)

每当服务器在交付请求的内容之前请求身份验证时,都会发出此信号。连接到此信号的槽函数应填充验证器对象中的凭据。

QNetworkAccessManager 将在内部缓存凭据,如果服务器再次需要身份验证,则将发送相同的值,而不发出此信号。如果服务器拒绝凭据,将再次发出此信号。

注意:无法使用 QueuedConnection 连接到此信号,因为如果在信号返回时验证器未填充新信息,则连接将失败。

2、[signal] void encrypted(QNetworkReply *reply)

当 SSL/TLS 会话成功完成初始握手时,会发出此信号。此时,还没有传输用户数据。

3、[signal] void finished(QNetworkReply *reply)

网络回复完成时会发出此信号。回复参数将包含一个指向刚刚完成的回复的指针。该信号与 QNetworkReply::finished() 信号一起发出。

注意:不要直接删除连接到该信号的槽中的回复对象。应使用 deleteLater()。

4、[signal] void preSharedKeyAuthenticationRequired(QNetworkReply *reply, QSslPreSharedKeyAuthenticator *authenticator)

如果 SSL/TLS 握手协商 PSK 密码套件,则会发出此信号,因此需要 PSK 身份验证。 回复对象是正在协商此类密码套件的 QNetworkReply。

使用 PSK 时,客户端必须向服务器发送一个有效的身份和一个有效的预共享密钥,以便 SSL 握手继续进行。 应用程序可以在连接到这个信号的槽中提供这个信息,根据他们的需要填充传递的验证器对象。

注意:忽略此信号,或未能提供所需的凭据,将导致握手失败,从而中止连接。

注意:验证器对象归回复所有,不得被应用程序删除。

5、[signal] void proxyAuthenticationRequired(const QNetworkProxy &proxy, QAuthenticator *authenticator)

每当代理请求身份验证并且 QNetworkAccessManager 找不到有效的缓存凭据时,就会发出此信号。连接到此信号的槽函数应填写身份验证器对象中的代理凭据。

QNetworkAccessManager 将在内部缓存凭据。下次代理请求身份验证时,将自动发送相同的凭据,而不会再次发出此信号。

如果代理拒绝凭据,QNetworkAccessManager 将再次发出信号。

6、[signal] void sslErrors(QNetworkReply *reply, const QList<QSslError> &errors)

如果 SSL/TLS 会话在设置期间遇到错误,包括证书验证错误,则会发出此信号。 errors 参数包含错误列表,reply 是遇到这些错误的 QNetworkReply。

为了表明错误不是致命的并且连接应该继续,应该从连接到这个信号的槽函数调用 QNetworkReply::ignoreSslErrors() 函数。如果未调用 SSL 会话将断开。

此信号可用于向用户显示错误消息,指示安全性可能受到威胁并显示 SSL 设置。如果用户在分析远程证书后决定继续,则槽函数应调用 ignoreSslErrors()。

7、void addStrictTransportSecurityHosts(const QVector<QHstsPolicy> &knownHosts)

将 HTTP 严格传输安全策略添加到 HSTS 缓存中。

8、void clearAccessCache()

刷新身份验证数据和网络连接的内部缓存。

9、void clearConnectionCache()

刷新网络连接的内部缓存。与 clearAccessCache() 相比,身份验证数据被保留。

10、void connectToHost(const QString &hostName, quint16 port = 80)

与指定的主机连接。

11、void connectToHostEncrypted(const QString &hostName, quint16 port = 443, const QSslConfiguration &sslConfiguration = QSslConfiguration::defaultConfiguration())

使用 sslConfiguration 配置与指定的主机连接。

12、void connectToHostEncrypted(const QString &hostName, quint16 port, const QSslConfiguration &sslConfiguration, const QString &peerName)

重载函数。使用 sslConfiguration 配置与指定的主机连接,peerName为用于证书验证的主机名。

13、QNetworkReply *deleteResource(const QNetworkRequest &request)

发送请求以删除由请求的 URL 标识的资源。此功能目前仅适用于 HTTP,执行 HTTP DELETE 请求。

14、QNetworkReply * get(const QNetworkRequest &request)

发布请求以获取内容,返回一个新的 QNetworkReply 对象,该对象在新数据到达时发出 readyRead() 信号。

15、QNetworkReply * head(const QNetworkRequest &request)

发布请求以获取请求的网络标头并返回一个新的 QNetworkReply 对象。

16、QNetworkReply * post(const QNetworkRequest &request, QIODevice *data)

将 HTTP POST 请求发送到 request 指定的目的地,并返回一个新的 QNetworkReply 对象,该对象将包含服务器发送的回复。data的内容将上传到服务器。

data必须打开以供读取,并且必须保持有效,直到为此回复发出finished()信号。

注意:在 HTTP 和 HTTPS 以外的协议上发送 POST 请求是未定义的,并且可能会失败。

17、QNetworkReply * post(const QNetworkRequest &request, const QByteArray &data)

重载函数。将数据字节数组的内容发送到请求指定的目的地。

18、QNetworkReply * post(const QNetworkRequest &request, QHttpMultiPart *multiPart)

重载函数。将 HTTP multipart MIME 消息的内容发送到请求指定的目的地。

19、QNetworkReply * put(const QNetworkRequest &request, QIODevice *data)

将数据上传到request设置的目标并返回一个新的 QNetworkReply 对象。

调用此函数时,必须打开(QIODevice::open())设备以进行读取,并且必须保持有效,直到为此回复发出finished() 信号为止。

20、QNetworkReply * put(const QNetworkRequest &request, const QByteArray &data)

21、QNetworkReply * put(const QNetworkRequest &request, QHttpMultiPart *multiPart)

重载函数。

22、QNetworkReply * sendCustomRequest(const QNetworkRequest &request, const QByteArray &verb, QIODevice *data = nullptr)

向由请求的 URL 标识的服务器发送自定义请求。

用户有责任将根据 HTTP 规范有效的动词发送到服务器。

此方法提供了发送除通过 get() 或 post() 等提供的常用动词以外的动词的方法,例如发送 HTTP OPTIONS 命令。

如果数据不为空,则将数据设备的内容上传到服务器; 在这种情况下,必须打开(QIODevice::open())设备以进行读取,并且必须保持有效,直到为此回复发出finished() 信号为止。

23、QNetworkReply * sendCustomRequest(const QNetworkRequest &request, const QByteArray &verb, const QByteArray &data)

24、QNetworkReply * sendCustomRequest(const QNetworkRequest &request, const QByteArray &verb, QHttpMultiPart *multiPart)

重载函数。

25、void setAutoDeleteReplies(bool shouldAutoDelete)

启用或禁用 QNetworkReply 的自动删除。设置为 true 与将 QNetworkRequest::AutoDeleteReplyOnFinishAttribute 属性设置为 true 相同。

26、void setCache(QAbstractNetworkCache *cache)

设置网络缓存对象。

27、void setCookieJar(QNetworkCookieJar *cookieJar)

设置保存cookie的对象。

28、void setProxy(const QNetworkProxy &proxy)

设置代理。

29、void setProxyFactory(QNetworkProxyFactory *factory)

设置代理工厂。代理工厂用于具体的代理列表,而不是尝试对所有请求使用相同的代理值(即根据不同情况使用不同的代理)。QNetworkAccessManager 发送的所有查询都将具有 QNetworkProxyQuery::UrlRequest 类型。

例如,代理工厂可以应用以下规则:

  • 如果目标地址在本地网络中,则返回 QNetworkProxy::NoProxy
  • 如果请求是 FTP,则返回一个 FTP 代理
  • 如果请求是 HTTP 或 HTTPS,则返回 HTTP 代理
  • 其他情况返回 SOCKSv5 代理服务器
  • 如果使用 setProxy() 设置了特定代理,则不会使用工厂。

30、void setRedirectPolicy(QNetworkRequest::RedirectPolicy policy)

设置重定向策略。

31、void setStrictTransportSecurityEnabled(bool enabled)

设置是否遵循 HTTP 严格传输安全策略(HSTS,RFC6797)。

如果启用:

处理请求时,QNetworkAccessManager 会自动将“http”方案替换为“https”,并为 HSTS 主机使用安全传输。如果明确设置,则端口 80 将替换为端口 443。

对于每个包含 HSTS 标头并通过安全传输接收的 HTTP 响应,QNetworkAccessManager 将更新其 HSTS 缓存,或者记住具有有效策略的主机或删除具有过期或禁用 HSTS 策略的主机。

32、void setTransferTimeout(int timeout = QNetworkRequest::DefaultTransferTimeoutConstant)

设置传输超时时间。如果在超时到期之前没有传输字节,传输将被中止。

零表示未设置计时器。如果未调用此函数,则超时将被禁用且值为 0。

33、QVector<QHstsPolicy> strictTransportSecurityHosts()

返回 HTTP 严格传输安全策略列表。如果 HSTS 缓存是从“Strict-Transport-Security”响应标头更新的,则此列表可能与最初通过 addStrictTransportSecurityHosts() 设置的不同。

34、QStringList supportedSchemes()

列出支持的所有 URL 方案。

本文福利,费领取Qt开发学习资料包、技术视频,内容包括(C++语言基础,Qt编程入门,QT信号与槽机制,QT界面开发-图像绘制,QT网络,QT数据库编程,QT项目实战,QT嵌入式开发,Quick模块等等)↓↓↓↓↓↓见下面↓↓文章底部点击费领取↓↓

QNetworkConfiguration

一、描述

QNetworkConfiguration 封装了单个接入点或服务网络。

单个接入点配置可以映射到一个网络接口。然而,单个网络接口可能并不总是只映射到一个接入点配置。同一网络设备的多种配置可以启用多个接入点。如智能手机允许用户管理多个 WLAN 配置,而设备本身只有一个 WLAN 网络设备。

QNetworkConfiguration 也支持服务网络的概念。这一概念允许将多个接入点配置分组为一个实体。这样的组称为服务网络,在需要到特定目标网络(例如公司网络)的网络会话的情况下可能是有益的。使用服务网络时,用户通常不关心选择了哪一种连接选项(例如,企业 WLAN 或通过 GPRS 的 VPN),只要他可以访问公司的目标服务器即可。此外,可以启用自动接入点漫游,使设备能够动态更改网络接口配置,同时保持应用程序与目标网络的连接。它允许适应不断变化的环境,并可以优化成本、速度或其他网络参数。

二、类型成员

1、enum QNetworkConfiguration::BearerType:指定配置使用的承载类型。

  • BearerUnknown:承载类型未知或未指定。
  • BearerEthernet:该配置用于以太网接口。
  • BearerWLAN:该配置用于无线 LAN 接口。
  • Bearer2G:该配置适用于 CSD、GPRS、HSCSD、EDGE 或 cdmaOne 接口。
  • Bearer3G:配置为3G接口。
  • Bearer4G:配置为4G接口。
  • BearerCDMA2000:配置为CDMA接口。
  • BearerWCDMA:该配置适用于 W-CDMA/UMTS 接口。
  • BearerHSPA:该配置用于高速分组接入 (HSPA) 接口。
  • BearerBluetooth:该配置用于蓝牙接口。
  • BearerWiMAX:该配置适用于 WiMAX 接口。
  • BearerEVDO:该配置用于 EVDO (3G) 接口。
  • BearerLTE:该配置用于 LTE (4G) 接口。

2、enum QNetworkConfiguration::Purpose:指定配置的目的。

  • UnknownPurpose:该配置没有指定任何目的。这是默认值。
  • PublicPurpose:该配置可用于通用互联网访问。
  • PrivatePurpose:该配置适用于访问办公室内网等私有网络。
  • ServiceSpecificPurpose:该配置可用于运营商特定服务(例如接收彩信或内容流)。

3、enum QNetworkConfiguration::StateFlag:指定配置状态。

  • Undefined:此状态用于临时配置,例如用户尚未实际为其创建配置的新发现的 WLAN。
  • Defined:定义的配置对系统来说是已知的,但不能立即使用(例如,配置的 WLAN 不在范围内或以太网电缆当前未插入机器)。
  • Discovered:发现的配置可以立即用于创建新的 QNetworkSession。 如果配置是服务网络,则如果至少一个底层接入点配置具有已发现状态,则设置此标志。
  • Active:该配置当前由开放网络会话使用(QNetworkSession::isOpen())。

4、enum QNetworkConfiguration::Type:此枚举描述配置的类型。

  • InternetAccessPoint:该配置指定单个接入点的详细信息。
  • ServiceNetwork:该配置基于一组 InternetAccessPoint 类型的 QNetworkConfiguration。 所有组成员都可以到达同一个目标网络。
  • UserChoice:配置是一个占位符,当会话打开时,它将被平台解析为实际配置。根据平台,选择可能会生成一个弹出对话框,询问用户他的首选选择。
  • Invalid:配置无效。

三、成员函数

1、QList<QNetworkConfiguration> children()

按优先级顺序返回此网络配置的所有子配置。列表中的第一个子配置具有最高优先级。

只有 ServiceNetwork 类型的网络配置可以有子级。

2、QString identifier()

返回此网络配置的唯一且特定于平台的标识符。

3、bool isRoamingAvailable()

配置是否支持漫游。

4、bool isValid()

此 QNetworkConfiguration 对象是否有效。如果用户删除配置或配置是默认构建的,则配置可能会失效。可以通过 QNetworkConfigurationManager 监控配置的添加和删除。

5、QString name()

返回此配置的用户可见名称。该名称可以是底层接入点的名称,也可以是此配置所代表的服务网络的名称。

6、bool setConnectTimeout(int timeout)

设置此配置的连接超时时间(毫秒)。

本文福利,费领取Qt开发学习资料包、技术视频,内容包括(C++语言基础,Qt编程入门,QT信号与槽机制,QT界面开发-图像绘制,QT网络,QT数据库编程,QT项目实战,QT嵌入式开发,Quick模块等等)↓↓↓↓↓↓见下面↓↓文章底部点击费领取↓↓

版权声明:本文为CSDN博主「友善啊,朋友」的原创文章

原文链接:https://blog.csdn.net/kenfan1647/article/details/118400310

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值