QT连接腾讯云数据库,并查询、更新数据(C++、微信小程序管理端程序)

(前提是你已经有了腾讯云数据库哦)
新建QT工程不多说
在.pro文件中加入
QT += network
在.h文件中加入头文件

#include <QTimer>
#include <QtNetwork>

腾讯微信小程序开发文档中对获取小程序全局唯一后台接口调用凭据(access_token)的描述为

请求地址

GET https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=APPID&secret=APPSECRET
属性类型说明
grant_typestring只能填client_credential
appidstring小程序唯一凭证,即 AppID,可在「微信公众平台 - 开发管理 - 开发设置」页中获得。
secretstring小程序唯一凭证密钥,即 AppSecret,获取方式同 appid(第一次使用一定要重置!注意不是登录密码,就是AppSecret)

在这里插入图片描述
使用微信公众平台接口调试工具调试显示成功即可。
在这里插入图片描述

属性类型说明
access_tokenstring获取到的凭证
expires_innumber凭证有效时间,单位:秒。目前是7200秒一次。
errcodenumber错误码
errmsgstring错误信息

因为需要http访问,我们使用QNetworkAccessManager完成访问数据操作的控制。
在.h中定义

signals:
    bool managerLoaded(bool);

private slots:
    void initial();
    void getAccess_token();
    void slotGetAccess_token();
    QString getAccess_Token();
    void managerLoad(QString account,QString pw);
    QString slotManagerLoad();
    QJsonObject getManagerInfo();
    void on_select_clicked();
    void on_initial_clicked();
    void getNetImage(QString imageName, QString imageUrl);
    void slotGetImage(QNetworkReply* r);
    void imageLoaded(QPixmap pixmap, QString imageName);
private:
    QNetworkAccessManager *manager;
    QNetworkRequest *request;//网络请求的URL,Header参数等信息
    QNetworkReply  *reply;//获知网络操作中的各种状态。当QNetworkReply发出readyRead()信号后,获取应答对象中的数据。
    QTimer *timer = new QTimer(this);//自动获取最新凭证
    QString Access_Token;//调用凭证
    int Access_Token_expries;//剩余凭证有效时间
    QJsonObject managerObject;//由于小程序的云数据库中数据为JSON数据包,因此使用QJsonDocument来对获取的数据进行处理
void MainWindow::initial()
{
    manager = new QNetworkAccessManager(this);
    request = new QNetworkRequest();
    getAccess_token();
    connect(timer, SIGNAL(timeout()), this, SLOT(getAccess_token()));
    timer->start(Access_Token_expries);
}
void MainWindow::getAccess_token()
{
    request->setUrl(QUrl(tr("https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=%1&secret=%2").arg(appid,secret)));//appid,secret参数为小程序AppID,AppSecret
    request->setHeader(QNetworkRequest::ContentTypeHeader,"application/json; encoding=utf-8");
    reply = manager->get(*request);
    connect(reply,SIGNAL(readyRead()),this,SLOT(slotGetAccess_token()));
}
 
void MainWindow::slotGetAccess_token()
{
    QByteArray ba = reply->readAll();
    QJsonDocument js = QJsonDocument::fromJson(ba);
    Access_Token = js["access_token"].toString();
    Access_Token_expries = js["expires_in"].toInt()-200;//为了提前更新凭证,提前200S
    timer->setInterval(Access_Token_expries*1000);
}
 
QString MainWindow::getAccess_Token()
{
    return Access_Token;//返回获取到的Access_Token值
}

腾讯微信小程序开发文档中对数据库查询记录描述为:
请求地址

POST https://api.weixin.qq.com/tcb/databasequery?access_token=ACCESS_TOKEN
属性类型说明
access_tokenstring接口调用凭证
envstring云环境ID
querystring数据库操作语句

因为需要POST发送数据,我们使用QNetworkAccessManager完成访问数据操作的控制。使用QJsonObject处理需要发送的data数据(JSON)。

void MainWindow::managerLoad(QString account,QString pw)
{
        request->setUrl(QUrl(tr("https://api.weixin.qq.com/tcb/databasequery?access_token=%1").arg(Access_Token)));
        QString query = tr("db.collection('login').where({_id: '%1',password: '%2'}).get()").arg(account,pw);//login为查询的数据集,_id和password为数据集字段,此行会获取符合条件的整个数据集
        QString env = "cloud1";//env为自己小程序云数据库的云环境ID,可在云开发控制台中找到
        QJsonObject obj
        {
            {"query",query},//query为微信小程序云数据库的查询语句,云数据库介绍可查看微信官方文档中的介绍。
            {"env",env}
        };
        QByteArray objBy = QJsonDocument(obj).toJson();//将JSON对象obj用QJsonDocument转为QByteArray字节数组,当QNetworkReply发出readyRead()信号后,获取应答对象中的数据。
        reply = manager->post(*request,objBy);
        connect(reply,SIGNAL(readyRead()),this,SLOT(slotManagerLoad()));
}

void MainWindow::slotManagerLoad()
{
    QByteArray ba = reply->readAll();
    QJsonDocument js = QJsonDocument::fromJson(ba);
    int totalInt = js["pager"].toObject()["Total"].toInt();
    QJsonValue dataValue = js["data"].toArray().first();
    qDebug()<<dataValue;
    QString dataStr = dataValue.toString();//读取到的数据
    managerObject = QJsonDocument::fromJson(dataStr.toUtf8()).object();//data数据转为Object
    if(totalInt != 0)
    {
        emit managerLoaded(true);
    }else
    {
        emit managerLoaded(false);
    }
}
 
QJsonObject MainWindow::getManagerInfo()
{//返回从服务器中获得的数据库内容
    return managerObject;
}

查询到的表单如下所示,做用find函数和substr函数做字符解析即可(或者使用正则匹配方法更合适):
在这里插入图片描述
更新数据:
只需要修改url地址,使用update语句,获取记录id即可,其余不变

request->setUrl(QUrl(tr("https://api.weixin.qq.com/tcb/databaseupdate?access_token=%1").arg(Access_Token)));
QString isok = tr("db.collection('Entrust').doc('%1').update({"
                        "data: {"
                          "'publish': true"
                        "},"
                      "})").arg(id);
  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值