§

拖入图片或点击选择

拖入图片或点击选择

JPEG、TIFF — HEIC 取决于您的浏览器支持。每个文件最大 30 MB。

国内用户在分享照片时面临的隐私风险尤为直接:智能手机默认将精确 GPS 坐标写入每张照片,微信、微博、小红书等平台在部分路径上会保留原始 EXIF 数据,意味着家庭住址、工作地点或子女学校可能通过一张随手拍的照片暴露给陌生人。自由撰稿人、公民记者和维权人士在发布现场照片前清除 EXIF 是基本的操作安全步骤;企业用户在将产品图或内部会议照片上传到第三方平台前同样建议清除位置和设备信息。本工具在浏览器标签页中完成所有操作 — 原始照片从不触碰任何远程服务器。

EXIF 清除的工作原理

JPEG 文件是一系列称为 APP 标记的标签段,紧接在两字节 SOI 签名(0xFFD8)之后。EXIF 数据存储在 APP1 中,GPS 作为子 IFD 也在同一 APP1 块内,IPTC 在 APP13 中。清除器遍历每个标记,识别携带元数据的段,将其移除,再将剩余内容重新组装为有效 JPEG。

  1. 解析 APP 标记. 工具读取原始 ArrayBuffer,逐字节遍历 JFIF 标记序列。每个两字节标记标识一种段类型:APP0(JFIF 头部)、APP1(EXIF 和 XMP)、APP13(Photoshop 和 IPTC),以此类推直到 APP15。解析器在修改任何内容之前记录每段的偏移量和字节长度,使原始缓冲区在内存中保持完整。
  2. 解码 EXIF 标签. APP1 载荷是一个包含四个图像文件目录的迷你 TIFF 结构:第 0 IFD(主要图像属性)、Exif SubIFD(曝光、镜头、焦距、ISO)、GPS IFD(纬度、经度、海拔、方向)和第 1 IFD(嵌入缩略图)。每个标签携带数字代码、数据类型(字节、短整型、长整型、有理数、ASCII 字符串)和数值。工具使用 piexifjs 的标签字典将数字代码映射为可读名称,然后按 IFD 分组渲染在元数据面板中。
  3. 标记 GPS 标签. GPS IFD 中的任何标签均以红色隐私标识突出显示。纬度和经度以三个有理数(度、分、秒)加参考方向(N 或 S,E 或 W)存储。工具将其转换为六位精度的十进制度(赤道处精度约 11 cm),在 GPS 面板中显示结果并附带 OpenStreetMap 链接。链接在本地生成,不发出任何图块请求,仅在您点击时才会打开。
  4. 清除元数据. 对于 JPEG 文件,默认路径使用 piexifjs 完全移除 APP1 段,返回像素数据完整的新 dataURL。开启「保留方向」时,工具先在 <canvas> 上根据原始 Orientation 标签值(1–8)旋转图像,再清除元数据,使视觉效果与相机拍摄意图一致 — 旋转被烘焙到像素中而非依赖元数据标志。
  5. Canvas 重新编码路径. 关闭「保留 ICC 色彩配置文件」时,工具将图像绘制到隐藏的 <canvas> 并调用 canvas.toBlob('image/jpeg', quality)。此路径清除所有内容(EXIF、XMP、IPTC、ICC 配置文件、缩略图),并允许您通过质量滑块在 60 到 100 之间调节 JPEG 质量。默认值为 92,对于大多数照片,生成的文件大小在原始尺寸的几个百分点之内,视觉质量与原始几乎无法区分。
  6. 下载干净文件. 清理后的 blob 以 <original-name>-stripped.jpg 为名提供下载。工具在下载链接出现之前重新解析结果,确认 EXIF GPS 部分为空,因此您不会得到一个标注「已清除」却仍携带位置标签的文件。PNG 和 WebP 文件本身不携带 EXIF;工具对这些格式显示「无 EXIF」消息并跳过清除步骤。

