LSB顺序替换嵌入与提取实现

一:代码

%LSB顺序替换嵌入和提取
%输入:载体图像C,秘密消息M
%显示:载体图像、载密图像、LSB平面分布情况
%嵌入消息明文message.txt,提取消息为secret.txt

C='Lena.bmp';
M='message.txt';
C1=imread(C);
%调用嵌入函数lsbshide
[C_M,C_C,L]=lsbshide(C,M);
%调用提取函数lsbsget
lsbsget('Lena_S.bmp',L);

%画图展示
subplot(1,3,1);imshow(C1);title('载体图像','FontSize',20);
subplot(1,3,2);imshow(C_M);title('载密图像','FontSize',20);
subplot(1,3,3);imshow(mat2gray(C_C));title('LSB平面分布情况图','fontsize',20);

调用的子函数:lsbshide.m

% LSB顺序替换嵌入算法--2016年6月24日
% 输入:载体C、秘密消息M。
% 输出:载密图像C_M、位平面C_C
% 1、将秘密消息M转化为二进制M1;
% 2、将转化为二进制的秘密消息M1嵌入到载体图像的LSB平面
%3、将载密图像C_M减去载体图像C,查看嵌入信息情况
% ---------------------------------------------------
% 函数功能介绍:实现LSB顺序替换嵌入
% 使用示例:function      [C_M,C_C,L]=lsbshide('Lena.bmp','message.txt');
%输入输入参数介绍:
%C:载体图像
%M:秘密消息
%C_M:载密图像
%C_C:lsb平面

function [C_M,C_C,L]=lsbshide(C,M)
C=imread(C);%读取图像并存放到C中
C_M=C;
fileID=fopen(M,'r');%打开文件
[M,L]=fread(fileID,'ubit1');%读取文件的内容,并以二进制方式存放到向量M中

%将二进制的秘密消息M嵌入到载密图像的LSB面
[m,n]=size(C);
p=1;%嵌入计数器
for i=1:m
    for j=1:n
        C_M(i,j)=C(i,j)-mod(C(i,j),2)+M(p,1);%嵌入方法是先将LSB置零,然后加上秘密消息中的对应的0或1
        if L==p   %嵌入终止条件:当嵌入的个数为秘密消息的长度时,跳出循环,不再嵌入
         break;
        end
       p=p+1;
 end
 if L==p    %嵌入终止条件:当嵌入的个数为秘密消息的长度时,跳出循环,不再嵌入
    break;
 end
end

imwrite(C_M,'Lena_S.bmp','bmp');

 %查看嵌入信息情况:将载密图像减去载体图像
for i=1:m
    for j=1:n
        C_C(i,j)=C_M(i,j)-C(i,j);
   end
 end

调用子函数:lsbsget.m

%LSB顺序替换提取--2016年6月27
%输入:载密图像C_M,嵌入长度L
%输出:秘密消息向量S
%输入输出格式:S=lsbsget('Lena_S.bmp',L)
%步骤:
%1、读取载密图像C_M
%2、读出LSB平面中0、1存入S中
%3、将二进制向量S转化为ASCII码并存放到文本文件secret.txt中

function S=lsbsget(C_M,L)
%读取载密图像矩阵
C_M1=imread(C_M);
[m,n]=size(C_M1);
S=zeros(1,L);
%读出LSB平面中0、1存入S中
for i=1:m
    for j=1:n
        if (i-1)*m+j>L%判断嵌入长度是否大于L,若大于L,则终止循环
            break;
        end
        S(1,(i-1)*m+j)=mod(C_M1(i,j),2);
    end
    if (i-1)*m+j>L%判断嵌入长度是否大于L,若大于L,则终止循环
         break;
    end
end

%将二进制向量S转化为ASCII码并存放到文本文件secret中
fileID=fopen('secret.txt','w');
a=L/8;%计算字符个数
SC=zeros(1,a);
for i=1:a
    b=0;
    for j=1:8
        b=b+S(1,(i-1)*8+j)*power(2,j-1);
    end
    SC(1,i)=b;
    fwrite(fileID,SC(1,i),'char');
end
fclose(fileID);

二、实验结果展示
1、载体图像、载密图像、LSB平面分布情况

Paste_Image.png

2、嵌入的消息message.txt,提取的消息secret.txt

Paste_Image.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,772评论 6 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,458评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,610评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,640评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,657评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,590评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,962评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,631评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,870评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,611评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,704评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,386评论 4 319
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,969评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,944评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,179评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,742评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,440评论 2 342

推荐阅读更多精彩内容