破解马赛克有多「容易」?

news2024/9/29 7:23:44

刷短视频时,估计大家都看过下面这类视频,各家营销号争相曝光「一分钟解码苹果笔刷背后内容」的秘密。换汤不换药,自媒体们戏称其为「破解马赛克」,殊不知让多少不明真相的用户建立起了错误的认知,也让苹果笔刷第 10086 次被「黑」为打码工具。

打码这个动作其实早就渗透在我们生活中的各个方面。如上用户通过 iOS 绘制功能提供的笔刷多次给截图进行涂抹,这样的操作至多称之为涂鸦而不是打码。普通人往往是打码行为的接收者而不是执行者,「单纯认为遮住内容就是打码」也变相造成了很多啼笑皆非的打码行为。

利用绘制功能中的涂鸦笔「打码」和「解码」

如上图所示,涂鸦笔只是对图片上追加了一层透明的遮罩,无论多少次叠加都可以通过调节亮度、对比度等参数的方式让笔刷后的内容现形。这些基于错误操作带来的错误结论居然变相又变成了马赛克不安全的证据,简直错上加错。

新时代围绕马赛克进行的讨论无非两个,马赛克是否安全以及马赛克的破解方式。从根本上来说,这两个问题取决于「打码时究竟图片发生了什么样的变化」,也就是得先知道图片打码背后的原理,才能判断其是否具备解码的可能,那么安全与否的问题也就水落石出了。

马赛克很难破解吗

首先从视觉上正视下马赛克的威力。以下是通过常规打码工具 Fotor 呈现的效果,可见物品轮廓,却不见高分辨率的细节,从人眼观看的效果来说,我们「知其然不知其所以然」。

打码工具 Fotor 提供的各种马赛克的截图

从定义上来说,马赛克指的通常是出于隐私保护等目的,将图片或视频中某个特定区域的色阶细节劣化,造成色块打乱、被晶格覆盖的效果。

光说还不明确,试试打码工具是就大致能看出个所以然来。在上图左侧的马赛克功能区,提供方块马赛克,三角形、六边形的马赛克形状可选,不仅有形状,强度的变更也可以调整马赛克单位覆盖的大小,越大意味着忽略的细节越多。从人眼来看,自然就更加难以还原了。

不过解码本来也不是人眼的行为,AI 则是普罗大众心中解密马赛克的万能钥匙。或许因为 AI 可以掌握某种规律和算法,通过猜想来完美还原马赛克呢?

通过 iOS 端的 DAMA App 进行像素打码

从上图中对一段字母和头像的聊天记录进行打码来看,很容易得出一些结论。(仅针对当前选择的打码工具)

  • 同样的头像在打码中依然呈现不同的结果,反过来可见通过马赛克完美解析出原内容难度太大。
  • 不同的字母也甚至因为色阶的劣化成了完全一致的空白,可见不同的内容在打码后可能保持一致的马赛克效果。

马赛克图片难以破解,指的是马赛克的色阶进行反向的细化,从而恢复成原图的样子很难。但很难还不一定意味着不可能,试图恢复的重要前提是——图片存储的数据中是否具备可还原的信息。

关于这一点是毋庸置疑的,不管是 JPG、PNG 等不同的压缩格式,图像数据中除了包含每个像素基本的 RGB 信息,部分格式额外存储的地理位置、拍摄设备等元数据信息,并不会包含打码等过程留下的任何数据。这切断了马赛克完美还原的根本途径,不然图像解码也不会是未来 AI 发挥力量的重要战场,AI 做的始终是试图「猜测」马赛克的原内容,正确与否并不能保证。

综上所述,被马赛克后的图片并不会额外存储打码过程中的额外处理信息,这就是马赛克不能被轻易还原的本质原因。

「马赛克」从何而来

既然说到了 AI,就不得不提各家厂商和学术团队在破解马赛克上的努力和成就。但本着严谨治学的态度,在此之前,先搞清楚什么是马赛克比较重要。

