我的 HTTP 请求有问题
请求.hpp
#ifndef PROGRAMMEREQUEST_HPP_
#define PROGRAMMEREQUEST_HPP_
#include <QObject>
class RequestHTTP : public QObject
{
Q_OBJECT
public:
RequestHTTP();
virtual ~RequestHTTP() {}
void sendRequest(QUrl url, QObject *target, const QString signature);
private:
QString callbackMethodName;
QObject *callbackObject;
private slots:
void onRequestFinished();
};
#endif
请求.cpp
#include "request.hpp"
#include <QNetworkReply>
#include <QNetworkRequest>
#include <QNetworkAccessManager>
#include <QBuffer>
#include <QIODevice>
#include <QMetaMethod>
RequestHTTP::RequestHTTP() : callbackObject(NULL) { }
void RequestHTTP::sendRequest(QUrl url, QObject *target, const QString signature)
{
this->callbackObject = target;
this->callbackMethodName = signature;
QNetworkRequest request = QNetworkRequest();
request.setUrl(url);
QNetworkAccessManager *pNetworkAccessManager = new QNetworkAccessManager(this);
QNetworkReply* reply = pNetworkAccessManager->get(request);
bool result = connect(reply, SIGNAL(finished()), this, SLOT(onRequestFinished()));
Q_UNUSED(result);
Q_ASSERT(result);
}
void RequestHTTP::onRequestFinished()
{
QNetworkReply* reply = qobject_cast<QNetworkReply*>(sender());
if (reply && reply->error() == QNetworkReply::NoError)
{
QBuffer device;
device.setData(reply->readAll());
device.open(QIODevice::ReadOnly);
QByteArray normalizedSignature = QMetaObject::normalizedSignature(callbackMethodName);
int methodIndex = callbackObject->metaObject()->indexOfMethod(normalizedSignature);
QMetaMethod method = callbackObject->metaObject()->method(methodIndex);
method.invoke(callbackObject,
Qt::DirectConnection, Q_ARG(QBuffer *, &device));
}
else
{
// Problem with the reply.
// ...
}
reply->deleteLater();
}
当我表演时
QUrl url("http://www.example-xml-ws.org");
RequestHTTP http;
http.sendRequest(url, this, "processData(QBuffer*)");
我在日志中看到错误之后bool result = connect(reply, SIGNAL(finished()), this, SLOT(onRequestFinished()));
3 月 15 日 17:20:55.032 org.example.testDev_xamplefmeb1c2e99.37572818 默认 8900 错误 netstatus_interface_get_type:类型为 NULL
3 月 15 日 17:20:55.032 org.example.testDev_xamplefmeb1c2e99.37572818 默认 8900 错误 netstatus_interface_get_ip_status: ip_ok 为 NULL
3 月 15 日 17:20:55.032 org.example.testDev_xamplefmeb1c2e99.37572818 默认 8900 错误 netstatus_interface_get_num_ip_addresses:num_ip_addresses 为 NULL
3 月 15 日 17:20:55.033 org.example.testDev_xamplefmeb1c2e99.37572818 默认 8900 错误 netstatus_interface_get_type:类型为 NULL
3 月 15 日 17:20:55.033 org.example.testDev_xamplefmeb1c2e99.37572818 默认 8900 错误 netstatus_interface_get_ip_status: ip_ok 为 NULL
3 月 15 日 17:20:55.033 org.example.testDev_xamplefmeb1c2e99.37572818 默认 8900 错误 netstatus_interface_get_num_ip_addresses:num_ip_addresses 为 NULL
3 月 15 日 17:20:55.034 org.example.testDev_xamplefmeb1c2e99.37572818 默认 8900 错误 netstatus_interface_get_type:类型为 NULL
3 月 15 日 17:20:55.034 org.example.testDev_xamplefmeb1c2e99.37572818 默认 8900 错误 netstatus_interface_get_ip_status: ip_ok 为 NULL
3 月 15 日 17:20:55.034 org.example.testDev_xamplefmeb1c2e99.37572818 默认 8900 错误 netstatus_interface_get_num_ip_addresses:num_ip_addresses 为 NULL
3 月 15 日 17:20:55.034 org.example.testDev_xamplefmeb1c2e99.37572818 默认 8900 错误 netstatus_interface_get_type:类型为 NULL
3 月 15 日 17:20:55.034 org.example.testDev_xamplefmeb1c2e99.37572818 默认 8900 错误 netstatus_interface_get_ip_status: ip_ok 为 NULL
3 月 15 日 17:20:55.034 org.example.testDev_xamplefmeb1c2e99.37572818 默认 8900 错误 netstatus_interface_get_num_ip_addresses:num_ip_addresses 为 NULL
3 月 15 日 17:20:55.036 org.example.testDev_xamplefmeb1c2e99.37572818 默认 8900 错误 netstatus_interface_get_type:类型为 NULL
3 月 15 日 17:20:55.036 org.example.testDev_xamplefmeb1c2e99.37572818 默认 8900 错误 netstatus_interface_get_ip_status: ip_ok 为 NULL
3 月 15 日 17:20:55.036 org.example.testDev_xamplefmeb1c2e99.37572818 默认 8900 错误 netstatus_interface_get_num_ip_addresses:num_ip_addresses 为 NULL
结果请求发送成功,但问题是为什么我看到这个输出?