百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

浏览器原生剪贴板:原来它能这样读取用户截图!

haoteby 2025-09-18 19:13 2 浏览

当我们使用 GitHub 时,会发现 Ctrl+V 就能直接读取用户剪贴板图片进行粘贴,那么它是如何工作的?安全性如何?

新一代神器:navigator.clipboard

navigator.clipboard API 是一个异步的、基于 Promise 的现代接口,其具有三大核心优势:

  1. 所有读写操作都返回 Promise,不会阻塞页面
  2. 操作剪贴板需要获得用户授权,既安全又透明
  3. 除了文本,它能轻松读写图片等二进制数据

写入剪贴板

在深入读取操作前,我们先看看如何向剪贴板写入内容。

写入文本

这是最常见的操作,比如实现一个“点击复制”按钮。

const copyBtn = document.getElementById('copy-btn');

copyBtn.addEventListener('click', async () => {
  try {
    await navigator.clipboard.writeText('你好,世界!');
    console.log('文本已成功复制到剪贴板');
  } catch (err) {
    console.error('复制失败: ', err);
  }
});

写入图片

写入图片稍微复杂一点,需要使用 clipboard.write() 方法,并传入一个 ClipboardItem 对象。这个对象可以包含不同 MIME 类型的数据。

// 假设你有一个 canvas 元素
const canvas = document.getElementById('my-canvas');

// 将 canvas 内容转为 blob
canvas.toBlob(async (blob) => {
    try {
        const item = new ClipboardItem({ 'image/png': blob });
        await navigator.clipboard.write([item]);
        console.log('图片已成功复制到剪贴板');
    } catch (err) {
        console.error('复制图片失败:', err);
    }
});

读取剪贴板

当用户在我们的网页上执行粘贴操作时,我们如何读取剪贴板里的内容,特别是图片?

关键:获取用户授权

这是最重要的一步。当我们尝试读取剪贴板时,浏览器会主动弹出提示框,请求用户授权。

只有用户点击“允许”,我们的代码才能继续执行。这彻底杜绝了恶意网站在后台偷偷读取用户剪贴板内容的可能。

读取步骤详解

让我们来实现一个监听粘贴事件并处理图片的功能。

  1. 监听 paste 事件
  2. 调用 navigator.clipboard.read():该方法会返回 Promise,解析为一个 ClipboardItem 对象的数组
  3. 检查每个 ClipboardItem MIME 类型
  4. 获取数据 Blob:如果 MIME 中包含我们想要的图片类型(如 "image/png"),我们就可以调用 item.getType() 方法解析为该数据的 Blob 对象
  5. 拿到 Blob 对象后,最常见的做法是使用 URL.createObjectURL() 生成一个临时 URL,并将其显示在 <img> 标签中,或直接上传到服务器

完整代码示例

假设我们有这样一个 HTML 结构:

<div id="paste-area" contenteditable="true">
  <p>请在这里粘贴你的截图...</p>
</div>
<img id="preview-image" src="" alt="图片预览" style="max-width: 100%; margin-top: 20px;">

对应的 JavaScript 代码如下:

const pasteArea = document.getElementById('paste-area');
const previewImage = document.getElementById('preview-image');

pasteArea.addEventListener('paste', async (e) => {
 // 阻止默认的粘贴行为
  e.preventDefault(); 
 try {
    // 请求读取剪贴板的权限
    const permission = await navigator.permissions.query({ name: 'clipboard-read' });
    if (permission.state === 'denied') {
      throw new Error('剪贴板读取权限被拒绝');
    }

    // 读取剪贴板内容
    const clipboardItems = await navigator.clipboard.read();
    for (const item of clipboardItems) {
      // 检查是否有图片类型
      const imageType = item.types.find(type => type.startsWith('image/'));
      if (imageType) {
        // 获取图片 blob 数据
        const blob = await item.getType(imageType);
        // 创建一个临时的 URL 来预览图片
        const imageUrl = URL.createObjectURL(blob);
        previewImage.src = imageUrl;
        // 在这里,你可以将 blob 上传到服务器
        // uploadToServer(blob); 
        console.log('图片粘贴成功!');
        return; // 处理完图片后即可退出
      }
    }

    // 如果没有图片,可以尝试读取文本
    const text = await navigator.clipboard.readText();
    console.log('粘贴的文本内容:', text);
    pasteArea.innerText = text;

  } catch (err) {
    console.error('粘贴失败: ', err);
    // 如果没有图片,尝试用传统方式读取文本
    const text = e.clipboardData.getData('text/plain');
    if (text) {
        pasteArea.innerText = text;
    }
  }
});

