LSB图像信息隐藏实验(附源代码)

一、【实验目的】

1.掌握对图像的基本操作。

2.能够用 LSB 算法对图像进行信息隐藏

3.能够用 LSB 提取算法提取隐藏进图像的信息

4.能够反映 jpeg 压缩率与误码率之间的关系

二、【实验环境】
Win7系统 Matlab软件

三、【实验过程】

实验算法 1:LSB 嵌入

1.读取一副 256*256 大小的图片,判断是否为 RGB 图像。若为 RGB 图像,则读取图像的一层信息(如 R 层)。

通过读取图像的尺寸大小来判断是否为RGB图像。RGB图像是三维多彩图,size有3个参数,最小参数是3,只要判断读取到的图像大小大于2,就确定读入的是RBG图像

image=imread('1.jpg');
mysize=size(image);
if numel(mysize)>2
   ['the photo is a rgb style photo'] %是rgb图像输出到命令行窗口
image1=Hide_image(:,:,1);
%第三个参数 1代表的读取的是红层,但是没有将2,3层设为0,因为会叠加,所以显示出来的第一层图像还是灰色的

2.以二进制形式读取要嵌入到图片里的消息。并读取消息的长度(嵌入消息的长度不能超过图像位数)。

message=fopen('message.txt','r');
[msg,msg_len]=fread(message,'ubit1') %按位以二进制形式读取文本内容与长度
[m,n]=size(image1)  %读取bin_iamge1的行和列
Msg就是二进制的文本内容,msg_len就是二进制长度

3.产生与消息长度一致的一串随机数(不能相同)。

自定义一个randinterval函数来实现伪随机数的生成
产生的伪随机数是代表消息要隐藏的像素位置(行和列的信息)

%function[row,col]=randinterval(matric,count,key)
% 三个参数说明
% matrice为载体矩阵,即要隐藏信息的图层
% count为要嵌入信息的像素数量
% key为秘钥,随机数种子,自己设定
[row,col]=randinterval(image1,msg_len,1996);

4.按照产生的随机数的序列依次将图片层的最后一位改为消息的信息。即用消息替换图片的最后一位信息。

for 
  • 42
    点赞
  • 277
    收藏
    觉得还不错? 一键收藏
  • 9
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值