chrome扩展在popup、background、content之间通信解决传输文件问题

这篇具有很好参考价值的文章主要介绍了chrome扩展在popup、background、content之间通信解决传输文件问题。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

背景介绍

        示例扩展API版本MV2。
        以弹出窗口(popup)和背景页面(background page)为例。
        在浏览器中,弹出窗口(popup)和背景页面(background page)之间可以通过消息通道进行通信。但是,由于安全限制,弹出窗口不能直接访问背景页面的文件系统或进行文件传输。
        然而,可以使用一些方法来实现弹出窗口向背景页面传输文件,就是在popup页面将文件转为base64的字符串格式向background传输,然后再将base64重新转为file对象,达到传输文件的目的。

案例介绍

        从popup页面选择文件开始上传,触发上传按钮后,获取到选择的文件并将文件传输到background,触发上传接口传输到服务器端,完成文件上传操作。
chrome扩展在popup、background、content之间通信解决传输文件问题,# 扩展插件,前端,文件上传,chrome扩展文件通信,chrome扩展

代码示例

使用到的js工具有,jquery、axios。文章来源地址https://www.toymoban.com/news/detail-626021.html

popup页面,上传文件页面

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>popup</title>
    <style>
        body {
            width: 400px;
            height: 450px;
            background-color: aliceblue;
        }
        .contnet {
            display: flex;
            flex-direction: column;
            flex-wrap: nowrap;
            align-items: center;
        }
        .upload_file {
            display: flex;
            flex-direction: column;
            margin-top: 88px;
        }
        .upload_btn {
            border: none;
            border-radius: 10px;
            background-color: #4343e0;
            font-size: 16px;
            color: white;
            font-weight: 400;
            font-family: '微软雅黑';
            cursor: pointer;
        }
        .upload_btn:hover {
            border: none;
            border-radius: 10px;
            background-color: #4343e0;
            font-size: 16px;
            color: white;
            font-weight: 400;
            font-family: '微软雅黑';
            cursor: pointer;
            box-shadow: 0px 0px 0px 1px #848181;
        }
    </style>
</head>
<body>
    <div class="contnet">
        <div class="upload_file">
            <!--  
              type: input类型为文件选择类型
          		name: 参数名
              accept: 上传文件的可选类型
          	-->
            <input id="uploadFile" type="file" name="myFile" accept="application/vnd.openxmlformats-officedocument.spreadsheetml.sheet|application/vnd.ms-excel" style="margin-bottom: 5px;" />
            <button id="uploadFileBtn" class="upload_btn" type="button">上传</button>
        </div>
    </div>
</body>
<script type="text/javascript" src="/utils/chrome.js"></script>
<script type="text/javascript" src="/lib/jquery-3.6.3.js"></script>
<script type="text/javascript" src="/popup/popup.js"></script>

</html>

popup页面,js上传代码,file文件转base64

// popop.js、jquery-3.6.3.js
// 绑定文件上传的button
$("#uploadFileBtn").click(() => {
    // 如果是单文件上传,选择第一个文件上传
    //let file = $("#uploadFile")[0].files[0] // ok
    let file = $("#uploadFile").prop('files')[0]
    if (!file) {
        alert('文件上传:' + '请先选择文件')
        return
    }
    let boo = confirm('是否确认上传文件?\n\r 请谨慎操作上传文件')
    if (boo) {
        // file转base64
        let reader = new FileReader()
        reader.readAsDataURL(file)
        reader.onload = () => {
            let base64 = reader.result.split(',')[1]
            // 发送base64到background
            // chrome.js
            sendMessageToBackground({type: 'upload', base64: base64}, (rsp) => {
                // 上传成功 or 失败后做一些操作
            })
        }
    }
})

background监听消息,base64转file文件,axios上传