function uploadToServer(blob) {
 const formData = new FormData();
  formData.append('image', blob, 'screenshot.png');

 // fetch('/api/upload', {
 //   method: 'POST',
 //   body: formData
 // }).then(...);
 console.log('正在模拟上传...', formData.get('image'));
}

现在,截取一张图到剪贴板,然后在这个区域按下 Ctrl+V,你会看到浏览器弹出权限请求。授权后,图片就会立刻显示在下方!

相关推荐

如何随时清理浏览器缓存_清理浏览器缓存怎么弄

想随时清理浏览器缓存吗?Cookieformac版是Macos上一款浏览器缓存清理工具,所有的浏览器Cookie,本地存储数据,HTML5数据库,FlashCookie,Silverlight,...

Luminati代理动态IP教程指南配置代理VMLogin中文版反指纹浏览器

介绍如何使用在VMLogin中文版设置Luminati代理。首先下载VMLogin中文版反指纹浏览器(https://cn.vmlogin.com)对于刚接触Luminati动态ip的朋友,是不是不懂...

mac清除工具分享,解除您在安全方面的后顾之忧

想要永久的安全的处理掉重要数据,删除是之一,使用今天小编分享的mac清除工具,为您的操作再增一层“保护”,小伙伴慎用哟,一旦使用就不可以恢复咯,来吧一起看看吧~mac清除工具分享,解除您在安全方面的后...

取代cookie的网站追踪技术:”帆布指纹识别”

【前言】一般情况下,网站或者广告联盟都会非常想要一种技术方式可以在网络上精确定位到每一个个体,这样可以通过收集这些个体的数据,通过分析后更加精准的去推送广告(精准化营销)或其他有针对性的一些活动。Co...

辅助上网为啥会被抛弃 曲奇(Cookie)虽甜但有毒

近期有个小新闻,大概很多小伙伴都没有注意到,那就是谷歌Chrome浏览器要弃用Cookie了!说到Cookie功能,很多小伙伴大概觉得不怎么熟悉,有可能还不如前一段时间被弃用的Flash“出名”,但它...

浏览器指纹是什么?浏览器指纹包括哪些信息

本文关键词:浏览器指纹、指纹浏览器、浏览器指纹信息、指纹浏览器原理什么是浏览器指纹?浏览器指纹是指浏览器的各种信息,当我们访问其他网站时,即使是在匿名的模式下,这些信息也可以帮助网站识别我们的身份。...

那些通用清除软件不曾注意的秘密_清理不常用的应用软件

系统清理就像卫生检查前的大扫除,即使你使出吃奶的劲儿把一切可能的地方都打扫过,还会留下边边角角的遗漏。随着大家电脑安全意识的提高,越来越多的朋友开始关注自己的电脑安全,也知道安装360系列软件来"武装...

「网络安全宣传周」这些安全上网小知识你要知道!

小布说:互联网改变了人们的衣食住行,但与之伴生的网络安全威胁也不容忽视。近些年来,风靡全球的勒索病毒、时有发生的电信诈骗、防不胜防的个人信息泄露时时刻刻都威胁着我们的生活。9月18日-24日是第四届...

TypeScript 终极初学者指南_typescript 进阶

在过去的几年里TypeScript变得越来越流行,现在许多工作都要求开发人员了解TypeScript...

jQuery知识一览_jquery的认识和使用

一、概览jQuery官网:https://jquery.com/jQuery是一个高效、轻量并且功能丰富的js库。核心在于查询query。...

我的第一个Electron应用_electronmy

hello,好久不见,最近笔者花了几天时间入门Electron,然后做了一个非常简单的应用,本文就来给各位分享一下过程,Electron大佬请随意~笔者开源了一个Web思维导图,虽然借助showSav...

HTML5 之拖放(Drag 和 Drop)_html拖放api

简介拖放是一种常见的特性,即抓取对象以后拖到另一个位置。在HTML5中,拖放是标准的一部分,任何元素都能够拖放。先点击一个小例子:在用户开始拖动<p>元素时执行JavaScrip...

如何用JavaScript判断输入值是数字还是字母?

在日常开发中,我们有时候需要判断用户输入的是数字还是字母。本文将介绍如何用JavaScript实现这一功能。检查输入值是否是数字或字母...

图形编辑器开发:快捷键的管理_图形编辑工具

大家好,我是前端西瓜哥。...

浏览器原生剪贴板:原来它能这样读取用户截图!

当我们使用GitHub时,会发现Ctrl+V就能直接读取用户剪贴板图片进行粘贴,那么它是如何工作的?安全性如何?...