有什么把大量文本编码到图片里的方案吗?

我的需求:一个客户端,可以生成一张图片,其中要包含大约几千字的信息,这张图片通过 QQ 发送,对方从 QQ 上复制图片后,可以通过他的客户端还原出这些信息。

我的问题:通过什么方式编码这个图片,能使图片的尺寸比较小?

我第一反应是 qrcode,但我这个文字量,生成出来的码尺寸太大了。我这个场景不需要高容错能力,也不需要限制黑白两色,所以按理说可以更高效的才对。

有什么其它类似的替代方案吗?

相关文章

20 thoughts on “有什么把大量文本编码到图片里的方案吗?

  1. 直接用 RGB 表示原始二进制数据然后编码成 png,只要确保接受到的是原始文件当然就可以还原。

  2. 我曾经做过一种实现:利用图片像素值的奇偶性来存储二进制数据。
    比如用偶数像素值表示 0 、奇数像素值表示 1 。将待存储数据转成二进制,然后给定一张图片,遍历其每一个像素,根据二进制数据将对应像素加 1 或者维持不变( 255 时减 1 ),最后在存储数据的像素区段开头和结尾加上特殊的奇偶序列用作标志位即可。
    读取数据时只需要遍历像素找到标志位,然后根据两个标志位之间像素的奇偶性即可还原出原始二进制数据。

    这样做的好处就是对图片的破坏性很小,只是将少量像素的值加了 1 而已,存储数据的图片跟原图肉眼看不出区别,也没有强行附加非图片数据在图片文件中,计算下来一张 1080×1920 的 3 通道图片可以存储 700kb 左右的数据。
    问题的话就是图片数据隐藏在像素值中,因此图片不能被压缩( jpg 这种自带压缩的图片格式也不能用),另外实际测试发现存储数据后图片文件一样的会增大。

  3. 如果传原图,那大也无所谓。如果用了有损压缩,那你用彩色都不完全可靠。

    @cat 图种这种走实现漏洞的做法未必管用。

  4. 直接用 byte 数组填充 RGB 数据然后保存为 png 就行了,如果需要容错就把 1byte 数据拆成 4 段然后每段再*4,这样每 4 个像素存 3byte,压缩成 jpg 应该也能还原。

  5. 都客户端了,都 QQ 了,说明这个终端设备是联网的。那你这些信息为什么要放到图片上。。。放在服务器上不好吗?

  6. 无需加密的话,append 到 jpg 后面就行

    加密的话
    stegraphy
    搜这个一大堆工具,还有开源代码,按需取用

  7. 技术上没什么坑,通过网络发送的话有几点需要注意,只有以原图发送信息才不会丢,像 QQ 、微博、微信如果不是以原图发送,则会出现信息丢失。

  8. @misaka19000
    @MintZX

    是这样的, 客户端是一个棋盘小游戏,一个人走完以后点击确定,生成盘面截图,图里还有一个二维码包含棋局数据,图片发到 QQ 群里,群友用他的客户端读取图片后接着玩。现在的问题就是二维码太大了,几乎跟棋盘一样大,不好看。

    确实可以二维码只包含链接,客户端访问链接获取数据,不过还是想了解下有没有纯本地解决方案。

  9. @cat
    @mumbler
    @Jirajine
    @cheng6563
    @xiri
    @wiix

    类似图种这种二进制方式,经过 QQ 的压缩会被破坏吧?

  10. @shintendo 你这个场景,最重要的是兼容性问题。大多数用户在分享图片时,是不会注意勾选发送原图的按钮。因此就必须考虑用户图片被压缩的情况。楼上方案中图片直接二维码包含链接的形式就很通用,比较适合这种场景。

发表评论

电子邮件地址不会被公开。 必填项已用*标注