HTML5实现代码的隐藏(一种在图片里隐藏你的程序代码的技术)
2013-03-30 09:12
543 查看
最近开发了我的第一个网页游戏:一个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万个文本字符。
你还有其它简单的能防止别人拷贝你的代码的方法吗?我们当然可以把字符进行加密,但如何保证你的解密步骤能不被人轻易的破解呢?告诉我你的想法吧!
转载地址:http://www.hackbase.com/tech/2013-03-06/67239.html
一张图片能隐含千言万语。
这依赖于图片的体积。但我决定要把源代码加密存放到一张图片里。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万个文本字符。
你还有其它简单的能防止别人拷贝你的代码的方法吗?我们当然可以把字符进行加密,但如何保证你的解密步骤能不被人轻易的破解呢?告诉我你的想法吧!
转载地址:http://www.hackbase.com/tech/2013-03-06/67239.html
相关文章推荐
- 一种在图片里隐藏你的程序代码的技术
- asp.net多图片上传实现程序代码
- 网页图片显示一段时间后自动隐藏 怎样实现 实现代码
- android程序代码实现改变字体颜色和输入密码的显示隐藏
- 微信小程序多张图片和表单一起上传,验证表单及进度条的实现完整代码
- asp.net多图片上传实现程序代码
- 自己实现图片压缩技术,直接上代码,绝对好用(优化效果不错)
- 架构,改善程序复用性的设计~第三讲 实现一种功能的代码只能出现在一处
- 一张图片能隐含千言万语之隐藏你的程序代码
- JAVA技术:代码实现验证码图片的生成
- JavaScript图片放大技术(放大镜)实现代码分享
- Html5 FileReader实现即时上传图片功能实例代码
- 一种多尺度的KCF跟踪程序代码分析(二)——图片视频转换和初始框输入
- 在VC中隐藏控制台程序窗口的实现代码
- 架构,改善程序复用性的设计~第三讲 实现一种功能的代码只能出现在一处(续)
- [微信小程序]实现列表点赞并让当前节点的图片改变,值加1完整实例代码加GIF图
- 两行 CSS 代码实现图片任意颜色赋色技术
- 微信小程序实现图片上传放大预览删除代码
- JavaScript图片放大技术(放大镜)实现代码分享
- asp.net多图片上传实现程序代码