Qt实现网页与本地应用(QWebEngine应用)之间的通讯(QWebChannel的使用)_qwebengineview 跨域注入qwebchannel(1)

收集整理了一份《2024年最新物联网嵌入式全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升的朋友。
img
img

如果你需要这些资料,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人

都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!


bridge = channel.objects.channelObject;

bridge.fromLocalToWebPage.connect(function (response) {    
                     alert(“received message from local:”+response);
                   });

});
       }
function fromWebToCpp(){

bridge.fromWebPageToLocal(“123456”);
            }
 
 
  <input id=“add” type=“button” value=“msFromWebToCpp” class=“button” οnclick=“fromWebToCpp();”/>
 

四、效果图,运行后点击网页端的按钮1,网页端会给本地传送2的123456,然后触发信号3,接着网页端会收到4显示的字符串fromLocalToWebPage

五、源代码,可以点击下载已经通过编译的代码:QtWebChannelDemon(包含已经编译通过的项目及测试html文件),也可以直接复制参考下面完整代码

1.QtWevChannelDemon.pro:

QT += core gui
QT +=webenginewidgets
greaterThan(QT_MAJOR_VERSION, 4): QT += widgets
TARGET = QtWebChannelDemon
TEMPLATE = app
DEFINES += QT_DEPRECATED_WARNINGS
SOURCES += \
main.cpp \
widget.cpp \
qwebchannelclass.cpp
HEADERS += \
widget.h \
qwebchannelclass.h

2.main.cpp:

#include "widget.h"
#include <QApplication>
int main(int argc, char *argv[])
{    
QApplication a(argc, argv);   
 Widget w;   
 w.show();    
return a.exec();
}

3.widget.h:

#ifndef WIDGET_H
#define WIDGET_H
#include <QWidget>
#include <QWebEngineView>
#include <QHBoxLayout>
#include "qwebchannelclass.h"
class Widget : public QWidget
{  
  Q_OBJECT

public:   
 Widget(QWidget *parent = 0);   
 ~Widget();    
void initWebChannel();
private:    
 QWebEngineView* m_pWebEngineView;    
 QHBoxLayout*    m_pHBoxLayout;   
 QWebChannelClass* m_pWebChannelClass;
};
#endif // WIDGET_H

4.widget.cpp

