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


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.0 图形构成实例练习二
Mar 19 HTML / CSS
常用的四种CSS透明属性介绍
Apr 12 HTML / CSS
一款CSS3实现多功能下拉菜单(带分享按)的教程
Nov 05 HTML / CSS
浅谈css3中的渐进增强和优雅降级
Dec 01 HTML / CSS
html5文本内容_动力节点Java学院整理
Jul 11 HTML / CSS
html5 利用canvas实现超级玛丽简单动画
Sep 06 HTML / CSS
详解android与HTML混合开发总结
Jun 06 HTML / CSS
详解WebSocket跨域问题解决
Aug 06 HTML / CSS
html2 canvas生成清晰的图片实现打印功能
Sep 23 HTML / CSS
基于 HTML5 WebGL 实现的医疗物流系统
Oct 08 HTML / CSS
HTML5超文本标记语言的实现方法
Sep 24 HTML / CSS
HTML5逐步分析实现拖放功能的方法
Sep 30 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
慎用preg_replace危险的/e修饰符(一句话后门常用)
2013/06/19 PHP
destoon常用的安全设置概述
2014/06/21 PHP
PHP生成随机码的思路与方法实例探索
2019/04/11 PHP
更优雅的事件触发兼容
2011/10/24 Javascript
jQuery load方法用法集锦
2011/12/06 Javascript
获取3个数组不重复的值的具体实现
2013/12/30 Javascript
什么是MEAN?JavaScript编程中的MEAN是什么意思?
2014/12/18 Javascript
jQuery插件expander实现图片翻转特效
2015/05/21 Javascript
jQuery+HTML5实现手机摇一摇换衣特效
2015/06/05 Javascript
JS实现自动变换的菜单效果代码
2015/09/09 Javascript
JavaScript Date对象详解
2016/03/01 Javascript
对js中回调函数的一些看法
2016/08/29 Javascript
关于javascript事件响应的基础语法总结(必看篇)
2016/12/26 Javascript
angularjs 缓存的使用详解
2018/03/19 Javascript
vue-cli 目录结构详细讲解总结
2019/01/15 Javascript
Vue+Element UI+Lumen实现通用表格分页功能
2019/02/02 Javascript
nodejs实现百度舆情接口应用示例
2020/02/07 NodeJs
详谈python http长连接客户端
2017/06/12 Python
Python操作mysql数据库实现增删查改功能的方法
2018/01/15 Python
Python实现购物车程序
2018/04/16 Python
使用Python+wxpy 找出微信里把你删除的好友实例
2019/02/21 Python
Pythony运维入门之Socket网络编程详解
2019/04/15 Python
python多进程下实现日志记录按时间分割
2019/07/22 Python
python pygame实现滚动横版射击游戏城市之战
2019/11/25 Python
Selenium环境变量配置(火狐浏览器)及验证实现
2020/12/07 Python
python中把元组转换为namedtuple方法
2020/12/09 Python
使用CSS3实现多列布局与多背景的技巧
2016/02/29 HTML / CSS
国际领先的学术出版商:Springer
2017/01/11 全球购物
巴西箱包、背包、钱包和旅行配件购物网站:Inovathi
2019/12/14 全球购物
2014年元旦联欢会活动策划方案
2014/02/16 职场文书
单位活动策划方案
2014/08/17 职场文书
2014教育局对照检查材料思想汇报
2014/09/23 职场文书
2015年学习部工作总结范文
2015/03/31 职场文书
青年干部培训班学习心得体会
2016/01/06 职场文书
创业计划书之服装
2019/10/07 职场文书
20180830晚上第一届KSL半决赛 雨神vs解冻(二龙 三炮解说)
2022/04/01 星际争霸