容我先问一个问题:你这辈子看过最美的马赛克是什么?

别误会,我不是要拿成人影片中的马赛克说事,只是恰好这部 Netflix 出品,讲述成人影片巨头崛起历程的精彩剧集《全裸导演》的片头制作太过精良,配合抓耳的 BGM 马赛克犹如烟花般绽放,有网友甚至称这是这辈子看过最美的马赛克。

被打上马赛克的霓虹灯,各种规则形状的碎片组合成的物体炸裂开来,仿佛世界都是由马赛克装扮而成。看似低分辨率的马赛克,远看却给人呈现出一种高清大图的美感,这样的美感早就被公元前三千年前的人们感知并利用起来,马赛克在当时就已经是教皇用在教堂建筑上的一种装饰艺术。

几千年后,被成人内容霸占用户心智,导致马赛克的使用场景越来越不被人们重视。加上一些自媒体隔三差五「破解马赛克」的碎片又片面化的宣传,言及马赛克动不动就内涵小电影的局面实在让人无语。

长此以往,不仅用户不知道如何正确打上马赛克,更是对马赛克的效果存疑,动不动马赛克不安全的囫囵说法实际上让群众对隐私保护的意识以及价值感大大降低。

各种马赛克场景

其实除了保护成人视频中的隐私泄漏,马赛克在日常中还有非常多的使用场景:

  • 在日常聊天传送涉及个人隐私的图片时,针对图片中的地址、车牌号、证件号、手机号等马赛克处理。
  • 电视新闻中,常见的有从法律层面上保护受害人、嫌疑人、证人隐私权等角度出发的马赛克处理。
  • 涉及国家隐私的地图和信息中,Google 地图等地图提供商往往要对军事禁区等信息进行马赛克处理。
  • 影视作品或游戏中,从未成年人保护角度出发对暴力、血腥等场景进行的马赛克处理。
  • ......

熟练地在涉及到隐私的地方打上马赛克,并将其合法合理地传播分享,是每个人新时代冲浪人必备的技能。

理论上的「破解」手段

既然无法 100% 保证还原马赛克之前的图像,可以通过什么样的方式来「推测」出马赛克之前的样子,就是所谓营销号眼中「破解马赛克神器」做的事情。这样的工具不外乎从逻辑层面上「猜」和「算」两种方法。

从「算」的学术描述上表述,去马赛克(demosaicing)算法是一种数字图像处理,用于根据从彩色滤波器阵列(CFA)覆盖的图像传感器输出的不完整颜色样本重建全色图像。 它也被称为 CFA 插值或颜色重建。

把令人迷惑的定义更通俗地表述出来,「算」的方式更像是对应人类「眯着眼睛看」的另一种机器执行的效果。不过单纯的算已经无法满足人类征服马赛克场景的复杂度了,大多数的马赛克去除方法是 AI 和算法加持下的双重结果。

从 2017 年 Google brain 展示出的 AI 去码功力,到 2020 年杜克大学的 PULSE 展示出的惊人效果,我们每一次都在惊叹于算法与 AI 结合后的去码效果。实验室产出的 paper 让人惊艳,但实际操作效果却始终不尽人意。

Google brain

2017 年  
Google Brain 团队发布了一个名为超强像素递归方案(Pixel Recursive Super Resolution)的 AI 系统,能提高像素乱化处理后的照片的分辨率。通俗地讲,就是能去除马赛克。

在上图中,右列是名人照片未经模糊化的原图,左列是被打码后的照片,分辨率仅有8×8像素。而中间是谷歌的 AI 解码处理后的效果,分辨率达到 32×32 像素,提升了 16 倍。

Google Brain 还原低分辨率照片基于两项核心工具。第一项是工具调节网络(conditioning network),通过海量人物面部照片来进行训练,让系统记忆学习到具有代表性的面部特征。另一项是工具优先网络(prior network),让系统基于之前的训练,猜测可以作为高分辨率照片的特征。

