【LSB】图片隐写文档大纲

第一章 绪论
1.1研究背景
1.2研究意义
1.3主要工作

第二章 图片隐写和LSB算法
2.1关于图片隐写术
2.2LSB算法

第三章 系统设计与实现
3.1图像的加载
3.2文本的预编码
3.3文字编码
3.4图片编码

第四章 功能测试及线上部署
4.1功能测试
4.2线上部署

第五章 总结及展望
5.1总结
5.2展望

第一章 绪论

1.1研究背景

	随着信息技术和个性化网络服务的飞速发展, 人们越来越依赖于同步个人数据到网络服务平台, 如Dropbox、百度云、有道云笔记等, 以便在社交网络中动态更新和共享。然而, 在体验网络服务带来的资源共享、便捷交流的同时, 用户的个人数据也面临着被窃取的风险。这给人们的个人信息、财产安全造成极大的影响。因此信息隐藏技术显得尤为重要

计算机技术发展和Internet广泛应用,越来越多的信息在网络上传输,在给 人们方便的同时,也带来极大安全隐患。作为信息的主要载体图像,其安全性也倍受关注。 图像加密作为保障图像信息安全的核心思路,已成为目前的研宄热点。
信息时代的发展,信息安全扮演着越来越重要的角色,在某些时候,其甚至威胁到国家的安全。密写技术属于信息安全的范畴,是一种将待传输信息嵌入到某种载体内,借助载体来掩盖秘密信息传输的技术,与更为常用的加密技术相比,它在信息传输时更为隐僻。JPEG标准是当今应用最为普遍的图片格式,据统计,互联网中80%的图片采用JPEG压缩标准,因此研究图片的密写对于保障信息的安全具有重要意义

1.2研究意义

依据目前信息传递的主要方式,选取图片作为研究对象有重要意义。上到公安、银行系统的身份证照片、银行卡照片、个人肖像照片等涉及到个人隐私信息图像的存档和管理,下到个人生活隐私照片的保护,都存在图片的存储安全问题。
随着网络带宽的提升,个人移动设备的不断普及,人们对于多媒体的消费需求随着生活水平的提高也不断增强,特别是近年来,随着高清数字图像逐渐普及,图像也越来越频繁地通过网络传输和存储,相应需要的存储空间和占用的网络开销随之增大,这带来了两方面的需求。一方面,由于计算机和网络以及各类黑客工具的普及,传输多媒体数据时容易被恶意监听甚至篡改,许多媒体内容有一定的保密性要求,因而图像的安全传输变得越来越重要。此外,随着用户的增多,高清图像将占据更多的网络开销,如何在保护图像隐私的前提下,同时加强图像的压缩以尽可能减少网络带宽需要,对于用户而言也变得更加急切。

1.3主要工作

网页技术介绍

  1. HTML称为超文本标记语言,是一种标识性的语言。它包括一系列标签.通过这些标签可以将网络上的文档格式统一,使分散的Internet资源连接为一个逻辑整体。它能独立于各种操作系统平台(如UNIX, Windows等)。使用HTML语言,将所需要表达的信息按某种规则写成HTML文件,通过专用的浏览器来识别,并将这些HTML文件“翻译”成可以识别的信息,即现在所见到的网页。
    HTML 5:HTML5是公认的下一代Web语言,极大地提升了Web在富媒体、富内容和富应用等方面的能力,被喻为终将改变移动互联网的重要推手
  2. CSS:层叠样式表(英文全称:Cascading Style Sheets)是一种用来表现HTML(标准通用标记语言的一个应用)或XML(标准通用标记语言的一个子集)等文件样式的计算机语言。CSS不仅可以静态地修饰网页,还可以配合各种脚本语言动态地对网页各元素进行格式化。
    CSS 能够对网页中元素位置的排版进行像素级精确控制,支持几乎所有的字体字号样式,拥有对网页对象和模型样式编辑的能力。CSS简化了网页的格式代码,外部的样式表还会被浏览器保存在缓存里,加快了下载显示的速度,也减少了需要上传的代码数量(因为重复设置的格式将被只保存一次)。只要修改保存着网站格式的CSs样式表文件就町以改变整个站点的风格特色,在修改页面数量庞大的站点时,显得格外有用。这就避免了一个个网页的修改,大大减少了工作量。
  3. JavaScript是一种直译式脚本语言,是一种动态类型、弱类型、基于原型的语言,内置支持类型。它的解释器被称为JavaScript引擎,为浏览器的一部分,广泛用于客户端的脚本语言,最早是在HTML(标准通用标记语言下的一个应用)网页上使用,用来给HTML网页增加动态功能。
    JavaScript是一种属于网络的脚本语言,已经被广泛用于Web应用开发,常用来为网页添加各式各样的动态功能,为用户提供更流畅美观的浏览效果。通常JavaScript脚本是通过嵌入在HTML中来实现自身的功能的。
  4. 是一种解释性脚本语言(代码不进行预编译)
  5. 主要用来向HTML(标准通用标记语言下的一个应用)页面添加交互行为。
  6. 可以直接嵌入HTML页面,但写成单独的js文件有利于结构和行为的分离。
  7. 跨平台特性,在绝大多数浏览器的支持下,可以在多种平台下运行(如Windows、Linux、Mac、Android、iOS等)。
    Javascript脚本语言同其他语言一样,有它自身的基本数据类型,表达式和算术运算符及程序的基本程序框架。Javascript提供了四种基本的数据类型和两种特殊数据类型用来处理数据和文字。而变量提供存放信息的地方,表达式则可以完成较复杂的信息处理。

