【问题标题】:Microsoft translator API Qt微软翻译 API Qt
【发布时间】:2013-07-21 13:54:21
【问题描述】:

我在使用 QNetworkAccessManager 获取 Microsoft 翻译器的应用程序令牌时遇到问题。这是我的代码:

QUrl serverUrl("https://datamarket.accesscontrol.windows.net/v2/OAuth2-13");
QNetworkRequest request(serverUrl);
request.setHeader(QNetworkRequest::ContentTypeHeader, "application/x-www-form-urlencoded");
QUrl postData;
postData.addQueryItem("grant_type", "client_credentials");
postData.addQueryItem("client_id", ClientID);
postData.addQueryItem("client_secret", ClientSecret);
postData.addQueryItem("scope", "http://api.microsofttranslator.com");
networkAccessManager->post(request, postData.encodedQuery());

当发出 finished(QNetworkReply*) 信号时,我发现服务器回复根本不包含任何数据,它只是空的!有谁知道这个问题的解决方案吗?
UPD我检查了一个错误的回复并得到以下信息:“创建 ssl 上下文时出错”。所以我在我的项目中添加了 SSL 库,但出现了下一个错误 - “未知错误”。有什么想法吗?

【问题讨论】:

  • 您是否已将 OpenSSL dll 复制到您的应用程序目录中?
  • 不,我没有,但我使用 -L[path_to_lib] -l[lib] 将 OpenSSL 库添加到我的项目中

标签: qt qnetworkaccessmanager microsoft-translator


【解决方案1】:

我使用了从 QNetworkAccessManager 继承的这个类来忽略 SSL 错误:

sslqnetworkaccessmanager.h

#ifndef SSLQNETWORKACCESSMANAGER_H
#define SSLQNETWORKACCESSMANAGER_H
#include <QtNetwork>
#include <QtCore>

class SslQNetworkAccessManager : public QNetworkAccessManager
{
    Q_OBJECT
public:
    explicit SslQNetworkAccessManager(QObject *parent = 0);


protected:
    QNetworkReply* createRequest(Operation op, const QNetworkRequest & request, QIODevice * outgoingData = 0);
};

#endif // SSLQNETWORKACCESSMANAGER_H

sslqnetworkaccessmanager.cpp

#include "sslqnetworkaccessmanager.h"

SslQNetworkAccessManager::SslQNetworkAccessManager(QObject *parent)
    : QNetworkAccessManager(parent)
{
}

QNetworkReply* SslQNetworkAccessManager::createRequest(Operation op, const QNetworkRequest& request, QIODevice* outgoingData)
{
    QNetworkRequest req(request);
    QNetworkReply* reply = QNetworkAccessManager::createRequest(op, req, outgoingData);
    reply->ignoreSslErrors();

    return reply;
}

此类重写 createRequest 方法并忽略返回的 QNetworkReply 可能发生的任何 SSL 错误。

【讨论】:

    猜你喜欢
    • 2013-03-06
    • 2019-11-17
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2013-08-22
    相关资源
    最近更新 更多