发者们通过深度学习让机器产生「联想」,以「猜测」的方式为被马赛克的色块增加细节,提升像素倍数,从而得出更清晰的画面。比起「还原」,还不如说这是 AI 靠强大的学习和计算能力「脑补」出了原图。

从应用角度来看,该系统最大的突破在于能够让 8×8 像素的模糊图片变得清晰一些,离更高清晰度的「解码」还有一段距离。

PULSE

杜克大学 2020 年 3 月 8 日在 arXiv 期刊
 中公布了不同于以往的超分辨率解决方案。这是 机器之心
 关于 PULSE 算法的一段关键描述:

PULSE 不从 LR 图像开始缓慢地添加细节,而是遍历高分辨率自然图像流形,搜索可以降级至原始 LR 图像的高分辨率图像。这一过程通过「降尺度损失」(downscaling loss)完成,它指引着在生成模型潜在空间中的探索。

通俗来说,PULSE 不是像拼图一样从 0 开始填补像素,而是快速生成高清大图然后降低图片分辨率与原始图片对比,从中找到匹配程度最高的图像的一种解决方案。这样的好处就是快速和生成的图片更加细腻。PULSE 算法可以在短短几秒内就把 16×16 像素的低分辨率图片提升到 1024×1024 级别,精度提升了64倍,同时可以将低分辨率图像中无法看清的毛孔、皱纹、头发等转换得清晰。

先放大再对比猜测,PULSE 算法可谓另辟蹊径。不过,靠猜测得到的图案毕竟不是原图,在还原过程往往得到清晰但跟原图大相径庭的图案。比如,我们将奥巴马的图像打码,再通过PULSE 算法还原,得到的居然是一张白人面孔。

对此,PULSE 算法创始人解释道:「结果的偏差,原因在于数据的偏差。为什么 PULSE 会出现奥巴马被洗白的情况?因为它是在 FlickFaceHQ 上进行预训练,这个数据集里基本都是白人照片。如果换成来自塞内加尔的数据集,训练完全相同的系统,那必然是每个人都看起来像非洲人。」

PULSE 解码生成的始终不是真实的原图。如果你打开 PULSE 的 Github 链接,在项目描述的第一段就有着清晰的描述:「我们已经注意到很多人担心 PULSE 将被用于识别面部被模糊化的个人。我们想强调的是,这是不可能的。PULSE 制作的是不存在的人的虚构面孔,不应该与真实的人混淆。它不会帮助识别或重建原始图像。」

Depix

除了识别人脸并去除马赛克,对于文字马赛克的处理也有对应的解码思路提出。

2022 年横空出世的 Depix
 就是能够从像素化截图中恢复密码的工具。该项目适用于使用线性方框滤波器(linear box filter)创建的像素化图像。如下图所示,项目作者给出了像素化图像、恢复之后的效果和原图的对比结果:

该算法利用了线性盒式滤波器分别处理每个块,对于每个块,它将对搜索图像中的所有块进行像素化以检查直接匹配。对于大多数像素化图像,Depix 设法找到单匹配结果。假设这些是正确的。然后,将周围的多匹配块的匹配进行比较,以在几何上与像素化图像中的距离相同的距离进行比较。匹配也被视为正确。重复此过程几次。正确的块不再具有几何匹配之后,它将直接输出所有正确的块。

不断重复这一过程,直到拼装出一张完整的拼图为止,达到去码的效果。Depix 拼图式的解决方案有一定效果,但网上众多开发者已经对其使用场景的限制有过总结:

  • 需要知道马赛克原始字符会有哪些可能。
  • 序列图像需要与马赛克图像原本的字符拥有相同字体设置(文本大小,字体,颜色,HSL)。
  • 只适用于英文、数字等字符序列的解码,不支持中文。

