当前位置: 首页 > news >正文

QT C++ QWebEngine与Web JS之间通信

Qt 与 Web 通信指南(QWebEngineView + QWebChannel)

概览

  • 目标:让网页 JavaScript 与 Qt 客户端进行双向通信(调用本地方法、通知 UI)。
  • 技术栈:Qt WebEngineWidgets + Qt WebChannel + JavaScript qwebchannel.js
  • 适用场景:在 QWebEngineView 内嵌外部或内部网页,并需要与桌面端交互。

通信模型

  • Qt 暴露一个 QObject(如 WebBridge),注册到 QWebChannel
  • Web 端通过 qwebchannel.js 获得该对象(例如 bridge),直接调用其 slot 方法。
  • Qt 端通过 signals 向 UI 或其他模块转发事件,或主动调用 evaluateJavaScript 与 Web 交互。

快速集成步骤

  1. 引入依赖并链接:
    • CMake:
      find_package(Qt6 REQUIRED COMPONENTS WebEngineWidgets WebChannel)
      target_link_libraries(QuantClient PRIVATE Qt6::WebEngineWidgets Qt6::WebChannel)
      
  2. 实现桥对象(Qt → Web 暴露):
    • src/gui/web/WebBridge.h / src/gui/web/WebBridge.cpp
    • 暴露 slot,在需要处 emit 信号给 UI 层。
  3. QWebEngineView 完成加载前注册通道:
    • webView->page()->setWebChannel(channel);
  4. Web 端加载 qwebchannel.js 并初始化通道,获取 bridge 对象进行调用。

Qt 侧代码示例

// StrategyPerformanceDialog.cpp(片段)
QWebChannel* channel = new QWebChannel(this);
WebBridge* bridge = new WebBridge(this);
channel->registerObject(QStringLiteral("bridge"), bridge);
webView->page()->setWebChannel(channel);
QObject::connect(bridge, &WebBridge::openStrategyDetailRequested, this, &StrategyPerformanceDialog::onStrategyDetailRequested);
// WebBridge.h(片段)
class WebBridge : public QObject {Q_OBJECT
public:explicit WebBridge(QObject *parent = nullptr);
public slots:void refreshStrategyData();void openStrategyDetail(const QString &strategyId);
signals:void openStrategyDetailRequested(const QString &strategyId);
};
// WebBridge.cpp(片段)
void WebBridge::openStrategyDetail(const QString &strategyId) {emit openStrategyDetailRequested(strategyId);
}

Web 侧代码示例

页面可改(直接在 HTML 中)

<script src="qrc:///qtwebchannel/qwebchannel.js"></script>
<script>new QWebChannel(qt.webChannelTransport, function(channel) {const bridge = channel.objects.bridge;bridge.refreshStrategyData();bridge.openStrategyDetail("strategy_123");});
</script>

页面不可改(Qt 侧注入)

// 加载完成后动态注入脚本
connect(webView, &QWebEngineView::loadFinished, this, [webView](bool){webView->page()->runJavaScript(R"((function(){var s=document.createElement('script');s.src='qrc:///qtwebchannel/qwebchannel.js';s.onload=function(){new QWebChannel(qt.webChannelTransport,function(c){window.bridge=c.objects.bridge;});};document.head.appendChild(s);})();)");
});

预注入(更稳,文档创建阶段)

QWebEngineScript script;
script.setName(QStringLiteral("qwebchannel-loader"));
script.setInjectionPoint(QWebEngineScript::DocumentCreation);
script.setWorldId(QWebEngineScript::MainWorld);
script.setRunsOnSubFrames(true);
script.setSourceCode(QStringLiteral("(function(){var s=document.createElement('script');" "s.src='qrc:///qtwebchannel/qwebchannel.js';" "s.onload=function(){new QWebChannel(qt.webChannelTransport,function(c){window.bridge=c.objects.bridge;});};" "document.head.appendChild(s);})();"
));
webView->page()->scripts().insert(script);

常见问题与排错

  • 链接错误:Undefined symbols for architecture arm64 → 未将 WebBridge.cpp 加入构建或未链接 Qt6::WebChannel
  • 头文件找不到:'config/AppConfig.h' file not found#include 相对路径错误,从 src/gui/mainwindowsrc/gui/config 需用 ../config/AppConfig.h
  • qwebchannel.js 加载失败:确保使用 qrc:///qtwebchannel/qwebchannel.js,并已链接 Qt6::WebChannel
  • JS 不生效:确认已调用 webView->page()->setWebChannel(channel),且对象名与 JS 一致(如 bridge)。

安全与最佳实践

  • 只暴露必要的 slot,在 Qt 侧校验参数与权限。
  • 对外部页面建议使用注入方式并限制可用接口。
  • 使用明确的对象名与命名空间,避免冲突。

扩展能力

  • Qt → Web 主动调用:webView->page()->runJavaScript("doSomething()")
  • Web → Qt 回调返回值:QWebEnginePage::runJavaScript 支持回调函数拿到执行结果。
http://www.dtcms.com/a/601051.html

相关文章:

  • 华为防火墙web配置SSL-在外人员访问内网资源
  • 本地部署事务管理软件 JIRA 并实现外网访问(Windows 版本)
  • 18、Linux常用命令-磁盘分区相关命令
  • nvm与node.js的安装指南
  • python+django/flask+vue的书城图书阅读器系统,亮点含目录章节pycharm
  • 外贸cms什么意思seo海外推广
  • C++网络开发---CURL与CURLcode数据类型
  • 【Python数据分析】数据分析与可视化
  • MyBatis概述
  • Hadoop集群搭建(下):centos 7为例(已将将安装所需压缩包统一放在了/opt/software目录下)
  • 美创网站建设优势开县网站制作
  • 北京市网站建设网站怎么盈利的
  • 2.6、安全大脑:AI驱动的安全编排与自动化响应实战
  • Linux 进程间通信怎么选?——场景化决策指南
  • 折800网站源码石家庄新闻发布会
  • ThreadLocal 中弱引用(WeakReference)设计:为什么要 “故意” 让 Key 被回收?
  • Java大厂面试真题:从Spring Boot到AI微服务的三轮技术拷问
  • es开源小工具 -- 分析器功能
  • MQTT 与双工通信
  • 【.NET10】正式发布!微软开启智能开发生态新纪元
  • Linux 魔法:多种空块填充技术详解与实践
  • 深入浅出 SQLSugar:快速掌握高效 .NET ORM 框架
  • 广东哪家网站建网站搜索不到公司网站
  • 做网站开发需要学什么app开发自学教程
  • 【Linux】网络编程入门:从一个小型回声服务器开始
  • 【统一功能处理】从入门到源码:拦截器学习指南(含适配器模式深度解读)
  • linux 解析并生成一个platform_device设备具体过程
  • 编译器使用的开发语言 | 解析编译器的实现原理及其开发语言的选择
  • 佛山企业网站建设流程织梦营销型网站模板
  • 洛谷 P11965:[GESP202503 七级] 等价消除 ← 位运算(异或) + STL map