收藏 分销(赏)

LSB信息隐藏实验报告.doc

上传人:丰**** 文档编号:4834066 上传时间:2024-10-14 格式:DOC 页数:18 大小:689.72KB 下载积分:8 金币
下载 相关 举报
LSB信息隐藏实验报告.doc_第1页
第1页 / 共18页
LSB信息隐藏实验报告.doc_第2页
第2页 / 共18页


点击查看更多>>
资源描述
个人收集整理资料, 仅供交流学习, 勿作商业用途 Central South University 信息隐藏 实验报告 学院: 信息科学与工程学院 班级:信息安全1201 学号:0909121724 姓名:吕秋言 时间: 2018年6 月 实验一:基于图像的LSB信息隐藏 一、 实验目的 该实验为验证性实验。目的是通过实验使学生掌握经典信息隐藏算法,在Matlab环境下,编写基于图像的LSB信息隐藏算法程序。用Matlab函数实现LSB信息隐藏及提取,并进行分析。b5E2RGbCAP 二、 实验要求 1、实验前要做好充分准备,包括:复习实验所涉及的知识点,掌握Matlab编程语言和调试环境。 2、实验时注意记录实验过程中产生的数据、出现的问题及解决问题的方法。 3、理论联系实际,认真分析实验结果,回答思考题。 4、实验后完成实验报告,并附相关截图。 三、 实验环境 计算机<安装Visual C++ 6.0和Matlab 6.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,Least Significant Bits,最低有效位,将图像加密处理。     这次将通过位平面的切割之后,嵌入一张隐私图片,一些人的隐私交流很有可能通过这个,比如美国的某某人,当然这个只是最简单的。DXDiTa9E3d             位平面切割是将数字图像分解为位平面,比如上一篇文章讲到的图片的8位的数据类型,可以让我们每一位所起的作用。一边学的时候也带着疑问,为什么用bitget呢。RTCrpUDGiT       经过实验也证明自己的想法是正确的,首先bitget(X,Y>是拿到X二进制的值的Y位。 [plain] view plaincopy 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] view plaincopy 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] view plaincopy 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] view plaincopy 1. >> f = imread('lina.jpg'>。   2. >> g = bitget(f,8>。   这样g虽然是第八层的图像,但是都是二进制最高位的值,非0即1,而在为灰度图像看来,都是黑色。需要转换成二值图像。jLBHrnAILg [plain] view plaincopy 1. t = logical(g>。   接下来,我把自己的话嵌入到照片中。 [plain] view plaincopy 1. >> b = imread('love.jpg'>。   2. >> c = im2bw(b>。   这次是反过来,我们是要把一幅8位数据类型的图像嵌入到位图中,那首先要把8位的数据转换成二进制,用上面的im2bw。xHAQX74J0X 先看看嵌入到影响最大的一层的效果如何: [plain] view plaincopy 1. >> w = bitset(a,8,c>。   2. >> imshow(w>   接下来,嵌入到第一层: [plain] view plaincopy 1. >> w = bitset(a,1,c>。   2. >> imshow(w>   几乎是看不到什么的,当你想看看你嵌入什么图像时,只需要把被替换的第一层取出。 [plain] view plaincopy 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>。 If len_total>m*n error(′嵌入消息量过大,请更换图像′>。 end %p作为消息嵌入位数计数 p=1。 %调用随机间隔函数选取像素点 [row,col]=randinterval(ste_cover,len_total,key>。 %在LSB隐秘消息 for i=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 if p==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是提取的消息 function result=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>。 for i=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 if p==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 申明: 所有资料为本人收集整理,仅限个人学习使用,勿做商业用途。 18 / 18
展开阅读全文

开通  VIP会员、SVIP会员  优惠大
下载10份以上建议开通VIP会员
下载20份以上建议开通SVIP会员


开通VIP      成为共赢上传

当前位置:首页 > 包罗万象 > 大杂烩

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        抽奖活动

©2010-2026 宁波自信网络信息技术有限公司  版权所有

客服电话:0574-28810668  投诉电话:18658249818

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :微信公众号    抖音    微博    LOFTER 

客服