从解决思路和方案来看,Depix 其实是面对一种较为严苛的马赛克场景提出的针对性解决方案。图片被打码的部分像是一张被拆散的拼图,Depix 的任务就是在零散的拼图碎片中,通过算法找到最合适的一块,然后放到正确的位置里。

马赛克还安全吗

马赛克,因为其图片本身的不可逆性质,任何使用打码技术的用户应该建立好「完全去码是不可能的」这项基本认知。这也是上文中我们反复论证的结果。但不得不承认,不断进步的 AI 算法和日渐庞大的训练库,让用户对于打码后传播的图片也抱有一丝被「AI 猜出」后传播的心理风险。

关于这个问题,问一问同是 AI 技术出身的「ChatGPT 博士」,答案也许会有些启发。

在 ChatGPT 的总结中,可见其对于马赛克安全性的认知是比较到位的——不是完全安全,部分情况下信息可以被破解。在多次的问询中,还举例类似银行卡号、车牌号常见场景更容易被黑客破解。而在增强马赛克安全性的总结中,也体现了 AI 回答的全面性。

所谓道高一尺,魔高一丈,马赛克是否安全始终取决于用户打码的手段和方式。在传统影视新闻等传播媒体中,但凡需要打码的场景下,我们可以见到以下几种方案:

  • 实色遮盖
  • 高斯模糊
  • 马赛克

其中,实色遮盖是最稳妥和无法解析的方案不言而喻,比如早期的网络视频直接使用黑白色块大面积遮挡以保护隐私。高斯模糊的打码方案可以看做是主动丢失图像的大量细节,但还兼顾了部分内容观感的隐私保护解决方案。这在涉及到解放军战区的武器装备中经常被看到使用,原因在于高斯模糊的逆运算复杂度极高。马赛克则更像是折中的解决方案,在马赛克颗粒度细时观感破坏性不大,在马赛克粒度大时,隐私保护性能突出,总能根据场景找到合适的解决方案。

同时,从以上几种解码的「佼佼者」中,我们也不难得出通过 AI 和算法结合去码的技术方案日趋成熟,但还远远不够的结论。究其本质,靠「猜」始终是解码的核心解决方案,这意味着马赛克依然不能被完美的去除。Google brain 和 PULSE 算法看似很牛,但依然逃不过 AI 训练库不够丰富,猜测的结果合理但不准确的现实。类似 Depix 的解决方案看似可靠但使用场景单一。

知己知彼,百战百胜。增加打码时对隐私的破坏性,让内容失去规律,增加解码复杂度就是最好的打码方案。

正确的打码方式

实色遮盖、高斯模糊和马赛克都是增加 AI 破解复杂度的利器,利用好手头的工具追加以上任一效果甚至将多种打码方式结合在一起,都应该是防止隐私泄漏的常见手段。

iOS 自带的打码工具

回到上文提到的常见打码方式中,不仅要摒弃马克笔打码的行为更要用上趁手有效的打码工具。iOS 中的马赛克笔工具本来就是用来进行标记和划线,非要用的话,推荐使用 iOS 的标记功能进行打码,可以在编辑图片右下角的 + 添加色块来遮盖内容。

通过专业打码的 App 或图像处理软件进行打码,也是一种合适的图片打码处理方案。如果要让图片更加难以破解,可以选择打码后更换工具再进行二次打码。比如通过 A 工具高斯模糊后再用 B 工具追加马赛克,这样的图像打码方案更加纯粹和可靠。

最后

回到最初马赛克诞生的初衷,作为一种艺术形式,马赛克依然在建筑和艺术设计中占有一席之地。与此同时,也不要仅仅以为去除马赛克只是为了看清原本被刻意打上码的图片,去码技术在医学、刑侦等领域依然有着不可忽视的作用。