第二章

2.1关于图片隐写术

隐写术是一门关于信息隐藏的技巧与科学,所谓信息隐藏指的是不让除预期的接收者之外的任何人知晓信息的传递事件或者信息的内容。隐写术的英文叫做Steganography,来源于特里特米乌斯的一本讲述密码学与隐写术的著作Steganographia,该书书名源于希腊语,意为“隐秘书写”。

2.2LSB算法

维基百科LSB:
最低有效位(英语:Least Significant Bit,lsb)是指一个二进制数字中的第0位(即最低位),权值为2^0,可以用它来检测数的奇偶性。

利用js的hideText函数提取各个像素,例如(255,255,255),转换成二进制例如(1111111,1111111,1111111),修改后一位至两位的话肉眼几乎无法辨别。

把所想隐含的信息转换成二进制ascall码分别填入每个像素的最后一位(可以是最后两位,或者一个像素每一种颜色都填入,在不影响的情况下随意修改)

LSB加密是信息隐藏中最基本的方法。由于人们识别声音或图片的能力有限,因此我们稍微改动信息的某一位是不会影响我们识别声音或图片的。

采用图片的最低有效位(LSB)进行隐写。其原理就是图片的像素点都是由三原色(RGB)构成(如下图),由这三原色可以组成各种颜色,如CSS里的颜色定义#FFFFFF,即是三原色的16进制值写法,每个颜色各占用8bit。而LSB隐写就是修改像素中每个颜色值的最低位值,最后通过这种方式达到隐写的效果

在这里插入图片描述
譬如我们想把’A’隐藏进来的话,如下图,就可以把A转成16进制的0x61再转成二进制的01100001,再修改为红色通道的最低位为这些二进制串。
在这里插入图片描述
解密的话通过读取最后一位的位值,每八位读取一个acall码或每16位读取一个unicode编码
,只要图片足够的大,解密的文字就越多

第三章 系统设计与实现

3.1 图片的加载

传统的图片加载需要将图片上传到服务器,再由服务器加载出来,而现在可以使用FileReader对象将图像加载到DOM中而无需往返服务器,这样就大大提高了隐私性。
在这里插入图片描述

再将我们读取到的数据加载在一个 Image对象中,然后我们将其输入到我们的 canvas画布中以进行像素操作。
canvas包含了我们图像的所有信心
在这里插入图片描述

再使用FileReader对象的readAsDataURL方法可以将读取到的文件编码成Data URL。Data URL是一项特殊的技术,可以将资料(例如图片)内嵌在网页之中,不用放到外部文件。使用Data URL的好处是,您不需要额外再发出一个HTTP 请求到服务器端取得额外的资料。
在这里插入图片描述
这样我们就获取了该图片的url,方便后面的下载

3.2获取图片所有信息

在这里插入图片描述
通过Context(‘2d’)可以获取图片的所有信息
在这里插入图片描述
再将其加载再imgData中传入ImageColorMask的color数组中

3.21信息导入

可以看到这里有个对象的函数,里面传入的参数是图像和文本信息
可知我们最核心的加密方式就是在这个函数里
在这里插入图片描述
让我们看一下imagemask.js里的hideText函数
在这里插入图片描述
这里有用到新的对象
在这里插入图片描述
来看ImageColorMask里的函数

3.3文字编码

3.4图片编码

第四章 系统设计与实现

4.1功能测试

加密文字

首先这是一张很普通的名为me.jpg的
在这里插入图片描述

进入index首页
在这里插入图片描述
选中图片
在这里插入图片描述
在加密文字上框输入文字
我们输入
阜阳师范大学信息工程学院010101

在这里插入图片描述
在这里插入图片描述
下面就会显示一张图片:
在这里插入图片描述
下载下来即可

这样我们就获取了一张download.png图片
在这里插入图片描述

