前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Qt翻译api封装

Qt翻译api封装

作者头像
Qt君
发布2023-11-26 14:54:38
1490
发布2023-11-26 14:54:38
举报
文章被收录于专栏:跟Qt君学编程跟Qt君学编程

  简单的几行实现封装翻译api接口,只需要填上对应的appid,key(密钥),和翻译的字段(text)即可。希望对大家有帮助。

代码语言:javascript
复制
static QByteArray createSign(const QByteArray &text, const QByteArray &appid, const QByteArray &key, const QByteArray &salt)
{
    return QCryptographicHash::hash(appid+text+salt+key, QCryptographicHash::Md5).toHex();
}

QByteArray appid = "389283589"; 
QByteArray key   = "12345678"; // 密钥
QByteArray text  = "apple";   // 需要翻译的文本
QByteArray salt  = QByteArray::number(QDateTime::currentSecsSinceEpoch());
QByteArray sign  = createSign(text, appid, key, salt);

static HttpClient client;
client.get("http://api.fanyi.baidu.com/api/trans/vip/translate")
      .queryParam("from",  "en") // 英文类型
      .queryParam("to",    "zh") // 翻译中文
      .queryParam("q",     text)
      .queryParam("appid", appid)
      .queryParam("salt",  salt)
      .queryParam("sign",  sign)
      .onSuccess([](QJsonObject result) { qDebug().noquote()<<result; })
      .onFailed([](QByteArray error) { qDebug()<<error; })
      .exec();
// 输出打印:
// QJsonObject({"from":"en","to":"zh","trans_result":[{"dst":"苹果","src":"apple"}]})

本文代码使用到下列使用了head-only实现的Http客户端库:https://github.com/aeagean/QtNetworkService

Qt开源网络库[1]-介绍

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2023-11-23,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 Qt君 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档