[实现]Javascript代码的另一种压缩与加密方法——代码图片转换
代码=图片
图片=代码
JS代码对于喜欢F12的同志来说,连个遮羞布都没有。。。
虽然把代码变成图片也仅仅只是增加一层纱布而已。。。但这方法还是挺好玩的,而且代码也被压缩了一点。
第一次看到[图片=代码]的想法,是在一个演示视屏拼图的博客里看到的。
最近有点闲,想起了这个,就试了试。
对于中文等字符,需要先转为十六禁止后,再转为图片的RGB像素
document.write(escape("字") ); //%u5B57
document.write(unescape("%u5B57"));
---
在线地址:
http://wangxinsheng.herokuapp.com/imageData
完整未压缩,未混淆免费代码:
http://download.csdn.net/detail/wangxsh42/8551511
下面的是jquery 1.9.1的代码图片:

---
代码段:
HTML:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta name="description" content="html5 js2png">
<meta name="keywords" content="html5,canvas,png,js">
<meta name="author" content="WangXinsheng">
<title>CopyRight©WangXinsheng</title>
<script src="jquery-1.9.1.min.js"></script>
<style type="text/css">
</style>
</head>
<body>
<p>
javascript:<br />
<textarea id='js' rows="5" cols="50">
function a(arg){alert(arg)};
a("hello world!");</textarea>
<br />
<button id='topng' type="button">2png</button>
<button id='tojs' type="button">2js</button>
<button id='canvastoimg' type="button">c2img</button>
<button id='runjs' type="button">run Js</button>
<button id='clear' type="button">clear</button>
</p>
<p>
picture:<br />
<input id='pngFile' type="file" onchange="onPngFileChange(this)" /><br />
<canvas id="png" width='10' height='10'></canvas>
<img id="pngImg" />
</p>
</body>
<script src="data:imageData.js"></script>
</html>
JS:
//将js代码编码为图片
function toPng(jsorg){
var canvas = document.getElementById("png");
var context = canvas.getContext("2d");
var width = Math.ceil(Math.sqrt(jsorg.length / 3));
var height = width;
$("#png").attr("width",width).attr("height",height);
$("#png").width(width).height(height);
var imageData = context.createImageData(width, height); var a = stringToHex(jsorg);
var arr = a.split(",");
for(var i = 0,j=0;j<width*height*4;i++,j++){
if((j+1)%4==0){
imageData.data[j]=255;
j++;
}
if(i<arr.length)
imageData.data[j] = arr[i];
}
//console.log(imageData.data);
context.putImageData(imageData, 0, 0);
}
//解析图片为js代码
function tojs(canvasId){
var canvas = document.getElementById(canvasId);
var context = canvas.getContext("2d");
var width = $("#"+canvasId).width();
var height = $("#"+canvasId).height();
var imageData = context.getImageData(0, 0, width, height);
//console.log(imageData.data);
var str = "";
for(var i = 0;i<imageData.data.length;i++){
if((i+1)%4==0)
continue;
str += imageData.data[i]!=0?hexToString(imageData.data[i]):'';
}
$("#js").val(str);
}
也可以添加私钥加密功能[添偏移量即可]
---
原理:
字符可以转为16进制,与图片RGB的一个R/G/B相对应,即一个像素点可容纳3个字符
注:Canvas的RGBA,透明度A似乎不能使用,使用后,RGB会有所变化,造成无法正确解码。
具体原理可参考:http://www.qingdou.me/2170.html
[实现]Javascript代码的另一种压缩与加密方法——代码图片转换的更多相关文章
- iOS里常见的几种信息编码、加密方法简单总结
一.MD5 MD5编码是最常用的编码方法之一,是从一段字符串中通过相应特征生成一段32位的数字字母混合码. MD5主要特点是 不可逆,相同数据的MD5值肯定一样,不同数据的MD5值不一样(也不是绝对的 ...
- javascript四种类型识别的方法
× 目录 [1]typeof [2]instanceof [3]constructor[4]toString 前面的话 javascript有复杂的类型系统,类型识别则是基本的功能.javascrip ...
- [转]Javascript removeChild()删除节点及删除子节点的方法(同样适用于jq)
Javascript removeChild()删除节点及删除子节点的方法 这篇文章主要介绍了Javascript removeChild()删除节点及删除子节点的方法的相关资料,需要的朋友可以参考下 ...
- Python解压ZIP、RAR等常用压缩格式的方法
解压大杀器 首先祭出可以应对多种压缩包格式的python库:patool.如果平时只用基本的解压.打包等操作,也不想详细了解各种压缩格式对应的python库,patool应该是个不错的选择. pato ...
- 最新的JavaScript核心语言标准——ES6,彻底改变你编写JS代码的方式!【转载+整理】
原文地址 本文内容 ECMAScript 发生了什么变化? 新标准 版本号6 兑现承诺 迭代器和for-of循环 生成器 Generators 模板字符串 不定参数和默认参数 解构 Destructu ...
- CSS, JavaScript 压缩, 美化, 加密, 解密
CSS, JavaScript 压缩, 美化, 加密, 解密 JS压缩, CSS压缩, javascript compress, js在线压缩,javascript在线压缩,css在线压缩,YUI C ...
- 2016年学习JavaScript是怎样的一种体验(转)
转自:http://www.zcfy.cc/article/how-it-feels-to-learn-javascript-in-2016-hacker-noon-1871.html 在这篇文章的写 ...
- javascript中数组的22种方法 (转载)
前面的话 数组总共有22种方法,本文将其分为对象继承方法.数组转换方法.栈和队列方法.数组排序方法.数组拼接方法.创建子数组方法.数组删改方法.数组位置方法.数组归并方法和数组迭代方法共10类来进行详 ...
- 最新的JavaScript核心语言标准——ES6,彻底改变你编写JS代码的方式!
原文地址 迁移到:http://www.bdata-cap.com/newsinfo/1741515.html 本文内容 ECMAScript 发生了什么变化? 新标准 版本号6 兑现承诺 迭代器和f ...
随机推荐
- ASP.NET MVC路由解析
继续往下看<ASP.NET MVC5框架揭秘>. ASP.NET系统通过注册路由和现有的物理文件路径发生映射.而对于ASP.NET MVC来说,请求的是某个Controller中的具体的A ...
- 原创:新手布局福音!微信小程序使用flex的一些基础样式属性
来源:新手布局福音!微信小程序使用flex的一些基础样式属性 作者:Nazi Flex布局相对于以前我们经常所用到的布局方式要好的很多,在做微信小程序的时候要既能符合微信小程序的文档开发要求,又能 ...
- 年度榜单:2013年最佳免费 PSD 设计素材揭晓
<年度榜单>系列继续给大家带来2013年度发布的好东西,这篇文章要给大家分享的是本年度最佳的12套精美的 PSD 设计素材,你可以免费下载使用.这些免费素材不仅能帮助他们节省大量的时间,而 ...
- 【Android】做一款类似我要当学霸里的学习监督的APP
我要当学霸这款App有个学习监督的功能,当你启动它的时候,你将无法使用其他App,以此达到帮助人提高自觉性,起到监督学习的效果.最近和同学做了个小App,正好有这个功能,所以就来说说它是怎么实现的. ...
- c#中如何执行存储过程
using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; usin ...
- Web API应用架构设计分析(1)
Web API 是一种应用接口框架,它能够构建HTTP服务以支撑更广泛的客户端(包括浏览器,手机和平板电脑等移动设备)的框架, ASP.NET Web API 是一种用于在 .NET Framewor ...
- 基于吉日嘎拉的OA协同办公模块重写
这一个月的业余时间主要是在忙这个重构的事情,将吉日嘎拉自带的文档管理.公司公告.留言板.通讯录.周任务.考勤,全部重新建表,重构代码和UI. 目前根据中小企业常用的日常办公需要,搞定了公告栏.任务中心 ...
- mysql之TIMESTAMP(时间戳)用法详解
一.TIMESTAMP的变体 TIMESTAMP时间戳在创建的时候可以有多重不同的特性,如: 1.在创建新记录和修改现有记录的时候都对这个数据列刷新: ? 1 TIMESTAMP DEFAULT CU ...
- Note: This element neither has attached source nor attached Javadoc and hence no Javadoc could be found.
在Eclipse中开发Android项目时,鼠标停放在想要查看帮助文档的类上面,发现没有显示帮助文档,显示了下面一句话: Note: This element neither has attached ...
- Using Recursive Common table expressions to represent Tree structures
http://www.postgresonline.com/journal/archives/131-Using-Recursive-Common-table-expressions-to-repre ...