这张图片里就含有我们加密的文字了,如果解析的话,只需传入图片解密即可

刷新网页
上传上次下载的图片在这里插入图片描述
解密
在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

解密成功,这就是一个完整的图片加密解密的过程

加密图片

还是选择这张图片
在这里插入图片描述
选择另一个网页
上传
之后加密选择一张二维码

在这里插入图片描述

在这里插入图片描述
点击加密图片后,下方就会有一张图片

在这里插入图片描述
还是下载下来
一张download.png图片
下面进行图片的解密

上传刚下载的图片
在这里插入图片描述
选择解密图片即可
在这里插入图片描述

下面会有一个下载地址,这个地址背后就是我们那张二维码图片

在这里插入图片描述

在这里插入图片描述
这样一张头像里面就夹藏着另一张图片了

##4.2线上部署
因为码云相比较于github,网络延迟相对好很多,所以选择在码云上进行代码的部署。
选择到相应路径
当然你也可以选择部署在自己的网站上,因为这样部署比较方便而且免费
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在码云上新建一个代码仓库
这里就叫test web吧
在这里插入图片描述
然后将它的ssh复制下来
使用git remote add origin将它推荐到远端
在这里插入图片描述
git push -f origin master,可直接推送
在这里插入图片描述

在这里插入图片描述
推送成功,在服务上开启git pages即可
在这里插入图片描述
这样我们就有了一个静态的网站可以直接加密我们的图片了

http://discipline_exhausted.gitee.io/test-web

第五章 总结及展望

5.1总结

5.2展望

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/323161.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

.NET下使用HTTP请求的正确姿势

一、前言 去年9月份的时候我看到过外国朋友关于.NET Framework下HttpClient缺陷的分析后对HttpClient有了一定的了解。前几日也有园友写了一篇关于HttpClient的分析文章, 于是我想深入探索一下在.NET下使用HTTP请求的正确姿势。姿势不是越多越好, 而在于精不精。如果不深入了解…

【LSB】图片隐写主体函数

关于图像隐写 图像隐写是一种有效的方式来交换隐藏的消息,而不会引起怀疑。它的工作原理是用lbs算法将消息编码为图像像素的颜色值。 这种功能基于浏览器的最新特性比如File API和Canvas,如果你的浏览器不支持该该功能,请下载最新的浏览器。…

【Ajax】创建并封装

创建 <!DOCTYPE html> <html> <head><title></title><style>#button1{background:skyblue;border-radius:20px;width:100px;}</style> </head> <body> <button id"button1">按钮</button> <i…

ABP从入门到精通(2):aspnet-zero-core 使用MySql数据库

关于 asp.net zero core 项目的启动及说明&#xff0c;请观看我前面的博文ABP从入门到精通&#xff08;1&#xff09;&#xff1a;aspnet-zero-core项目启动及各项目源码说明 本操作对于ABP默认项目应该也是适用的&#xff01; 一.移除默认的SqlServer相关程序包 需要移除“MyC…

Visual Studio 15.5预览版先睹为快

Microsoft延续了Visual Studio 2017快速迭代开发的步伐&#xff0c;最新发布了15.5预览版&#xff0c;这是VS2017这一广受欢迎的IDE自发布以来的第五次更新&#xff0c;该预览版的发布使用户可以先睹为快。 该预览版启用了一个称为“Stepping Back”的调试历史新特性。IntelliT…

【Android】实现页面跳转

对比html&#xff0c;安卓的页面跳转要难的多。 html只需要一个a标签即可实现页面的跳转&#xff0c;而安卓要分三步走 第一步 在activity_main.xml创建一个按钮 <Buttonandroid:id"id/btn1"android:layout_width"match_parent"android:layout_heigh…

ABP从入门到精通(3):aspnet-zero-core 使用Redis缓存

一.Redis是什么&#xff1f; redis是一个key-value存储系统。和Memcached类似&#xff0c;它支持存储的value类型相对更多&#xff0c;包括string(字符串)、list(链表)、set(集合)、zset(sorted set --有序集合)和hash&#xff08;哈希类型&#xff09;。这些数据类型都支持pus…

【Mysql】win10上Mysq的l安装

最近想学习java的jdbc&#xff0c;完成注册登录系统&#xff0c;有了php的经验&#xff0c;&#xff0c;就简单多。但是php是基于wamp集成环境的&#xff0c;当时就是由于win10安装mysql老是错误&#xff0c;所以选择了集成环境&#xff0c;这对入门来讲降低了很大的难度。这次…

Entity Framework Core 2.0 使用代码进行自动迁移