为什么要在分享前清除 EXIF

  • 位置隐私. 智能手机默认在每张照片中嵌入精确的 GPS 坐标。拍摄于餐厅、办公室或家中的 JPEG 文件以约五米的精度将该地址存储在元数据中。在发布到社交媒体、发送给陌生人或附加到公开支持工单之前清除 GPS 标签,即可完全消除该位置指纹。
  • 出版物中的匿名性. 记者、维权人士和举报人在提交照片前清除 EXIF,因为相机序列号、镜头固件版本和创建时间戳都可以与其他已发布图片交叉对比以识别摄影师身份。对于不应将署名与特定物理设备关联的人来说,删除这些标签是基本的操作安全步骤。
  • 减小文件体积. 典型智能手机 JPEG 在其 APP1 段中携带 5 到 15 KB 的元数据,包括 160×120 的嵌入缩略图。相对于 5 MB 照片而言这个量很小,但对 1,000 张产品图片批量清除可节省每次上传 5 到 15 MB — 在整理产品目录、图片库或 Pinterest 导出时很有用。
  • 消除相机指纹. 相机品牌、型号、固件版本、镜头标识符和快门触发次数构成一个指纹,即使 EXIF 其他信息并无特别之处,也能在不同上传之间关联照片。如果您在不暴露硬件的情况下分享图片(漏洞报告、竞赛投稿、匿名作品集),Exif SubIFD 正是这些识别信息的存储位置。清除后,关联便被切断。

常见应用场景

每当一张照片在不同主体之间流转,而其携带的元数据可能对发送方或拍摄对象造成问题时,就需要清除 EXIF。

  • 社交媒体上传:大多数平台在服务器端会清除 EXIF,但先在客户端清除意味着原始坐标从未被传输到平台服务器。如果他们的流水线发生泄露(或被传票要求提供),原始 GPS 不在其日志中,因为它从未被发送。
  • 新闻和纪录摄影:通讯社和图片编辑室要求干净的元数据,以便署名和说明由编辑室控制而非相机决定。美联社、路透社和法新社的图片编辑在图片上传前都会运行元数据清除步骤。
  • 房产和产品列表:房产经纪人和电商卖家经常上传在房产或仓库地址拍摄的照片。在上传前清除 GPS 可防止列表无意中在文件中发布精确的商业地址 — 当仓库是私人住宅或房产仍有人居住时尤为重要。

实际案例

一张用近期 iPhone 拍摄的 3.5 MB JPEG 携带约 12 KB 的 APP1 元数据:GPS 坐标(含方位和海拔)、精确到毫秒的拍摄时间戳、相机型号和镜头标识符、白平衡设置以及一张 160×120 的嵌入缩略图。使用默认 piexif 路径清除后,文件降至 3.488 MB。轻了 12 KB,像素与原始完全相同,且没有位置信息。下载前,上方的 GPS 面板将显示被移除的具体坐标。

什么是 EXIF 元数据?

EXIF(可交换图像文件格式)是一项定义数码相机和智能手机如何在图像文件内存储元数据的标准。典型的智能手机 JPEG 携带相机品牌和型号、镜头焦距、快门速度、ISO、精确的 GPS 位置(精度达几米)、创建时间戳以及一张小型嵌入缩略图 — 这些在渲染图像中完全不可见,但任何支持 EXIF 的应用程序(包括操作系统文件浏览器和大多数图片编辑工具)均可读取。

为什么要在分享照片前清除 EXIF?

GPS 标签会暴露照片的拍摄地点,精度可达几米。不清除 EXIF 就分享照片,意味着您将该位置信息分享给了所有收到文件的人。相机序列号和镜头标识符还可以在不同上传间对摄影师进行指纹识别,这对匿名发布者尤为重要。清除 EXIF 可在文件离开您的设备之前移除所有这些信息。

这会影响图像质量吗?

默认的 piexif 路径在不触及图像像素的情况下移除 APP1 段,因此质量与原始完全一致(逐位相同)。Canvas 重新编码路径(关闭「保留 ICC 色彩配置文件」时使用,或对旋转图像开启「保留方向」时使用)会以所选 JPEG 质量滑块值重新编码像素 — 将滑块设置为 95 或更高,可在大多数照片上保持与原始接近的视觉效果。

iPhone 拍摄的 HEIC 文件怎么处理?

HEIC 清除取决于您的浏览器对 HEIC 的原生支持。Safari 13+ 可原生解码 HEIC;Chrome 和 Firefox 不支持。如果您的浏览器无法显示 HEIC,请先在手机上使用「导出为 JPEG」选项(iOS 照片:分享 → 选项 → 最兼容),然后在此上传 JPEG。转换后文件的清除步骤与其他 JPEG 完全相同。

每次清除都在您的浏览器本地运行。原始照片不会到达任何服务器,清理后的文件完全从上传时加载到内存的 ArrayBuffer 生成。将照片拖入上方,检查元数据,下载清理后的副本。