一张图片能隐含千言万语之隐藏你的程序代码


Posted in HTML / CSS onDecember 13, 2012

我最近开发了我的第一个网页游戏:一个HTML5的视频智力游戏。开发的过程很有趣,我喜欢编程,但当实现了游戏逻辑后,我有了一个有趣的想法:为什么不想个办法把代码隐藏起来?起初我想到的是一些很简单的做法,比如禁止上下文菜单,以防右键点击时可以查看页面源代码。但这毫无意义,右键菜单不能用,人们仍然可以通过键盘快捷键或菜单栏里的“查看源文件”来观看源代码。

一张图片能隐含千言万语

这依赖于图片的体积。但我决定要把源代码加密存放到一张图片里。HTML5的画布(canvas)组件很适合干这种事情,因为它支持针对图像像素的操作。一个像素由四个值(通道)来表示:红,绿,蓝和alpha通道。它们的值的分布范围是从0到255。我的Javascript代码就是一个个的字符,每个字符都有一个ASCII对应值。ASCII值的范围也是0-255,所以,我想做的是,遍历画布上的每个像素,给每个像素设置3个代码字符的ASCII值作为它的RGB值,你可以通过charCodeAt函数轻松的取出这些字符。

复制代码
代码如下:

.charCodeAt(0)

生成的是一张色彩斑斓、很小的图片,它就是我的程序代码看看吧:

解码的时候,我只需要把这个图片画到画布上,遍历像素点,取出r,g,b值所代表的字符:

复制代码
代码如下:

String.fromCharCode(code)

把它们连接成一个大的字符串,这就是你的代码了——可执行的代码。

这样就能保护你的源代码了吗?

其实不能——一个有经验的(甚至没有经验的)程序员仍然能够知道如何去解码图片,取出里面的代码,但我想这是能防止那些怀着不良商业目的人偷盗你的的代码的第一步措施——而那些能够想出如何解码的程序员(大部分)都不是来剽窃的

这种方法的主要缺陷
这种技术只能应用在支持HTML5画布(canvas)技术的现代浏览器里,IE6、IE8 里肯定是不行的。甚至有些现代的浏览器对于图片的alpha通道的编码也有支持问题,所以,每个像素点你只能放3个字符——一个100×100大小的图片可以存放3万个文本字符。

你还有其它简单的能防止别人拷贝你的代码的方法吗?我们当然可以把字符进行加密,但如何保证你的解密步骤能不被人轻易的破解呢?告诉我你的想法吧!

HTML / CSS 相关文章推荐
非常震撼的纯CSS3人物行走动画
Feb 24 HTML / CSS
CSS3 仿微信聊天小气泡实例代码
Apr 05 HTML / CSS
css3+伪元素实现鼠标移入时下划线向两边展开的效果
Apr 25 HTML / CSS
html5-websocket基于远程方法调用的数据交互实现
Dec 04 HTML / CSS
html5 button autofocus 属性介绍及应用
Jan 04 HTML / CSS
HTML5中微数据概述及在搜索引擎中的使用举例
Feb 07 HTML / CSS
html5菜单折纸效果
Apr 22 HTML / CSS
Html5大文件断点续传实现方法
Dec 05 HTML / CSS
canvas探照灯效果的示例代码
Nov 30 HTML / CSS
遮罩层 + Iframe实现界面自动显示的示例代码
Apr 26 HTML / CSS
HTML5中在title标题标签里设置小图标的方法
Jun 23 HTML / CSS
AmazeUI 点击元素显示全屏的实现
Aug 25 HTML / CSS
HTML5 新旧语法标记对我们有什么好处
Dec 13 #HTML / CSS
HTML5自定义data-* data(obj)属性和jquery的data()方法的使用
Dec 13 #HTML / CSS
HTML5 Web存储方式的localStorage和sessionStorage进行数据本地存储案例应用
Dec 09 #HTML / CSS
HTML5 Web Database 数据库的SQL语句的使用方法
Dec 09 #HTML / CSS
html5 浏览器支持 如何让所有的浏览器都支持HTML5标签样式
Dec 07 #HTML / CSS
html5-websocket基于远程方法调用的数据交互实现
Dec 04 #HTML / CSS
HTML5 Canvas像素处理使用接口介绍
Dec 02 #HTML / CSS
You might like
消息持续发送的完整例子
2006/10/09 PHP
针对初学PHP者的疑难问答(2)
2006/10/09 PHP
destoon各类调用汇总
2014/06/20 PHP
从wamp到xampp的升级之路
2015/04/08 PHP
thinkphp框架实现路由重定义简化url访问地址的方法分析
2020/04/04 PHP
firefox插件Firebug的使用教程
2010/01/02 Javascript
js 左右悬浮对联广告代码示例
2014/12/12 Javascript
浅析node连接数据库(express+mysql)
2015/11/30 Javascript
基于Turn.js 实现翻书效果实例解析
2016/06/20 Javascript
深入理解JavaScript中的预解析
2017/01/04 Javascript
探索webpack模块及webpack3新特性
2017/09/18 Javascript
React手稿之 React-Saga的详解
2018/11/12 Javascript
微信小程序template模板与component组件的区别和使用详解
2019/05/22 Javascript
[04:26]2014DOTA2国际邀请赛-Newbee顺利进入胜者组决赛 独家专访战神7
2014/07/19 DOTA
Python修改Excel数据的实例代码
2013/11/01 Python
python模糊图片过滤的方法
2018/12/14 Python
Python3 关于pycharm自动导入包快捷设置的方法
2019/01/16 Python
Python分支语句与循环语句应用实例分析
2019/05/07 Python
python3 线性回归验证方法
2019/07/09 Python
python切片的步进、添加、连接简单操作示例
2019/07/11 Python
基于Django的乐观锁与悲观锁解决订单并发问题详解
2019/07/31 Python
python BlockingScheduler定时任务及其他方式的实现
2019/09/19 Python
解决django后台管理界面添加中文内容乱码问题
2019/11/15 Python
python根据文本生成词云图代码实例
2019/11/15 Python
Python通过4种方式实现进程数据通信
2020/03/12 Python
HTML里显示pdf、word、xls、ppt的方法示例
2020/04/14 HTML / CSS
关于Assembly命名空间的三个面试题
2015/07/23 面试题
服装设计专业自荐书范文
2013/12/30 职场文书
初中生评语大全
2014/04/24 职场文书
银行反洗钱宣传活动总结
2015/05/08 职场文书
学校学期工作总结
2015/08/13 职场文书
老舍《猫》教学反思
2016/02/17 职场文书
golang switch语句的灵活写法介绍
2021/05/06 Golang
基于Redis延迟队列的实现代码
2021/05/13 Redis
关于python类SortedList详解
2021/09/04 Python
Python爬虫入门案例之爬取二手房源数据
2021/10/16 Python