一.前言 我们在使用EF进行开发的时候&#xff0c;肯定会遇到将迁移更新到生产数据库这个问题&#xff0c;前面写了一篇文章介绍了Entity Framework Core 2.0的入门使用&#xff0c;这里面介绍了使用命令生成迁移所需的SQL&#xff0c;然后更新到生产数据库的方法。这里还有另一…

【JDBC】各版本jar包下载网址及Tomcat下载

http://central.maven.org/maven2/mysql/mysql-connector-java/ 自己的mysql的版本号会在登录之后显示 Tomcat链接&#xff1a; 链接&#xff1a;https://pan.baidu.com/s/1bOMY_6hp7nV5KpU496YPlA 提取码&#xff1a;rerg

Mybatis中强大的功能元素:resultMap

转载自 Mybatis中强大的功能元素&#xff1a;resultMap 前言 在Mybatis中&#xff0c;有一个强大的功能元素resultMap。当我们希望将JDBC ResultSets中的数据&#xff0c;转化为合理的Java对象时&#xff0c;你就能感受到它的非凡之处。正如其官方所述的那样&#xff1a; re…

将编号为0和1的两个栈存放于一个数组空间V[m]中。

目录 1.题目描述 2.算法实现 1.题目描述 将编号为0和1的两个栈存放于一个数组空间V[m]中,栈底分别处于数组的两端。当第0号栈的栈顶指针top[0]等于-1时该栈为空&#xff1b;当第1号栈的栈顶指针top[1]等于m时该栈为空。两个栈均从两端向中间增长&#xff08;见图&#xff09;…

ASP.NET Core 2.0 依赖注入

问题 如何使用 ASP.NET Core 服务容器进行依赖注入&#xff1f; 答案 创建一个服务 public interface IGreetingService { string Greet(string to); } public class GreetingService : IGreetingService { public string Greet(string to){ return $"H…

面试 - 要不简单聊一下你对MySQL索引的理解?

转载自 面试 &#xff0d; 要不简单聊一下你对MySQL索引的理解&#xff1f; MySQL索引&#xff1f;这玩意儿还能简单聊&#xff1f;明显是在挖坑&#xff0c;幸好老夫早有准备&#xff0c;切听我一一道来。 一、索引是什么? 索引是帮助MySQL高效获取数据的数据结构。 二、…

ABP从入门到精通(4):使用基于JWT标准的Token访问WebApi

项目&#xff1a;asp.net zero 4.2.0 .net core&#xff08;1.1&#xff09; 版本 我们做项目的时候可能会遇到需要提供api给app调用&#xff0c;ABP动态生成的WebApi提供了方便的基于JWT标准的Token访问方式供我们访问API&#xff0c;不用在代码上做任何改动&#xff0c;很方便…

ASP.NET Core 2.0 + EF6 + Linux +MySql混搭

好消息&#xff01;特好消息&#xff01;同时使用ASP.NET Core 2.0和.NET Framework类库还能运行在linux上的方法来啦&#xff01; 是的&#xff0c;你没有看错&#xff01;ASP.NET Core 2.0&#xff0c;.NET Framework类库&#xff0c;linux通通都给你&#xff0c;不要998只要…

面试被问Mysql没答上来?阿里P5:总结了55道常见面试题,收藏一波

转载自 面试被问Mysql没答上来&#xff1f;阿里P5:总结了55道常见面试题&#xff0c;收藏一波 正文开始前&#xff0c;分享阿里 P8 高级架构师吐血总结的 《Java 核心知识体系&面试资料.pdf》, 非卖课程的哟&#xff01; 阿里 P8 级高级架构师吐血总结的一份 Java 核心知…

开源纯C#工控网关+组态软件(四)上下位机通讯原理

一、 网关的功能&#xff1a;承上启下 最近有点忙&#xff0c;更新慢了。感谢园友们给予的支持&#xff0c;现在github上已经有。目标是最好的开源组态&#xff0c;看来又近一步^^ 之前有提到网关是物联网的关键环节&#xff0c;它的作用就是承上启下。 下位机有下位机的语言…

微软Tech Summit 2017,等你来打Call

2017年10月31至11月3日&#xff0c;由微软举办的Tech Summit 2017技术暨生态大会将在北京盛大举办&#xff0c;要在北京连开四天。今年的技术大会看头十足&#xff0c;不仅有大咖级人物带来十二大主题课程&#xff0c;更有三天四场的主题之夜。微软技术大会最早是由微软技术教育…

ABP从入门到精通(5):.扩展国际化语言资源

ABP的有些组件使用的该组件自带的语言包资源&#xff0c;所以在有些时候会因为我们当前使用的语言对应的语言包不全&#xff0c;而造成日志一直记录WARN。ABP给我们提供了扩展语言包资源的接口&#xff0c;可以解决这个问题。 以下示例代码适用于ABP .net core版本。我要为名为…