Ⅰ qt 怎麼使用JSON格式與web通信
你說的發送json格式的字元串,可以直接放到提供介面的地方就可以了,比如%1這個位置或%2這個位置,服務端直接使用JSON來解析就好了。
Ⅱ 用C++寫一個最簡單的web伺服器,qt做界面。要求在界面顯示伺服器連接日誌。 直接把伺服器代碼
如果你是想鏈表和Qt做在同一個進程裡面的話.
把鏈表直接做成 靜態或動態庫 給 Qt調用就可以了.
如果在兩個進程裡面的話就要搞進程間通信也許就要另外開線程了.
Qt做界面可以不用VC的.下個Qt creator 也不錯.
Ⅲ QT如何運用TCP/IP協議與VC程序通信
cp ip協議中 TCP 跟IP 具體作用 TCP是主機到主機層的協議,它負責從上層獲得數據為之分段、編號、排序。而且使用確認機制,窗口機制,保障了數據的安全傳送。就像是郵局的人郵寄包裹的過程! IP是網際網路層協議,負責查看數據包的IP地址,並且通過路由表網路定址,尋找數據到目的主機的最佳路徑。
Ⅳ 誰能給一個 Qt 跟 java 用socket通訊的例子,要求java 做服務端,qt 做客戶端,要求雙方都能實時顯示對方發過
提供一個聊天功能的給你
import java.net.*;
import java.io.*;
class My1 extends Thread
{
private Socket skt;
public My1(Socket skt)
{
this.skt = skt;
}
public void run()
{
try
{
BufferedReader br = new BufferedReader(new InputStreamReader(skt.getInputStream()));
for(;;)
{
if(br.readLine()==null) {break;}
System.out.println(br.readLine()); // 阻塞
}
}
catch(Exception e)
{
System.out.println("對方斷線!");
}
}
}
class My2 extends Thread
{
private Socket skt;
public My2(Socket skt)
{
this.skt = skt;
}
public void run()
{
try
{
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
PrintWriter pw = new PrintWriter(skt.getOutputStream());
for(;;)
{
pw.println("姓名====>:"+br.readLine()); // 阻塞
pw.flush();
}
}
catch(Exception e)
{
System.out.println("對方斷線!");
}
}
}
public class Good
{
public static void main(String[] args) throws Exception
{
//連接的目的是:獲得Socket對象
Socket skt;
System.out.print("請輸入<port> 或者:<ip>,<port> ");
// 先選擇角色
String[] ss = new BufferedReader(new InputStreamReader(System.in)).readLine().split(",");
if(ss.length==1)
skt = new ServerSocket(Integer.parseInt(ss[0])).accept();
else
skt = new Socket(ss[0], Integer.parseInt(ss[1]));
System.out.println("連接到:" + skt.getInetAddress().getHostAddress());
// 連接建立,角色消失
new My1(skt).start(); //讀網路
new My2(skt).start(); //讀鍵盤
}
}
Ⅳ 如何使用 qt+gsoap 調用 webservice
gsoap調用webservice的方法步驟:
生成存客戶端存根程序和框架
wsdl2h -o xxx.h xxx.wsdl(-t D:/gsoap-2.7/gsoap/typemap.dat)
soapcpp2 -L -x -i xxx.h(-I D:/gsoap-2.7/gsoap/import)
2.或直接自己編寫xxx.h,並生成xxx.wsdl
//gsoap ns service name: xxx
//gsoap ns service style: rpc
//gsoap ns service encoding: literal
//gsoap ns service location: ht//localhost:8080
//gsoap ns schema namespace: ht/localhost:8080/xxx.wsdl
int ns__add(int a, int b, int* result);
3.客戶端1) 把如下生成的文件添加到項目:stdsoap2.h,stdsoap2.cpp,soapH.h,soapC.cpp,soapStub.h,soapxxxProxy.h,soapxxxProxy.cpp,xxxSoap.nsmapwsock32.lib
2) 代理方式調用
#include "soapTestWebServiceProxy.h"
#include "Testwww.hbbz08.comWebService.nsmap"
int main(int argc, char* argv[])
{
int result = 0;
TestWebServiceProxy proxy;
proxy.add(12, 23, &result);
} //w
4.服務端
1) 把如下生成的文件添加到項目:
stdsoap2.h,stdsoap2.cpp,
soapH.h,soapC.cpp,soapStub.h,
soapxxxService.h,soapxxxService.cpp,xxxSoap.nsmap
wsock32.lib
2) 實現介面函數
int TestWebServiceService::add(int a, int b, int *result)
{
*result = a+b;
return SOAP_OK;
} /
3) 開啟服務
#include "soapTestWebServiceService.h"
#include "TestWebService.nsmap"
int main(int argc, char* argv[])
{
TestWebServiceService service;
service.run(8080);
Ⅵ 如何評價Qt WebEngine取代Qt Webkit
很遺憾,QtWebkits在Qt5.6以上版本被淘汰了,對於這個介面良且和其他類例如QWebFrame完美結合的組件就這么沒了,我只能表示惋惜。對於QtWebEngine新的組件,不得不承認它從Chromium繼承過來的強大的性能,但介面上還不是很豐富,和其他類的交互也不是很完美,期待Qt能夠對其進行進一步開發,我也會不斷的升級Qt,嘗試新的介面。
目前而言,QWebEngine有以下缺點:
MinGW版本的Qt不支持,即便是Qt5.6版本以上也是不支持的。僅僅支持MSVC版本。
介面暫時不豐富
無法和QWebFrame進行交互(使用了新的QWebChannel和QWebEnginePage組合進行交互)
- #include <QtWebEngineWidgets> // 基本組件#include <QWebEnginePage> // HTML頁面#include <QWebChannel> // C++和JS/HTML雙向通信,代替了已淘汰的QtWebFrame的功能
在WebKits中的初始化:
- QUrl url(strMapPath); // strMapPath為QString類,是你html文件的路徑ui->webView->load(url);
- ui->webView->setContentsMargins(0,0,0,0);
- ui->webView->setTextSizeMultiplier(1);//設置網頁字體大小connect(ui->webView->page()->mainFrame(), SIGNAL(javaScriptWindowObjectCleared()), this, SLOT(()));
- void Widget::()
- {
- ui->webView->page()->mainFrame()->addToJavaScriptWindowObject("ReinforcePC", this);
- }
在WebEngine中的初始化:
- QWebEnginePage *page = new QWebEnginePage(this); // 定義一個page作為頁面管理QWebChannel *channel = new QWebChannel(this); // 定義一個channel作為和JS或HTML交互page->load(strMapPath); // page上載入html路徑page->setWebChannel(channel); // 把channel配置到page上,讓channel作為其信使ui->webEngine->setPage(page); // 建立page和UI上的webEngine的聯系
WebKits組件中的運行JS:
- void Widget::on_pushButtonStreetMap_clicked()
- { QWebFrame *frame = ui->webView->page()->mainFrame(); // 定義一個QWebFrame負責交互
- QString cmd = QString("showStreetMap()"); // JS的命令
- frame->evaluateJavaScript(cmd); // 使用frame下的命令運行該命令}
WebEngine組件中的運行JS:
- void Widget::on_pushButtonSatelliteMap_clicked()
- { QString cmd = "showSatelliteMap()";
- ui->webEngine->page()->runJavaScript(cmd); // 直接page()下就可以運行}
- connect(ui->webEngine,&QWebEngineView::loadFinished,[=](int){
- ui->webEngine->page()->runJavaScript(cmd1);
基於我們的GPS定位項目,參考:[Qt開發北斗定位系統融合網路地圖API及Qt程序打包發布],我們在該項目中使用的是Qt5.5版本,在嵌入的瀏覽器作為載入地圖用的是QWebKits組件,我們將其升級使用QWebEngine進行載入地圖,和HTML和JS進行交互。我們以此為例,進行簡要的介紹。
2. 兩者的UI上面的區別
你剛剛升級到Qt5.6版本可能在UI設計界面時候在組件中找不到QWebEngineView這個組件,無法從這里拖拽這個組件到你的UI界面上。我查閱了很多資料,看到別人經常使用ui->webEngineview->...這樣,我甚至懷疑是否因為安裝了其他版本的Qt影響到了我,我卸載了包含5.6版本的所有Qt,又重新安裝了一遍,但是再重啟軟體後,依然沒有發現QWebEngineView這個鬼東西。在Qt5.5中你也能發現有這樣的組件QWebView,如圖1所示:
有了QWebEngineView這個UI組件,我們可以在程序中調用其成員、方法和函數完成操作了。
3. 使用方法區別
在使用方法上有很大的區別,可以說是兩個完全不同理念的東西,這里為了更通俗易懂,就不粘貼API文檔中函數解釋,就用最常用的!
在我們的項目中一開始就要引入這樣的組件,但在我們的項目中,沒有頻繁用到與JS的互相交互,所以這里暫時沒有關於QWebChannel的使用方法,只留下這個介面。
以下為區別:
我們會使用load方法載入html所在的界面,使用QWebFrame類的mainFrame()中的SIGNAL和槽函數
進行響應。參考文獻1:《javascript調用qt》,可以解釋這個槽函數的重要性。
如果你的 初始化程序寫到這里,當你運行程序的時候,無論是webKits里的WebView還是新版的webEngineView,你的UI界面上的那個組件區域就會顯示那個html文件了。
到此,我們完成了兩者的初始化。
我們以按鈕的槽函數為例,當點擊按鈕時,會向JS發送命令,運行JS腳本,我們這里發送的是將顯示變為衛星圖的JS命令:
從這個例子中我們也可以看到,QWebFrame是JS交互的關鍵。
還是以該槽函數為例:
在JS單向通信中十分簡單,也不需要使用QWebChannel信使,但該方法runJavaScript()無法在構造函數中使用,原因不明。也可以這樣使用:
第二個參數SIGNAL位置的,只能使用這樣的方式調用,如果使用SIGNAL(....loadFinished),報錯。
Ⅶ qt 與c程序怎麼通信
共享內存、管道都是可以的。但其實現在一般來說,沒有特殊的理由的話,socket是進程間通信的首選。c部分添加發送數據的模塊,qt用一個線程來監聽,收到數據就觸發一個signal, 界面(主線程)的一個slot接受這個signal並更新顯示。
Ⅷ 如何利用 QT 進行 web 與本地混合應用開發
如何利用 QT 進行 web 與本地混合應用開發是本文要講述的內容,Qt提供了本地 C++對象與JavaScript的無縫集成,是進行本地與web混合應用開發的理想平台。
一、Qt Webkit 集成
利用Qt的Webkit 集成與QtNetwork模塊,你完全可以進行本地桌面與web混合應用開發,你可以自由地混合JavaScript,樣式表,Web內容和Qt組件。 Webkit是一個非常成熟的web瀏覽引擎。Qt中集成了這個大名鼎鼎的引擎,通過QtWebkit,你可以在C++ 中執行JavaScript,或者在網頁中集成C++對象,並且通過JavaScript和這些對象進行交互。
一個現代的HTML渲染引擎只 是混合開發的一半,另一半就是本地應用和渲染對象的交互。QT的Webkit 集成提供了這種解決方案:
1.使用object標簽嵌入Qt Widgets組件。這可以讓使用C++代碼的Qt組件包含在網頁中,作為網頁的部分外觀。
2.在JavaScript中訪問C++對象。你 可以在JavaScript環境中插入C++對象,讓網頁腳本直接訪問你的數據結構。
3.在Qt中執行JavaScript。你可以在C++ 調用網頁環境中的JavaScript函數,觸發網頁事件。
4.共享客戶端存儲。在JavaScript和C++中你都具有訪問資料庫的能 力,這樣當下線時也能共享大量數據。
二、與嵌入的Qt對象交互
使用 QWebView 組件,有兩種方法可以在網頁中嵌入C++對象。你可以在網頁的JavaScript中添加C++對象,或者也可以創建一個插件,然後在網頁中使用 object標簽嵌入。
第二種方法更容易入手。當在網頁中放入 Widget組件時,它的所有public slots就像普通函數一樣被網頁中的JavaScript函數訪問。
要在網頁中添加一個Widget,首先要告訴你的QWebPage對象,該Widget可用,這個通過子類化QWebPlugFactory完成,
你需要 重新實現兩個方法:plugs和create。plugs方法通知網頁該Widget可用,create方法根據請求創建widget。
在 HTML網頁中,widgets使用object標簽創建。比如,下面這個標簽試圖創建一個 application/x-qt-colorlabel組件。
<object type="application/x-qt-colorlabel" width="50px" height="20px" id="label" />
要利用這種創建,必須要允許使用插件並且要告訴QWebpage插件的工廠類。在下面的代碼中,ColorLabelFactory將 會根據application/x-qt-colorlabel的請求創建相應實例。
QWebSettings::globalSettings()->setAttribute(QWebSettings::PluginsEnabled, true); webView->page()->setPluginFactory(new ColorLabelFactory(this));
ColorLabel有一個公開的slot: chagneColor(),這個對於網頁中的JavaScript自動可用。在網頁中插入一個指向該元素的鏈接,可以以一種簡單的方式激活C++函數。
<a href='javascript:document.getElementById("label").changeColor();'>Change color!</a>
要反方向推進事件,必須要使你的對象在JavaScript文檔上下文中可用。要對QWebPage的每一個 QWebFrame,調用addToJavaScriptWindowObject方法。這個方法允許你根據名字把一個對象添加到JavaScipt上下 文中。
webView->page()->mainFrame()->addToJavaScriptWindowObject( "eventSource", new eventSource( this ) );
要連接剛添加對象eventSource的信號,要加上一段JavaScript代碼,使用evaluateJavaScript方法
完成。下面的代碼將把eventSource對象的signalName信號連接到一個JavaScript函數destFunction。
webView->page()->mainFrame()->evaluateJavaScript( "eventSource.signalName.connect(destFunction);" );
如果你把一個對象添加到一個以標准瀏覽器查看的JavaScript頁面中,有一個信號需要知道。每一次JavaScript
內容被清除,Frame都會釋放 javaScriptWindowObjectCleared
信號。為了使你的Qt對象一直可用,你需要連接這個信號,並且在這里調用 addToJavaScriptWindowObject函數。
Ⅸ qt和外部c程序通信問題
1. 使用共享內存,兩個不同進程訪問這個內存區,A進程把buf數據存放到共享內存中,B進程直接訪問讀取。
2. 寫一個TCP通信,A進程把buf數據通過socket,發送到B進程。B進程接收到數據數據後,進行後續操作。