qt嵌入浏览器(六)——qcefview实现js通信接口

author author     2023-03-27     779

关键词:

参考技术A

上一节中,我们完成了CEF各基本组件的封装,并完成了浏览器基本功能的实现。 >>点这里回顾上节内容

本节我们将尝试扩展所实现的各组件,实现浏览器与页面的双向通信。

本篇的小目标:

上一节曾提到过,CEF应用在默认情况下包含很多子进程,这些进程会共享同一个执行入口。除了主进程的各类处理接口外,CEF还提供了各类子进程的处理接口。而 页面到浏览器的消息通道 就可以借助对 渲染进程 的控制来实现,整体流程如下:

完成上述步骤后,在页面调用对应的消息通道函数时,V8处理器则会相应地进行处理,从而完成消息的发送。

另一方面,实现 浏览器到页面 的消息通道和第二节中基于Qt WebEngine的方法类似,CEF也提供了执行JS脚本的方法,只需在页面中定义好对应的消息接口,并通过执行脚本方法执行该接口即可完成消息的发送。

因此,实现双向通道主要的问题集中在针对渲染进程处理和JS脚本执行的扩展上。接下来先就渲染进程处理进行说明。

为了实现对渲染进程的处理,我们首先需要向上一节中封装的QCefContext中添加对渲染进程入口的解析和处理。具体实现如下:

上面的实现除了处理了CEF主进程外,还判断了子进程是否为渲染进程(Windows环境下的renderer进程和Linux环境下的zygote进程),如果发现当前处理的是渲染进程,则创建一个渲染进程处理器QCefRenderHandler的实例。QCefRenderHandler的声明如下:

和主进程CefApp的实现类似,这里也实现了CefApp接口,此外额外实现了CefRenderProcessHandler接口的OnContextCreated方法,来获取V8上下文的引用,具体实现如下:

上面的实现将sendMessage函数定义为消息通道,并注册到了window对象上。sendMessage函数的具体实现则放在v8Handler的实现中。QCefV8Handler声明如下:

QCefV8Handler通过实现CEF V8处理器的Execute执行方法,完成对所加载的JS函数的过滤,并进行相应的处理,实现如下:

这里首先对函数名和参数进行了校验,之后调用CefBrowser的IPC方法SendProcessMessage向主进程的CefClient发送消息,从而完成页面向浏览器主进程消息的传递。

要实现页面到浏览器的消息通道,除了完成了上面渲染进程的控制扩展,我们还需要在QCefClient中添加接收IPC消息的接口实现。首先在QCefClient头文件中声明对CefClient接口的重载:

然后实现这个接口,完成消息的接收处理:

可以看到这里只是对收到的消息进行了简单的转换,并通过信号发送给感兴趣的下游控件使用。在第四小节的实现中,我们将QCefClient封装到了QCefView中,因此在QCefView中也需要将这个信号转发给它的下游控件:

这样,QCefView接收JS消息的通道就实现完成了。

这里额外讲解一下有关js alert的特殊处理。要实现js调用alert方法时的弹窗提醒,需要额外在CefClient中实现CefJSDialogHandler接口的OnJSDialog方法,参考实现如下:

承前所述,浏览器到页面的消息发送通过CEF的JS脚本执行接口实现。首先在QCefView中,声明并实现一个执行JS脚本的方法:

然后指定一个特定的JS方法,作为消息通道使用:

如此,QCefView发送JS的通道也实现完成了。

完成了消息通道的实现,接下来我们实际使用一下我们定义好的消息通道。

首先是Qt端的实现,在MainDlg的initWebView方法中,添加对JS消息的监听,并将监听到的消息通过QMessageBox显示出来:

然后添加文本输入和发送按钮,并在按钮点击信号对应的槽中调用QCefView的消息发送方法:

接下来在页面端实现消息接收和发送的接口msgutils.js:

可以看到这里我们使用了上面定义的recvMessage和sendMessage两个函数。然后在页面上调用这些接口:

实际运行一下浏览器,并加载我们实现的这个页面,消息发送效果如下:

有关CEF消息通道的讲解就先进行到这里。下一节将分析使用CEF接口实现Https双向认证的方法。

>>返回系列索引

[1] Chromium Embedded Framework官网
[2] Chromium Embedded Framework官方教程

qtvs2022使用qcefview控件与html通信(代码片段)

...0c;太难理解了;偶然间,在网上看到有QT第三方库QCefView,这个库封装了cef3,使得可以很简单的在桌面应用加载显示html,并与其进行通信;经过几天的调研,现在将调研结果记录下来!目录前言一... 查看详情

编译qcefview+vs2019+qt5.15.2(代码片段)

目录一 编译结果二 编译要点 三 cmake部署qt方法四 参考链接一 编译结果链接:https://pan.baidu.com/s/1ehk2cD8xnWqLihROxi9ZsQ 提取码:gwi1  二 编译要点找到子模块,并安装cef库库链接:CEFAutomatedBuilds最后运行:ge... 查看详情

qcefview:一个集成了cef的qtwidget

QcefView:一个集成了CEF的QtWidget官方网址:http://tishion.github.io/QCefView/Github地址:https://github.com/tishion/QCefViewQCefView是一个与ChromiumEmbeddedFramework集成的Qt小部件。 您可以使用QCefView而无需编写任何与CEF代码相关的代码。 这 查看详情

