图像隐写之使用PHP隐藏图像中的文本

2019-04-01 23:23:27

隐写术是一门研究隐藏信息的科学艺术,通过隐写术,可以只让发送者和接收者知道隐藏的信息。

图像隐写术则是研究将数据隐藏在图像中,通过该技术可以防止无关用户发现这些隐藏的信息或数据。

相关的原理

图像都是由很小的点组成的,这些点就是像素。每个像素由三个字节来表示:一个代表红(Red),一个代表绿(Green),一个代表蓝(Blue)。这三种颜色的组合决定了像素的实际颜色。

红色:

二进制:11001001

十进制:201

绿色:


二进制:11111000

十进制:248(原文此处为201,实际应为248)

蓝色:

二进制:00000011

十进制:3

这一组合呈现的像素颜色是橙色。

图像隐写的基本原理就是修改LSB(Least Significant Bit,最不重要的那一bit)并不会被人眼察觉到。所以我们修改RGB的LSB值来存储隐藏信息,同时不影响图像的颜色。

在这个例子中,我们仅仅修改蓝色的LSB,但是如果我们想的话,也可以修改所有的红,绿和蓝的成分。不过只修改蓝色的LSB,我们可以隐藏的信息更少一些。我们也可以将要隐藏信息的长度存储到图像中,不过本教程中还没有做这一点。

假设我们现在要将1101藏到图片中。

首先我们要得到图片中每个像素的RGB值,因为我们要隐藏4bit的数据,而且我们要修改蓝色的部分,所以我们需要4个像素。

假设图片前4个像素的RGB值如下:

11001100 10010001 00101011

00011000 11110000 11111110

11100010 00100101 01010101

11111101 00001010 01000011

现在,我们将这4个RGB值最后的bit替换成1101,

现在新的RGB值变成了:

11001100 10010001 00101011

00011000 11110000 11111111

11100010 00100101 01010100

11111101 00001010 01000011

加粗的最后一bit,就是我们要隐藏到图片的信息。

现在将新的RGB值应用到像素,因为人眼并不会注意到这种改变,所以图片看起来还是一样的。

加密的部分到现在就完成了,接下来我们将解密隐藏在图片的信息。

为了达到这一点,我们需要取出每个像素的RGB值,然后合并LSB来得到我们隐藏的信息。

用PHP实现

我们需要一张图片和3个php脚本来实现基本的图像隐写。

encrypt.php

decrypt.php

functions.php

1.jpg


encrypt.php

include('functions.php');

$message_to_hide = 'hello';

$binary_message = toBin($message_to_hide);

$message_length = strlen($binary_message);

$src = '1.jpg';

$im = imagecreatefromjpeg($src);

for($x=0;$x<$message_length;$x++){

$y = $x;

$rgb = imagecolorat($im,$x,$y);

$r = ($rgb >>16) & 0xFF;

$g = ($rgb >>8) & 0xFF;

$b = $rgb & 0xFF;

$newR = $r;

$newG = $g;

$newB = toBin($b);

$newB[strlen($newB)-1] = $binary_message[$x];

$newB = toString($newB);

$new_color = imagecolorallocate($im,$newR,$newG,$newB);

imagesetpixel($im,$x,$y,$new_color);

}

echo $x;

imagepng($im,'simple.png');

imagedestroy($im);

?>

decrypt.php

include('functions.php');

$src = 'simple.png';

$im = imagecreatefrompng($src);

$real_message = '';

for($x=0;$x<40;$x++){

$y = $x;

$rgb = imagecolorat($im,$x,$y);

$r = ($rgb >>16) & 0xFF;

$g = ($rgb >>8) & 0xFF;

$b = $rgb & 0xFF;

$blue = toBin($b);

$real_message .= $blue[strlen($blue)-1];

}

$real_message = toString($real_message);

echo $real_message;

die;

?>


functions.php

function toBin($str){

$str = (string)$str;

$l = strlen($str);

$result = '';

while($l--){

$result = str_pad(decbin(ord($str[$l])),8,"0",STR_PAD_LEFT).$result;

}

return $result;

}

function toString($binary){

return pack('H*',base_convert($binary,2,16));

}

?>

更多的信息可以查看这个视频:

视频地址:yotube: https://youtu.be/qH0wLIwZa0U (自备梯子)


  • 2020-02-24 18:43:54

    百度地图JS关于规划路线偏离预警的解决方式

    说实在的这个解决方案有点low,我并不会很赞成,效率有点低。如果多的话,很是耗费资源。 我推荐使用矩形来解决这个问题,而不是圆形。 当日用矩形的话,就要确保轨迹是折线的,而不是弧线等。

  • 2020-02-24 18:45:33

    巧妙解决百度地图加偏纠偏问题

    所谓的加偏,就是将真实坐标加上一定的偏移量,而这个偏移量又不是线性的,不同地区偏移不一样,但同一地区偏移量却差不多,因此,有人就使用了个暴力破解的方法,

  • 2020-02-24 18:48:34

    规划驾车路线和途径点及判断车辆路线偏移

    项目需求需要利用百度地图构建路线并支持设置途径点,以及可以实时监控车辆是否偏移路线;两种方案。 写了比较完整的注释了,替换ak可直接看效果,规划驾车路线和途径点及判断车辆路线偏移

  • 2020-02-25 15:15:56

    nuxtjs全栈

    Nuxt.js 依据 pages 目录结构自动生成 vue-router 模块的路由配置。 要在页面之间使用路由,我们建议使用<nuxt-link> 标签。

  • 2020-02-25 19:24:08

    IDEA 简单的正则匹配

    IDEA在进行查看或替换的时候,勾选Regex 选项就可以进行正则匹配查找了 几个简单实用的正则:

  • 2020-02-26 20:16:49

    一条简单的命令就可以将 stylus 语法转换为 scss 语法

    因为早期有个项目用到了 stylus,stylus 开发起来很爽,但 stylus 基于缩进的代码在修改的时候不是很方便,加上所在团队开发使用的都是 SCSS ,为了便于维护和统一,准备将项目中的 stylus 替换成 SCSS。手动转换 stylus 浪费时间,且出错率大,当时在想也许别人也有这样的需求呢,所以就做了这样一个项目。请各位大佬动动你们发财的小手,给我点个 star,不胜感激。^_^

  • 2020-02-27 09:01:32

    npm yarn 命令对比

    Yarn 是 Facebook, Google, Exponent 和 Tilde 开发的一款新的 JavaScript 包管理工具。就像我们可以从官方文档了解那样,它的目的是解决这些团队使用 npm 面临的少数问题.