// 上传文件
// axios.js
// base64: popup传过来的数据
function uploadFile(base64) {
    // base64转blob
    let blob = base64ToBlob(base64, 'application/vnd.ms-excel')
    // blob转file
  	let file = new File([blob], '上传文件的名字[filename].xlsx', {type: 'application/vnd.ms-excel'})

    // 构造formData表单对象,发起post请求
    let formatData = new FormData()
    formatData.append('file', file)
  
  	// axios发送文件上传的请求
    return axios({
        url: 'upload_url',
        method: 'POST',
        headers: {
            'xx-header': 'xxx',
            // 'Content-Type': 'multipart/form-data' // 不需要设置Content-Type请求头,axios请求机制会自动判断,发起什么样的请求
        },
        transformRequest: [(data, headers) => {
            delete headers['Content-Type']
            return data
        }],
        data: formatData
    }).then(rsp => {
        // 服务器数据响应
        return rsp.data
    })
}

/**
 *	
 * @param {*} mineType 选择适当的类型来转换base64,并创建Blob二进制对象
 *  'application/pdf': 表示 PDF 文件类型,可以以可移植文档格式查看和编辑。
 *  'application/msword' 或 'application/vnd.ms-word': 表示 Word 文档类型,可以以 Microsoft Word 格式查看和编辑。
 *  'application/vnd.openxmlformats-officedocument.wordprocessingml.document': 表示 Word 2007 或更高版本的文件类型,可以以 Office Open XML 格式查看和编辑。
 *  'application/epub+zip': 表示 ePub 电子书类型,可以以电子书格式查看和编辑。
 *  'application/vnd.ms-powerpoint' 或 'application/mspowerpoint': 表示 PowerPoint 演示文稿类型,可以以 Microsoft PowerPoint 格式查看和编辑。
 *  'application/vnd.openxmlformats-officedocument.presentationml.presentation': 表示 PowerPoint 2007 或更高版本的文件类型,可以以 Office Open XML 格式查看和编辑。
 *  'application/vnd.ms-excel' 或 'application/msexcel': 表示 Excel 电子表格类型,可以以 Microsoft Excel 格式查看和编辑。
 *  'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet': 表示 Excel 2007 或更高版本的文件类型,可以以 Office Open XML 格式查看和编辑。
 *  'image/jpeg'、'image/png'、'image/gif' 等:表示图像类型的数据,可以以图像的形式查看和编辑。
 * @returns 
 */
function base64ToBlob(base64, mineType) {
    mineType = mineType || 'application/octet-stream'
    const byteCharacters = atob(base64)
    const byteNumbers = new Array(byteCharacters.length)
    for(let i = 0; i < byteCharacters.length; i++) {
        byteNumbers[i] = byteCharacters.charCodeAt(i)
    }
    let byteArray = new Uint8Array(byteNumbers)
    return new Blob([byteArray], {type: mineType})
}

附-转base64后直接下载

function download(base64, mineType) {
  mineType = mineType || 'application/octet-stream'
  const dataUrl = `data:${mineType};base64,${base64}`

  const link = document.createElement('a')
  // document.body.appendChild(link)
  link.href = dataUrl
  link.download = 'file.xlsx' // 前提需要先知道是什么文件类型
  link.click() // 点击下载
  // document.body.removeChild(link) // 下载完成后移除标签
}

