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

2016-02-19 12:34 6 1 收藏

今天图老师小编要向大家分享个一张图片能隐含千言万语之隐藏你的程序代码教程,过程简单易学,相信聪明的你一定能轻松get!

【 tulaoshi.com - Web开发 】

我最近开发了我的第一个网页游戏:一个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万个文本字符。

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

来源:https://www.tulaoshi.com/n/20160219/1601228.html

延伸阅读
标签: Web开发
'把pattern 又修改了下 'code要检测的代码 'http://school.cnd8.com/asp.asp 'leixing html 或者ubb 'nopic 代码没有图片时默认值 function toppic(code,leixing,nopic)         set regex = new regexp         ...
  一直以来我们都希望我们的代码在不影响可读、可维护、可移植等条件下尽可能的短小精悍。       对于编程发烧友来说将代码的精简做极致,往往会比较变态,今天我也变了一把,时刻准备着各位拍砖。       事情是这样的,有个朋友说他写了个彩票机先程序,然后群里开始...
标签: ASP
  随手写个注册域名程序,你自己可以扩展,这只是三位字母的。 <% '制作:默飞 'asp程序制作:http://mofei.xinxiu.com b1="a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s,t,u,v,w,x,y,z" b2=split(b1,",") for ii1=0 to ubound(b2) for ii2=0 to ubound(b2)   for ii3=0 to ubound(b2)         res...
标签: PhotoShop PS PS教程
PS两张图片合成一张的技巧 PS两张图片合成一张换背景效果 如上图,上面可是两张照片换背景合成的,怎么样,很漂亮吧。那么给图片换背景如何实现呢?目前最常用的就是使用Photoshop简单处理,其实也很简单,相信看完的朋友都可以轻松学会。 一、在电脑上安装好PS软件(没有的朋友请百度搜索一下下载)然后打开PS软件,点文件,...
标签: 电脑入门
      ∧,,,∧            /●   ●\          ╰/] - [\╯       世界那么脏,    何处谈悲伤. 男人男人男人 女人女人女人  &...

经验教程

371

收藏

16
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部