51.Qt-使用ajax獲取ashx接口的post數據

因爲當前C++項目須要使用ajax庫去post調用ashx接口,接口地址以下所示:html

 

須要傳遞的參數以下:ajax

 

而後發現qml比較好調用ajax.js庫,因此本章經過C++界面去獲取qml方法來實現調用ashx接口(以一個C++界面demo程序爲例)json

 

 1.抓post數據app

經過網頁獲取到的post數據以下所示:函數

 

因此查詢20191121~20191122期間時則填入內容: "deptCode=021&startDate=20191121&endDate=20191122"post

2.導入ajax.js庫ui

ajax.js文件以下所示:this

// GET
function get(url, success, failure)
{
    var xhr = new XMLHttpRequest;
    xhr.open("GET", url);
    xhr.onreadystatechange = function() {
        handleResponse(xhr, success, failure);
    }
    xhr.send();
}

// POST
function post(url, arg, success, failure)
{
    var xhr = new XMLHttpRequest;
    xhr.open("POST", url);
    xhr.setRequestHeader("Content-Length", arg.length);
    xhr.setRequestHeader("Content-Type", "application/x-www-form-urlencoded;");  //用POST的時候必定要有這句
    xhr.onreadystatechange = function() {
        handleResponse(xhr, success, failure);
    }
    xhr.send(arg);
}

// 處理返回值
function handleResponse(xhr, success, failure){
    if (xhr.readyState == XMLHttpRequest.DONE) {
        if (xhr.status ==  200){
            if (success != null && success != undefined)
            {
                var result = xhr.responseText;
                try{
                    success(result, JSON.parse(result));
                }catch(e){
                    success(result, {});
                }
            }
        }
        else{
            if (failure != null && failure != undefined)
                failure(xhr.responseText, xhr.status);
        }
    }
}

3.寫main.qmlurl

import QtQuick 2.3
import QtQuick.Window 2.2
import "ajax.js" as Ajax
Item {
    
    function getWrenchTools(deptCode,startDate,endDate) {
        console.log("Got message:", deptCode,startDate,endDate) //打印參數數據

Ajax.post("http://10.194.102.253/WLPTService/Pages/Tools/GetNLToolsByDeptCode.ashx","deptCode="+deptCode+"&startDate="+startDate+"&endDate="+endDate+"",
                  Widget.invokeFunc);

}

這裏表示定義一個getWrenchTools()方法,當post成功並返回數據時,則調用Widget.invokeFunc()回調函數(Widget: 該qml對應的C++類,後面會講怎麼捆綁的)spa

 

4.widget界面以下

 

而後寫widget.h

#ifndef WIDGET_H
#define WIDGET_H
 
#include <QWidget>
#include <QString>
#include <QDebug>
#include <QTimer>
#include <QQmlApplicationEngine>
#include <QQmlComponent>
namespace Ui {
class widget;
}
 
class widget : public QWidget
{
    Q_OBJECT
 
    QQmlApplicationEngine engine;
    QObject *engineObject;      //指向運行的qml對象
 
public:
    explicit widget(QWidget *parent = 0);
    ~widget();
 
private:
    Ui::widget *ui;
 
public:
     Q_INVOKABLE void invokeFunc(QVariant data1,QVariant data2);   
 
private slots:
    void on_pushButton_clicked();
};
 
#endif // WIDGET_H

寫widget.cpp

#include "widget.h"
#include "ui_widget.h"
#include <QTimer>
#include <QQmlContext>
widget::widget(QWidget *parent) :
    QWidget(parent),
    ui(new Ui::widget)
{
 
    ui->setupUi(this);
 
    engine.rootContext()->setContextProperty("Widget",this);
    //將QML中的Widget變量指向爲當前類.從而使QML和widget類鏈接起來
 
    engineObject = QQmlComponent(&engine, "qrc:/main.qml").create();        //建立qml並獲取運行中的qml對象
}
 
widget::~widget()
{
    delete ui;
}
 
 
void widget::invokeFunc(QVariant data1,QVariant data2)
{
    ui->plainTextEdit->setPlainText(data1.toString());
 
}
 
void widget::on_pushButton_clicked()
{
     QVariant depatment= "021";
     QVariant start= ui->start->text();
     QVariant end = ui->end->text();    //"結束日期"
 
     QMetaObject::invokeMethod(engineObject, "getWrenchTools",Q_ARG(QVariant, depatment)\
                             ,Q_ARG(QVariant, start),Q_ARG(QVariant, end));
 
}
  • engine.rootContext()->setContextProperty("Widget",this)的做用:
將QML中的Widget變量指向爲當前類.從而使QML和widget類鏈接起來, 而後main.qml若是post成功則調用當前類的invokeFunc(QVariant data1,QVariant data2)方法,從而實現數據返回.
  • 當按下同步按鈕時,則調用on_pushButton_clicked():

因爲engineObject指向運行中的qml對象,而後咱們經過invokeMethod()就能夠方便的請求調用qml對象中的getWrenchTools()函數.從而實現post請求

 

點擊同步後,效果以下所示(而後可參考50.Qt-QJsonDocument讀寫json來提取數據):

相關文章
相關標籤/搜索