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

chrome extensions mv3通过content scripts注入/获取原网站的window数据

开发插件的都知道插件的content scripts和top window只共享Dom不共享window和其他数据,如果想拿挂载在window的数据还有点难度,下面会通过事件的方式传递cs和top window之间的数据写一个例子

代码

manifest.json

这里只搞了2个js,content.js是content scripts,main.js是在top window里运行的

{"version": "0.0.1","author": "apades","name": "ext-hack","description": "","manifest_version": 3,"content_scripts": [{"matches": ["<all_urls>"],"js": ["content.js"],"run_at": "document_end","all_frames": true},{"matches": ["<all_urls>"],"js": ["main.js"],"run_at": "document_end","world": "MAIN"}]
}

content.js

async function sendExtMessage(type, data) {window.dispatchEvent(new CustomEvent('ext-req', { detail: { type, data } }))return new Promise((res) => {function handleResponse(e) {const detail = e.detailif (detail.type == type) {window.removeEventListener('ext-res', handleResponse)return res(detail.data)}}window.addEventListener('ext-res', handleResponse)})
}// 暴露到content script的window里测试
window.sendExtMessage = sendExtMessage

main.js

window.addEventListener('ext-req', async (e) => {const { type, data } = e.detailswitch (type) {case 'run-code': {let fn = new Function(`return (${data.function})(...arguments)`)let rs = await fn(...(data.args ?? []))sendExtResponse(type, rs)break}}
})function sendExtResponse(type, data) {window.dispatchEvent(new CustomEvent('ext-res', {detail: { type, data },}))
}

运行测试

首先我先在top window里随便写个window.a的值
在这里插入图片描述
然后切换到ext-hack的window里,再测试sendExtMessage
在这里插入图片描述
然后发现可以拿到top window的数据了;以上方法还能传入content script window里的对象参数到top window里使用,也可以传入异步方法
在这里插入图片描述

最后要说的

通过事件里互相传的数据会经过插件内部的序列化,地址、Object.defineProperty都是不共享的。而且这个方法相较于script标签插入,可以绕开doc response的Content-Security-Policy

http://www.lryc.cn/news/180106.html

相关文章:

  • 震坤行API接口聚合解析,实现根据ID取商品详情
  • mencpy和strcpy的区别?
  • 机器人过程自动化(RPA)入门 8. 异常处理、调试和日志记录
  • tomcat总结笔记
  • 中断向量控制器(NVIC)
  • QT配置FFmpeg出现错误原因
  • 列出使用Typescript的一些优点?
  • 如何做好测试?(四)集成测试(Integration Testing, IT)
  • 二叉树前序、中序、后序遍历(递归法、迭代法)
  • npm ,yarn 更换使用国内镜像源,淘宝源
  • 真正理解浏览器渲染更新流程
  • 市场调研的步骤与技巧:助你了解市场需求
  • ansible的个人笔记使用记录-个人心得总结
  • 相机数据恢复!详细步骤解析(2023新版)
  • LNK2001: unresolved external symbol __imp___std_init_once_begin_initialize 问题解决
  • 修改switch Nand无线区码 以支持高频5G 信道
  • 基于SpringBoot的课程答疑系统
  • JAVA中的泛型
  • 日撸代码300行:第73天(固定激活函数的BP神经网络,训练与测试过程理解)
  • css中常用单位辨析
  • Unity 一些常用特性收集
  • select实现服务器并发
  • 【Spring底层原理】BeanFactory的实现
  • c++---I/o操作
  • UG\NX二次开发 用程序修改“用户默认设置”
  • 什么是信号处理?如何处理信号?
  • 谈谈 Redis 数据类型底层的数据结构?
  • 九、GC收集日志
  • SimpleCG动画示例--汉诺塔动画演示
  • 反弹shell脚本(php-reverse-shell)