关于qcefview的一些事

不知不觉QCefView这个项目已经诞生7年多了,自从开源这个项目之后我也没有做过相关的介绍和宣传。这些年我通过业余时间不断优化重构,修复缺陷,扩展项目的支持边界,从最初只能在Windows平台上基于Qt框架开... 查看详情

关于qcefview的一些事

不知不觉QCefView这个项目已经诞生7年多了,自从开源这个项目之后我也没有做过相关的介绍和宣传。这些年我通过业余时间不断优化重构,修复缺陷,扩展项目的支持边界,从最初只能在Windows平台上基于Qt框架开... 查看详情

关于qcefview的一些事

不知不觉QCefView这个项目已经诞生7年多了,自从开源这个项目之后我也没有做过相关的介绍和宣传。这些年我通过业余时间不断优化重构,修复缺陷,扩展项目的支持边界,从最初只能在Windows平台上基于Qt框架开... 查看详情

在 python QT GUI 中嵌入 Chrome 浏览器?

】在pythonQTGUI中嵌入Chrome浏览器?【英文标题】:EmbeddingChromebrowserinpythonQTGUI?【发布时间】:2016-04-2016:14:40【问题描述】:我有一个使用Seleium打开Chrome窗口的pythonGUI。PyQTGUI中有没有办法嵌入Chrome浏览器的窗口,所以没有2个单独... 查看详情

qtvs2022使用qcefview控件与html通信(代码片段)

...0c;太难理解了;偶然间,在网上看到有QT第三方库QCefView,这个库封装了cef3,使得可以很简单的在桌面应用加载显示html,并与其进行通信;经过几天的调研,现在将调研结果记录下来!目录前 查看详情

如何将pdf.js嵌入fancybox

...实现效果不佳,因为支持、外观和感觉取决于操作系统、浏览器和adobe安装。PDF.js通过使用基于Web标准的平台来解析和呈现PDF来解决这个问题。如何在fancybox中嵌入pdf.js查看器?【问题讨论】:【参考方案1】:这是我 查看详情

web页面嵌入到qt注意事项

参考技术A目前,web页面嵌入Qt框架方式:Qt:系统、一级、二级菜单框架;底部消息栏。Web:三级菜单子页面。开发方式:在web环境下开发完成后,将单独页面嵌入到qt中,html、js等文件都作为资源加入到qt工程中。1、html页面中... 查看详情

react学习案例六

...例六,主要是使用ReactDOM中的render函数来实现元素的嵌入的操作,这里是嵌入了一个组合的标签(html),但是需要注意的是多个html标签同时嵌入的时候,必须要注意放在一个div下面,否则是无法 查看详情

用qt写软件系列六:博客园客户端的设计与实现(用fiddler抓包,用curl提交数据,用htmlcxx解析html)

引言    博客园是本人每日必逛的一个IT社区。尽管博文以.net技术居多,但是相对于CSDN这种业务杂乱、体系庞大的平台,博客园的纯粹更得我青睐。之前在园子里也见过不少讲解为博客园编写客户端的博文。不过... 查看详情

qt嵌入网页(代码片段)

Qt嵌入网页1.QWebEngineView使用pro文件:Qt+=webenginewidgets头文件:#include<QWebEngineView>、#include<QWebEngineSettings>使用:voidWidget::initWebview()//创建QWebEngineView,会有一个独立窗口QWebEngineView*web=newQWebEngineView();//打... 查看详情

qt界面中嵌入其他exe程序的界面,使用qt5

下面用一个小例子来演示如何在Qt的界面中嵌入其他exe程序的界面,最终效果如下图所示。本文参考了http://blog.csdn.net/jiaoyaziyang/article/details/49802993,感谢原作者。   下面是具体的实现方法,用Windows自带的计算器程序... 查看详情

shine.js实现动态阴影效果

...关系,AMD兼容使用基于内容的文本或框阴影   4、在浏览器支持textShadow或boxShadow会自己主动加入前缀效果图例如以下:  代码引用及编写:嵌入js文件<scriptsrc= 查看详情

javascript(浏览器模型/window对象/iframe)(代码片段)

JavaScript(六)(浏览器模型/window对象/iframe)文章目录JavaScript(六)(浏览器模型/window对象/iframe)八、浏览器模型54.浏览器环境概述54.1代码嵌入网页的方法54.1.1script元素嵌入代码54.1.2script元素加... 查看详情

jsjquery

JS介绍​JavaScript,简称JS​JS是一门嵌入在浏览器中执行的脚本语言(一段小程序)​主要作用:用于实现网页中的动画效果和实现表单验证​JS可以运行在服务器端(Node.js)JS的特点​JS是一门直译式的语言(JS不需要编译,执行... 查看详情

qt5.9.1结合ref开发基于chorm的浏览器

下载cef3的源码cef简介  嵌入式Chromium框架(简称CEF)是一个由MarshallGreenblatt在2008建立的开源项目,它主要目的是开发一个基于GoogleChromium的Webbrowser控件。CEF支持一系列的编程语言和操作系统,并且能很容易地整合到新的或已有的... 查看详情