到了这里,关于chrome扩展在popup、background、content之间通信解决传输文件问题的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【Vue/Js】如何解决谷歌浏览器(chrome)扩展插件安装后,再打开自动消失问题(两种解决方案)

    卸载后,再重新从官网下载最新版安装。 注意:卸载一定要把缓存数据都卸载干净。 1、打开设置  2、选择百度或360 极简插件_Chrome扩展插件商店_优质crx应用 极简插件是一个优质Chrome插件扩展收录下载网站,收录热门好用的Chrome插件扩展,国内最方便的插件下载网站。 htt

    2024年02月05日
    浏览(63)
  • chorme安装esay scholar及chrome 无法从该网站添加应用、扩展程序和用户脚本解决方案

    如题,博主想安装easy scholar用于查询论文的分区,结果安装了半天一直出现chrome 无法从该网站添加应用、扩展程序和用户脚本解决方案的问题。 先从这个网址下载:https://www.easyscholar.cc/download 然后对下载好的文件进行解压。  按照[1]中说的,点击右上角三个点-更多工具-扩展

    2024年02月07日
    浏览(36)
  • 利用Redis实现向量相似度搜索:解决文可变化、可扩展本、图像和音频之间的相似度匹配问题

    最近工作中需要用到MongoDB的事务操作,因此参考了一些资料封装了一个小的组件,提供基础的CRUD Repository基类 和 UnitOfWork工作单元模式。今天,就来简单介绍一下这个小组件。 MongoDB在4.2版本开始全面支持了多文档事务,至今已过了四年了,虽然我们可能没有在项目中用Mon

    2024年02月21日
    浏览(54)
  • chrome插件开发实例02-使用content_scripts对用户浏览页面操作

    目录 引言 chrome插件 插件演示 源代码 manifest.json content_scripts.js

    2024年02月14日
    浏览(35)
  • Chrome 插件 V3 版本 Manifest.json 中的内容脚本(Content Scripts)解析

    指定在用户打开某些网页时要使用的 JavaScript 或 CSS 文件。 内容脚本是在网页环境中运行的文件。通过使用标准文档对象模型 ( DOM ),开发者能够读取浏览器所访问网页的详情、更改这些网页,并将信息传递给其父级扩展程序。 内容脚本在声明扩展程序文件为可通过网络访问

    2024年01月19日
    浏览(38)
  • Chrome扩展开发系列开篇

    大家好,我是 dom 哥。这是我关于 Chrome 扩展开发的系列文章,感兴趣的可以 点个小星星。 研究机构 Statcounter 发布了 2023 年 9 月报告,揭示了有关浏览器的最新统计数据。 浏览器 市场份额 Chromium-based? Chrome 63.56% Yes Safari 19.85% No Edge 5.43% Yes Firefox 2.94% No Opera ... Yes 可以看到基

    2024年02月04日
    浏览(50)
  • 从零实现的Chrome扩展

    Chrome 扩展是一种可以在 Chrome 浏览器中添加新功能和修改浏览器行为的软件程序,例如我们常用的 TamperMonkey 、 Proxy SwitchyOmega 、 AdGuard 等等,这些拓展都是可以通过 WebExtensions API 来修改、增强浏览器的能力,用来提供一些浏览器本体没有的功能,从而实现一些有趣的事情。

    2024年02月17日
    浏览(44)
  • Chrome扩展开发实战:快速填充表单

    大家好,我是 dom 哥。我正在写关于 Chrome 扩展开发的系列文章,感兴趣的可以 点个小星星 。 填表单是打工人经常面对的场景,作为一个前端,我经常开发一些PC端的页面,它们主要由表单和表格构成,而输入框又是表单里最常见的表单项。 接下来就试着做一个简单的小扩展

    2024年02月04日
    浏览(47)
  • vue3+ts+uniapp小程序端自定义日期选择器基于内置组件picker-view + 扩展组件 Popup 实现自定义日期选择及其他选择

    vue3+ts 基于内置组件picker-view + 扩展组件 Popup 实现自定义日期选择及单列选择 自我记录 直接上代码 srccomponentshbcy-popup.vue srcutilsindex.ts 全局自动导入看(https://blog.csdn.net/zhgweb/article/details/132499886?spm=1001.2014.3001.5502 第11标题 没有配置全局自动导入的需要自己手动引入! srcpage

    2024年02月11日
    浏览(58)
  • Chrome扩展的核心:manifest 文件(下)

    大家好,我是 dom 哥。这是我关于 Chrome 扩展开发的系列文章,感兴趣的可以 点个小星星。 在上篇和中篇中已经完成了对 manifest 文件中以下字段的解释: \\\"manifest_version\\\" \\\"name\\\" \\\"version\\\" \\\"description\\\" \\\"icons\\\" \\\"content_scripts\\\" \\\"background\\\" \\\"permissions\\\" 本篇接着说剩下的 manifest 可选字段。 定义

    2024年02月04日
    浏览(49)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包