LSB信息隐藏实验报告.docx
- 文档编号:15004678
- 上传时间:2023-06-29
- 格式:DOCX
- 页数:16
- 大小:685.29KB
LSB信息隐藏实验报告.docx
《LSB信息隐藏实验报告.docx》由会员分享,可在线阅读,更多相关《LSB信息隐藏实验报告.docx(16页珍藏版)》请在冰点文库上搜索。
LSB信息隐藏实验报告
CentralSouthUniversity
信息隐藏
实验报告
学院:
信息科学与工程学院
班级:
信息安全1201
学号:
**********
姓名:
***
时间:
2018年6月
实验一:
基于图像的LSB信息隐藏
一、实验目的
该实验为验证性实验。
目的是通过实验使学生掌握经典信息隐藏算法,在Matlab环境下,编写基于图像的LSB信息隐藏算法程序。
用Matlab函数实现LSB信息隐藏及提取,并进行分析。
b5E2RGbCAP
二、实验要求
1、实验前要做好充分准备,包括:
复习实验所涉及的知识点,掌握Matlab编程语言和调试环境。
2、实验时注意记录实验过程中产生的数据、出现的问题及解决问题的方法。
3、理论联系实际,认真分析实验结果,回答思考题。
4、实验后完成实验报告,并附相关截图。
三、实验环境
计算机<安装VisualC++6.0和Matlab6.5以上版本)
四、实验原理
隐秘算法核心是将我们选取的像素点的最不重要位依次替换成秘密信息,以达到信息隐秘的目的。
嵌入过程包括选择一个图像载体像素点的子集{j1,…,jl(m>},然后在子集上执行替换操作像素cji←→mi,即把cji的LSB与秘密信息mi进行交换(mi可以是1或0>。
一个替换系统也可以修改载体图像像素点的多个比特,例如,在一个载体元素的两个最低比特位隐藏两比特、三比特信息,可以使得信息嵌入量大大增加但同时将破坏载体图像的质量。
在提取过程中,找出被选择载体图像的像素序列,将LSB(最不重要位>排列起来重构秘密信息,算法描述如下:
p1EanqFDPw
嵌入过程:
for(i=1。
i<=像素序列个数。
i++>
si←ci
for(i=1。
i<=秘密消息长度。
i++>
//将选取的像素点的最不重要位依次替换成秘密信息
sji←cji←→mi
提取过程:
for(i=1。
i<=秘密消息长度。
i++>
{i←→ji//序选取
mi←LSB(cji>
}
五、实验内容与步骤
基本演示
环境:
matlab
LSB,LeastSignificantBits,最低有效位,将图像加密处理。
这次将通过位平面的切割之后,嵌入一张隐私图片,一些人的隐私交流很有可能通过这个,比如美国的某某人,当然这个只是最简单的。
DXDiTa9E3d
位平面切割是将数字图像分解为位平面,比如上一篇文章讲到的图片的8位的数据类型,可以让我们每一位所起的作用。
一边学的时候也带着疑问,为什么用bitget呢。
RTCrpUDGiT
经过实验也证明自己的想法是正确的,首先bitget(X,Y>是拿到X二进制的值的Y位。
[plain] viewplaincopy
1.>> bitget(1,1>
2.
3.ans =
4.
5. 1
6.
7.>> bitget(1,2>
8.
9.ans =
10.
11. 0
12.
13.>>
那么我们可以想想,一幅8位的数字图像<无符号类型),最高是11111111<二进制),即2^8-1,255,用大腿一想,当然是第八位起决定性作用,假如有一百万零一这个数字,少了最前面的一个一和最后面的一个一可是两码事。
5PCzVD7HxA
举个例子,我切除图像的一部分:
[plain] viewplaincopy
1.>> q = f(122:
130,122:
130>。
2.>> imwrite(q,'verysmall.jpg'>。
3.>> f = imread('verysmall.jpg'>
4.
5.f =
6.
7. 155 154 149 141 134 129 129 130 127
8. 171 169 166 161 157 154 154 154 148
9. 173 171 170 170 171 171 169 168 163
10. 165 164 164 167 170 172 171 169 165
11. 166 166 167 169 171 172 172 171 168
12. 174 175 175 174 170 169 169 170 175
13. 179 182 181 174 164 159 160 164 172
14. 184 186 185 174 160 152 155 160 161
15. 182 185 180 167 154 149 148 148 149
每个像素点的值这么大。
接下来:
[plain] viewplaincopy
1.>> t = bitget(f,8>
2.
3.t =
4.
5. 1 1 1 1 1 1 1 1 0
6. 1 1 1 1 1 1 1 1 1
7. 1 1 1 1 1 1 1 1 1
8. 1 1 1 1 1 1 1 1 1
9. 1 1 1 1 1 1 1 1 1
10. 1 1 1 1 1 1 1 1 1
11. 1 1 1 1 1 1 1 1 1
12. 1 1 1 1 1 1 1 1 1
13. 1 1 1 1 1 1 1 1 1
14.
15.>>
最高位是决定性作用的一层。
所以,要嵌入图像,就要嵌入到第一层,影响最小。
[plain] viewplaincopy
1.>> f = imread('lina.jpg'>。
2.>> g = bitget(f,8>。
这样g虽然是第八层的图像,但是都是二进制最高位的值,非0即1,而在为灰度图像看来,都是黑色。
需要转换成二值图像。
jLBHrnAILg
[plain] viewplaincopy
1.t = logical(g>。
接下来,我把自己的话嵌入到照片中。
[plain] viewplaincopy
1.>> b = imread('love.jpg'>。
2.>> c = im2bw(b>。
这次是反过来,我们是要把一幅8位数据类型的图像嵌入到位图中,那首先要把8位的数据转换成二进制,用上面的im2bw。
xHAQX74J0X
先看看嵌入到影响最大的一层的效果如何:
[plain] viewplaincopy
1.>> w = bitset(a,8,c>。
2.>> imshow(w>
接下来,嵌入到第一层:
[plain] viewplaincopy
1.>> w = bitset(a,1,c>。
2.>> imshow(w>
几乎是看不到什么的,当你想看看你嵌入什么图像时,只需要把被替换的第一层取出。
[plain] viewplaincopy
1.>> y = bitget(w,1>。
2.>> imshow(logical(y>>
1、随机选取图像载体像素,实现隐秘消息的嵌入与提取
<1)隐秘消息的嵌入
%文件名:
randlsbhide.m
%函数功能:
本函数将完成随机选择LSB的信息隐秘,载体选用灰度BMP图
%输入格式举例:
[ste_cover,len_total]=randlsbhide(′glenna.bmp′,′message.txt′,′scover.bmp′,2001>LDAYtRyKfE
%参数说明:
%input是信息隐蔽载体图像%file是秘密消息文件
%output是信息隐秘后的生成图像
%key是随机间隔函数的密钥
function[ste_cover,len_total]=randlsbhide(input,file,output,key>Zzz6ZB2Ltk
%读入图像矩阵
cover=imread(input>。
ste_cover=cover。
ste_cover=double(ste_cover>。
%将文本文件转换为二进制序列
f_id=fopen(file,′r′>。
[msg,len_total]=fread(f_id,′ubit1′>。
%判断嵌入消息量是否过大
[m,n]=size(ste_cover>。
Iflen_total>m*n
error(′嵌入消息量过大,请更换图像′>。
end
%p作为消息嵌入位数计数
p=1。
%调用随机间隔函数选取像素点
[row,col]=randinterval(ste_cover,len_total,key>。
%在LSB隐秘消息
fori=1:
len_total
ste_cover(row(i>,col(i>>=ste_cover(row(i>,col(i>>-mod(ste_cover(row(i>,col(i>>,2>+msg(p,1>。
dvzfvkwMI1
ifp==len_total
break。
end
p=p+1。
end
ste_cover=uint8(ste_cover>。
imwrite(ste_cover,output>。
%显示实验结果
subplot(1,2,1>。
imshow(cover>。
title(′原始图像′>。
subplot(1,2,2>。
imshow(output>。
title(′隐藏信息的图像′>。
<2)编写函数比较两幅图像区别
%文件名:
compare.m
%函数功能:
本函数完成显示隐秘前后两幅图像的区别
%输入格式举例:
F=compare(′blenna.bmp′,′scover.bmp′>
%参数说明:
%original是原始载体图像
%hided是隐秘后的图像
%F是差值矩阵
functionF=compare(original,hided>
%读取原始载体图像矩阵
W=imread(original>。
W=double(W>/255。
%读取隐秘后图像矩阵
E=imread(hided>。
E=double(E>/255。
%将两图像矩阵相减,显示效果
%注意,MATLAB中矩阵相减只支持double型
imshow(mat2gray(F>>
<3)隐秘消息的提取
%文件名:
randlsbget.m
%函数功能:
本函数将完成提取隐秘于LSB上的秘密消息
%输入格式举例:
result=randlsbget(′scover.jpg′,56,′secret.txt′,2001>rqyn14ZNXI
%参数说明:
%output是信息隐秘后的图像
%len_total是秘密消息的长度
%goalfile是提取出的秘密消息文件
%key是随机间隔函数的密钥
%result是提取的消息
functionresult=randlsbget(output,len_total,goalfile,key>EmxvxOtOco
ste_cover=imread(output>。
ste_cover=double(ste_cover>。
%判断嵌入消息量是否过大
[m,n]=size(ste_cover>。
frr=fopen(goalfile,′a′>。
%p作为消息嵌入位数计数器,将消息序列写回文本文件
p=1。
%调用随机间隔函数选取像素点
[row,col]=randinterval(ste_cover,len_total,key>。
fori=1:
len_total
ifbitand(ste_cover(row(i>,col(i>>,1>==1
fwrite(frr,1,′bit1′>。
result(p,1>=1。
else
fwrite(frr,0,′bit1′>。
result(p,1>=0。
end
ifp==len_total
break。
end
p=p+1。
end
fclose(frr>。
2、顺序选取图像载体像素,实现隐秘消息的嵌入与提取
<1)隐秘消息的嵌入
%文件名:
lsbhide.m
%函数功能:
本函数将完成在LSB上的顺序信息隐秘,载体选用灰度BMP图
%输入格式举例:
[ste_cover,len_total]=lsbhide(′glenna.bmp′,′message.txt′,′scover.bmp′>SixE2yXPq5
%参数说明:
%input是信息隐蔽载体图像,为灰度BMP图
%file是秘密消息文件
%output是信息隐秘后生成图像
%ste_cover是信息隐秘后图像矩阵
%len_total是秘密消息的长度,即容量
function[ste_cover,len_total]=lsbhide(input,file,output>6ewMyirQFL
%读入图像矩阵
cover=imread(input>。
ste_cover=cover。
ste_cover=double(ste_cover>。
%将文本文件转换为二进制序列
f_id=fopen(file,′r′>。
[msg,len_total]=fread(f_id,′ubit1′>。
%判断嵌入消息量是否过大
[m,n]=size(ste_cover>。
iflen_total>m*n
error(′嵌入消息量过大,请更换图像′>。
end
%p作为消息嵌入位数计数
%生成信息隐秘后图像
imwrite(ste_cover,output>。
%显示实验结果
subplot(1,2,1>。
imshow(cover>。
title(′原始图像′>。
subplot(1,2,2>。
imshow(output>。
title(′隐藏信息的图像′>。
<2)调用函数compare.m比较两幅图像区别
<3)隐秘消息的提取
%文件名:
lsbget.m
%函数功能:
本函数将完成提取隐秘于LSB上的秘密消息
%输入格式举例:
result=lsbget(′scover.bmp′,56,′secret.txt′>kavU42VRUs
%参数说明:
%output是信息隐秘后的图像
%len_total是秘密消息的长度
%goalfile是提取出的秘密消息文件
%result是提取的消息
functionresult=lsbget(output,len_total,goalfile>
ste_cover=imread(output>。
ste_cover=double(ste_cover>。
%判断嵌入消息量是否过大
[m,n]=size(ste_cover>。
frr=fopen(goalfile,′a′>。
%p作为消息嵌入位数计数器,将消息序列写回文本文件
六:
实验小结:
通过这次实验使我掌握经典信息隐藏算法,在Matlab环境下,编写基于图像的LSB信息隐藏算法程序。
用Matlab函数实现LSB信息隐藏及提取,并进行分析,对顺序嵌入隐秘消息和随机嵌入隐秘消息两种方法的实现结果进行比较。
通过比较可得,顺序嵌入隐秘消息比随机嵌入隐秘消息更有序,代码更复杂,要求更严格,同时隐秘性也更好。
y6v3ALoS89
申明:
所有资料为本人收集整理,仅限个人学习使用,勿做商业用途。
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- LSB 信息 隐藏 实验 报告