#include “widget.h”
#include
#include
Widget::Widget(QWidget *parent) : QWidget(parent)
{
m_pHBoxLayout=new QHBoxLayout(this);
m_pWebChannelClass =new QWebChannelClass(this);
m_pHBoxLayout->setContentsMargins(0,0,0,0);
m_pWebEngineView=new QWebEngineView;      //创建一个vebview
m_pHBoxLayout->addWidget(m_pWebEngineView);
initWebChannel();
m_pWebEngineView->load(QUrl(“file:///E:/sources/qt/QtWebChannelDemon/test.html”));  //在webview中加载网页
}
Widget::~Widget()
{
}
void Widget::initWebChannel()
{
QWebChannel *pChannel=new QWebChannel(this);
pChannel->registerObject(QStringLiteral(“channelObject”),m_pWebChannelClass);
m_pWebEngineView->page()->setWebChannel(pChannel);
}

5.qwebchannelclass.h

#ifndef QWEBCHANNELCLASS_H
#define QWEBCHANNELCLASS_H
#include <QObject>
class QWebChannelClass : public QObject
{    

Q_OBJECT

public:    
explicit QWebChannelClass(QObject *parent = nullptr);
signals:    
void fromLocalToWebPage(const QString& strTemp);
public slots:    
void fromWebPageToLocal(const QString& strTemp);
};
#endif // QWEBCHANNELCLASS_H
6.qwebchannelclass.cpp
#include "qwebchannelclass.h"
#include <QDebug>
QWebChannelClass::QWebChannelClass(QObject *parent) : QObject(parent)
{
}
void QWebChannelClass::fromWebPageToLocal(const QString& strTemp)
{    
qDebug()<<QString("string from WebPage:%1").arg(strTemp);    
emit fromLocalToWebPage("fromLocalToWebPage");
}


![img](https://img-blog.csdnimg.cn/img_convert/252ad24d768499238fbb767b78f6781f.png)
![img](https://img-blog.csdnimg.cn/img_convert/bd1a492c2b5d7a5beb6734fa401211f5.png)

**既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上物联网嵌入式知识点,真正体系化!**

**由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、电子书籍、讲解视频,并且后续会持续更新**

**[如果你需要这些资料,可以戳这里获取](https://bbs.csdn.net/topics/618679757)**

有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上物联网嵌入式知识点,真正体系化!**

**由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、电子书籍、讲解视频,并且后续会持续更新**

**[如果你需要这些资料,可以戳这里获取](https://bbs.csdn.net/topics/618679757)**

  • 22
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Web开发中,Cookie是常用的一种状态管理方式,它可以在客户端浏览器和服务器之间传递信息,并且具有跨域的能力。但是在跨域场景下,不同域名之间的Cookie是不能共享的。本文将介绍如何通过Java实现跨域Cookie共享的方法。 一、什么是跨域Cookie共享 在同源策略下,浏览器只允许当前域名下的页面访问该域名下的Cookie,而不允许其他域名的页面访问该域名下的Cookie。这就是所谓的Cookie跨域问题。 但是在实际开发中,我们经常需要在不同域名之间共享Cookie。例如,在OA系统中,用户登录后可能会跳转到其他子系统中,此时需要保持用户登录状态,就需要在不同域名之间共享Cookie。这就是所谓的跨域Cookie共享。 二、实现跨域Cookie共享的方法 在Java中,实现跨域Cookie共享的方法有两种: 1、使用第三方Cookie共享方案,例如:CAS、OAuth等。 2、手动实现Cookie共享,即在跨域场景下手动设置Cookie。 下面将介绍手动实现Cookie共享的方法。 三、手动实现Cookie共享 手动实现Cookie共享的原理很简单:在A域名下设置Cookie时,同时在B域名下也设置一个相同名称的Cookie。这样,在B域名下访问时就可以获取到A域名下的Cookie信息了。 具体实现步骤如下: 1、在A域名下设置Cookie时,同时在B域名下也设置一个相同名称的Cookie。 代码示例: ```java // 在A域名下设置Cookie Cookie cookie = new Cookie("userId", "123456"); cookie.setDomain(".domaina.com"); // 设置Cookie的域名为.domaina.com cookie.setPath("/"); // 设置Cookie的路径为根路径 cookie.setMaxAge(60 * 60 * 24 * 7); // 设置Cookie的生命周期为7天 response.addCookie(cookie); // 将Cookie添加到响应中 // 在B域名下设置相同名称的Cookie Cookie cookie = new Cookie("userId", "123456"); cookie.setDomain(".domainb.com"); // 设置Cookie的域名为.domainb.com cookie.setPath("/"); // 设置Cookie的路径为根路径 cookie.setMaxAge(60 * 60 * 24 * 7); // 设置Cookie的生命周期为7天 response.addCookie(cookie); // 将Cookie添加到响应中 ``` 2、在B域名下访问时,获取A域名下的Cookie信息。 代码示例: ```java // 获取A域名下的Cookie信息 Cookie[] cookies = request.getCookies(); if (cookies != null) { for (Cookie cookie : cookies) { if (cookie.getName().equals("userId")) { String userId = cookie.getValue(); // TODO: 处理业务逻辑 break; } } } ``` 需要注意的是,在设置Cookie时,域名要以点号开头,例如:.domaina.com。这样设置后,所有以domaina.com结尾的子域名都可以共享该Cookie。 四、总结 本文介绍了如何通过Java实现跨域Cookie共享的方法,即手动实现Cookie共享。在跨域场景下,手动实现Cookie共享可以很好地解决Cookie跨域问题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值