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


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 border-radius属性详解
Jul 05 HTML / CSS
CSS3 please 跨浏览器的CSS3产生器
Mar 14 HTML / CSS
实列教程 一款基于jquery和css3的响应式二级导航菜单
Nov 13 HTML / CSS
CSS中越界问题的经典解决方案【推荐】
Apr 19 HTML / CSS
CSS3模拟动画下拉菜单效果
Apr 12 HTML / CSS
HTML5实现的震撼3D焦点图动画的示例代码
Sep 26 HTML / CSS
HTML5之SVG 2D入门2—图形绘制(基本形状)介绍及使用
Jan 30 HTML / CSS
html5小技巧之通过document.head获取head元素
Jun 04 HTML / CSS
推荐WEB开发者最佳HTML5和CSS3代码生成器
Nov 24 HTML / CSS
HTML5 canvas基本绘图之绘制五角星
Jun 27 HTML / CSS
HTML5 video进入全屏和退出全屏的实现方法
Jul 28 HTML / CSS
使用CSS定位HTML元素的实现方法
Jul 07 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
PHP提取中文首字母
2008/04/09 PHP
Windows下的PHP安装pear教程
2014/10/24 PHP
WordPress主题制作之模板文件的引入方法
2015/12/28 PHP
PHP实现原生态图片上传封装类方法
2016/11/08 PHP
php使用parse_str实现查询字符串解析到变量中的方法
2017/02/17 PHP
thinkPHP5实现的查询数据库并返回json数据实例
2017/10/23 PHP
详解php中curl返回false的解决办法
2019/03/18 PHP
PHP实现基于状态的责任链审批模式详解
2019/05/31 PHP
Laravel中GraphQL接口请求频率实战记录
2020/09/01 PHP
JavaScript的9个陷阱及评点分析
2008/05/16 Javascript
JSON 和 JavaScript eval使用说明
2010/06/13 Javascript
jQuery查询数据返回object和字符串影响原因是什么
2013/08/09 Javascript
获得Javascript对象属性个数的示例代码
2013/11/21 Javascript
javascript的解析执行顺序在各个浏览器中的不同
2014/03/17 Javascript
9款2014最热门jQuery实用特效推荐
2014/12/07 Javascript
js控制元素显示在屏幕固定位置及监听屏幕高度变化的方法
2015/08/11 Javascript
js格式化输入框内金额、银行卡号
2016/02/01 Javascript
Node.js本地文件操作之文件拷贝与目录遍历的方法
2016/02/16 Javascript
一系列Bootstrap导航条使用方法分享
2016/04/29 Javascript
基于angular6.0实现的一个组件懒加载功能示例
2018/04/12 Javascript
使用vue-router与v-if实现tab切换遇到的问题及解决方法
2018/09/07 Javascript
性能优化篇之Webpack构建速度优化的建议
2019/04/03 Javascript
Vue axios 跨域请求无法带上cookie的解决
2020/09/08 Javascript
python多重继承新算法C3介绍
2014/09/28 Python
Python中的两个内置模块介绍
2015/04/05 Python
python 实现将字典dict、列表list中的中文正常显示方法
2018/07/06 Python
Python vtk读取并显示dicom文件示例
2020/01/13 Python
基于css3 animate制作绚丽的动画效果
2015/11/24 HTML / CSS
英国婴儿和儿童服装网站:Vertbaudet
2018/04/02 全球购物
捷克移动配件网上商店:ProMobily.cz
2019/03/15 全球购物
如何唤起类中的一个方法
2013/11/29 面试题
银行财务部实习生的自我鉴定
2013/11/27 职场文书
计算机相关的自我评价
2014/01/15 职场文书
2014年中秋寄语
2014/08/11 职场文书
Python机器学习之决策树和随机森林
2021/07/15 Javascript
MySQL数据库实验实现简单数据库应用系统设计
2022/06/21 MySQL