您现在的位置是:网站首页> 编程资料编程资料
一张图片能隐含千言万语之隐藏你的程序代码html5实现点击弹出图片功能html5 录制mp3音频支持采样率和比特率设置html5表单的required属性使用html5调用摄像头实例代码HTML5页面音频自动播放的实现方式Html5大屏数据可视化开发的实现html实现弹窗的实例HTML5来实现本地文件读取和写入的实现方法HTML 罗盘式时钟的实现HTML5简单实现添加背景音乐的几种方法
2023-10-15
444人已围观
简介 一个HTML5的视频智力游戏,开发的过程很有趣,我喜欢编程,但当实现了游戏逻辑后,我有了一个有趣的想法:为什么不想个办法把代码隐藏起来
我最近开发了我的第一个网页游戏:一个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万个文本字符。
你还有其它简单的能防止别人拷贝你的代码的方法吗?我们当然可以把字符进行加密,但如何保证你的解密步骤能不被人轻易的破解呢?告诉我你的想法吧!
一张图片能隐含千言万语
这依赖于图片的体积。但我决定要把源代码加密存放到一张图片里。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万个文本字符。
你还有其它简单的能防止别人拷贝你的代码的方法吗?我们当然可以把字符进行加密,但如何保证你的解密步骤能不被人轻易的破解呢?告诉我你的想法吧!
相关内容
- HTML5 新旧语法标记对我们有什么好处html5标记文字_动力节点Java学院整理 HTML5 b和i标记将被赋予真正的语义自定义html标记替换html5新增元素HTML5超文本标记语言的实现方法
- HTML5自定义data-* data(obj)属性和jquery的data()方法的使用详解HTML5 data-* 自定义属性HTML5自定义属性前缀data-及dataset的使用方法(html5 新特性)全面解析HTML5中的标准属性与自定义属性html5的自定义data-*属性与jquery的data()方法的使用HTML5的自定义属性data-*详细介绍和JS操作实例HTML5自定义属性的问题分析
- HTML5 Web Database 数据库的SQL语句的使用方法我的css框架——base.css(重设浏览器默认样式)HTML5本地存储之Database Storage应用介绍HTML5教程之html 5 本地数据库(Web Sql Database)Web数据存储浅析 Cookie、UserData、SessionStorage、WebSqlDatabase html 基底网址标记 <base>基链接标签base的使用介绍CSS标准:vertical-align属性HTML中的base标签使用详解
- html5 浏览器支持 如何让所有的浏览器都支持HTML5标签样式HTML5之HTML元素扩展(上)—新增加的元素及使用概述让IE6支持HTML5元素的方法检测浏览器是否支持html5视频的代码几个解决兼容IE6\7\8不支持html5标签的几个方法html5 canvas-1.canvas介绍(hello canvas)input file上传文件样式支持html5的浏览器解决方案让IE支持HTML5的方法IE支持HTML5的解决方法如何让IE9以下版本(ie6/7/8)认识html5元素
- html5-websocket基于远程方法调用的数据交互实现HTML5+WebSocket实现多文件同时上传的实例HTML5-WebSocket实现聊天室示例浅析HTML5的WebSocket与服务器推送事件HTML5实现WebSocket协议原理浅析html5的websockets全双工通信详解学习示例利用html5的websocket实现websocket聊天室基于HTML5的WebSocket的实例代码
- html5构建触屏网站之网站尺寸探讨html5实现点击弹出图片功能html5 录制mp3音频支持采样率和比特率设置html5表单的required属性使用html5调用摄像头实例代码HTML5页面音频自动播放的实现方式Html5大屏数据可视化开发的实现html实现弹窗的实例HTML5来实现本地文件读取和写入的实现方法HTML 罗盘式时钟的实现HTML5简单实现添加背景音乐的几种方法
- 使用css创建三角形 使用CSS3创建3d四面体原理及代码(html5实践)纯CSS3+DIV实现小三角形边框效果的示例代码详解css如何利用 :before :after 写小三角形CSS3 画基本图形,圆形、椭圆形、三角形等用CSS3绘制三角形的简单方法布局和排版教程 纯css3实现图片三角形排列CSS3实现三角形不断放大效果
- 天天飞车游戏秘籍 超级奖励模式开启方法和技巧_手机游戏_游戏攻略_
- 天天飞车手动刷分技巧分享 20W高分轻松得_手机游戏_游戏攻略_
- 信长之野望14:创造实用攻略 姬小路开局战法详解_手机游戏_游戏攻略_