马赛克是武器,让人们免除隐私的泄漏,恰到好处地使用好这门打码的技术,可以保护我们免受隐私泄漏的风险。去码技术是人类以 AI 对抗模糊的武器,鼓励其发展,合理合法地使用好这门「武器」,更加是我们始终要坚守的底线。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/486215.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【网络编程】demo版UDP网络服务器实现

文章目录 一、引入二、服务端实现2.1 创建套接字socket2.2 绑定bind2.3 启动服务器2.4 IP的绑定2.5 读取数据recvfrom 三、用户端实现3.1 绑定问题3.2 发送数据sendto 四、源码 一、引入 在上一章【网络编程】socket套接字中我们讲述了TCP/UDP协议,这一篇就是简单实…

保护移动设备免受恶意软件侵害优秀方法

几天前,移动恶意软件攻击增加了500%显然,我们大多数人都不知道不能很好地保护我们的手机下面小编揭秘有效保护移动设备免受恶意软件侵害的最佳方法。 1、使用移动反恶意软件 恶意软件很容易感染智能手机和平板电脑,因此在设备上安装可靠的…

douyin 之xgorgon0404参数

如果我们想要看抖音的数据,在抓包的时候,会发现有一个xgorgon参数,在请求接口的时候,只需要在请求头携带xgorgon参数,就能获得响应后的数据。 目前抖音的xgorgon0404算法已经还原了, 下面是一个请求的demo。代码如下:…

计算机网络可靠传输的三种基本实现机制

可靠传输的means 在数据链路层会给上层网络层提供可靠传输或者不可靠传输,不可靠传输是指检测到传输差错的时候只是丢弃该分组而不进行任何处理,而可靠传输会给发送者一个信号进行重发该分组。 以下给出的三种基本实现机制是提出一些问题,慢…

截图的背景色如何去除?这里介绍一个小工具

屏幕截图,是方便常用的功能。例如从网页或者视频中截图。但是有时候想去除截图中的背景颜色,怎么办?下面这个案例介绍如何去掉截图中的蓝色背景色。 这个小工具就能帮你方便实现。Web端的便捷小工具链接: http://www.artvily.com/renderCase…

深度学习框架发展趋势

深度学习方法的发展是推动深度学习框架进步的最大动力,因此深度学习框架的功能和设计应顺应 算法和模型的发展趋势: 第一,易用性。深度学习领域仍处于快速发展期,参与者和学习者不断增加,新模型大量提出。因 此&#…

深入篇【C++】类与对象:拷贝构造函数详解

深入篇【C】类与对象:拷贝构造函数详解 ①.拷贝构造函数Ⅰ.概念Ⅱ.特征1.重载形式之一2.参数唯一3.形参必须传引用4.编译器的拷贝函数5.典型调用场景 ②.总结: ①.拷贝构造函数 Ⅰ.概念 在创建对象时,能否创建一个与已存在对象一模一样的新…

[架构之路-186]-《软考-系统分析师》-5-数据库系统 - 关系型数据库、操作型数据库、数据集市、数据仓库的区别?

目录 总体架构: 一、数据库 二、关系型数据库 三、SQL与数据库 四、 分布式数据库 五、数据仓库 1. 概述 2. 架构 3、数据仓库的主要特征 3、1 面向主题性 3、2 集成性 3、3 非易失性 3、4 时变性 总体架构: 一、数据库 数据库是“按照数据…

【链表OJ题 1】反转链表

