当前位置:首页 » 网页前端 » qt程序与web程序通信
扩展阅读
webinf下怎么引入js 2023-08-31 21:54:13
堡垒机怎么打开web 2023-08-31 21:54:11

qt程序与web程序通信

发布时间: 2022-08-02 10:44:38

Ⅰ 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的方法步骤:

  1. 生成存客户端存根程序和框架

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组合进行交互)

  • 基于我们的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文档中函数解释,就用最常用的!

  • #include <QtWebEngineWidgets> // 基本组件#include <QWebEnginePage> // HTML页面#include <QWebChannel> // C++和JS/HTML双向通信,代替了已淘汰的QtWebFrame的功能

  • 在我们的项目中一开始就要引入这样的组件,但在我们的项目中,没有频繁用到与JS的互相交互,所以这里暂时没有关于QWebChannel的使用方法,只留下这个接口。

    以下为区别:

  • 在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(()));

  • 我们会使用load方法加载html所在的界面,使用QWebFrame类的mainFrame()中的SIGNAL和槽函数

  • void Widget::()

  • {

  • ui->webView->page()->mainFrame()->addToJavaScriptWindowObject("ReinforcePC", this);

  • }

  • 进行响应。参考文献1:《javascript调用qt》,可以解释这个槽函数的重要性。

  • 在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里的WebView还是新版的webEngineView,你的UI界面上的那个组件区域就会显示那个html文件了。

    到此,我们完成了两者的初始化。

  • WebKits组件中的运行JS:

  • 我们以按钮的槽函数为例,当点击按钮时,会向JS发送命令,运行JS脚本,我们这里发送的是将显示变为卫星图的JS命令:

  • void Widget::on_pushButtonStreetMap_clicked()

  • { QWebFrame *frame = ui->webView->page()->mainFrame(); // 定义一个QWebFrame负责交互

  • QString cmd = QString("showStreetMap()"); // JS的命令

  • frame->evaluateJavaScript(cmd); // 使用frame下的命令运行该命令}

  • 从这个例子中我们也可以看到,QWebFrame是JS交互的关键。

  • WebEngine组件中的运行JS:

  • 还是以该槽函数为例:

  • void Widget::on_pushButtonSatelliteMap_clicked()

  • { QString cmd = "showSatelliteMap()";

  • ui->webEngine->page()->runJavaScript(cmd); // 直接page()下就可以运行}

  • 在JS单向通信中十分简单,也不需要使用QWebChannel信使,但该方法runJavaScript()无法在构造函数中使用,原因不明。也可以这样使用:

  • connect(ui->webEngine,&QWebEngineView::loadFinished,[=](int){

  • ui->webEngine->page()->runJavaScript(cmd1);

  • 第二个参数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进程接收到数据数据后,进行后续操作。