目录 题目来源: 代码实现 1、方法一 1.1分析 2、方法二 2.1 分析 题目来源: 力扣 题目描述: 代码实现 1、方法一 struct ListNode* reverseList(struct ListNode* head) {struct ListNode* prev NULL, * cur head;while (cur){st…

基础IO+文件

基础IO 回顾文件回顾文件操作库函数调用接口写文件-w读文件-r 系统调用打开文件-open写文件-write 文件操作本质文件描述符fd文件描述符的分配规则重定向 FILE缓冲区模拟实现缓冲区总结 理解文件系统磁盘物理结构存储结构逻辑结构 文件系统软硬链接 动静态库动态库和静态库生成…

Kafka上的优化经验

1. 平滑扩容 Motivation kafka扩容⼀台新机器的流程 假如集群有 3 个 broker ,⼀共有 4 个 TP ,每个 3 副本,均匀分布。现在要扩容⼀台机器, 新 broker 加⼊集群后需要通过⼯具进⾏ TP 的迁移。⼀共迁移 3 个 TP 的副…

JavaScript高级程序设计(第2版)——读书笔记

文章目录 第1章 JavaScript简介第2章 在HTML中使用JavaScript第3章 基本概念第4章 变量、作用域、内存问题第5章 引用类型第6章 面向对象的程序设计第7章 匿名函数第8章 BOM第9章 客户端检测第10章 DOM第11章 DOM2和DOM3第12章 事件第13章 表单脚本第14章 错误处理与调试第15章…

java 的参数传递

一、疑惑引入 首先&#xff0c;我们从一个例子来引出这个问题&#xff1a; public static void main(String[] args) throws IOException {List<String> mockList Lists.newArrayList("a", "b");System.out.println("1: " mockList);L…

【GAMES101】04 Viewing Transformation

1.View/Camera Transformation&#xff08;视图变换&#xff09; 1、将准备拍摄的对象移动到场景中指定位置。&#xff08;模型变换&#xff0c;Model Transform&#xff09; - 模型导入场景中从模型坐标系转换成世界坐标系 2、将相机移动到准备拍摄的位置&#xff0c;将它对准…

【网络】-- TCP协议

其中TCP就属于传输层&#xff0c;并且端口号也是在传输层起作用。 目录 TCP协议报头 可靠性 32位序号 16位窗口大小 六个标记位 三次握手四次挥手 RST PSH URG 16位紧急指针 FIN socksetopt 可靠性机制 确认应答(ACK)机制 超时重传机制 连接管理机制 三大机…

03-角色维护 尚筹网

一、分页操作 目标 将角色数据进行分页显示 思路 点击后台主页面的权限管理->角色维护&#xff0c;通过view-controller进入角色分页显示的页面&#xff0c;浏览器加载页面的数据并初始化一些数据&#xff08;页码、页大小、关键词等&#xff09;&#xff0c;调用分页函…

基于Open3D的点云处理3-可视化

可视化接口 API open3d.visualization.draw_geometries(*args, **kwargs)重载函数1 draw_geometries(geometry_list, window_name’Open3D’, width1920, height1080, left50, top50, point_show_normalFalse, mesh_show_wireframeFalse, mesh_show_back_faceFalse)geometry…

B树

文章目录 B树的定义和性质为什么需要B树B树的定义 B树的模拟实现节点的数据结构B树的插入B树的删除 B树的模拟实现 B树的定义和性质 我们之前已经对 平衡搜索二叉树有了一定的了解&#xff0c;学习了两种树——AVL树 和 红黑树&#xff0c;下面介绍一下B树 为什么需要B树 数…

Nacos 服务网格⽣态

博主介绍&#xff1a;✌全网粉丝4W&#xff0c;全栈开发工程师&#xff0c;从事多年软件开发&#xff0c;在大厂呆过。持有软件中级、六级等证书。可提供微服务项目搭建与毕业项目实战、定制、远程&#xff0c;博主也曾写过优秀论文&#xff0c;查重率极低&#xff0c;在这方面…

为一加七Pro(LineageOs17.1 4.14内核版本)编译KernelSu

编译内核 因为一加七的内核版本是4.14&#xff0c;所以想使用kernelsu&#xff0c;需要自己将kernelsu编译到内核里。 我使用的系统是&#xff1a;LineageOS17.1&#xff0c;对于之后的lineage版本同样适用&#xff0c;只是拉取的源代码不一样。刷机教程请看&#xff1a;wsl2…