代码=图片

图片=代码

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&copy;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代码的另一种压缩与加密方法——代码图片转换的更多相关文章

  1. iOS里常见的几种信息编码、加密方法简单总结

    一.MD5 MD5编码是最常用的编码方法之一,是从一段字符串中通过相应特征生成一段32位的数字字母混合码. MD5主要特点是 不可逆,相同数据的MD5值肯定一样,不同数据的MD5值不一样(也不是绝对的 ...

  2. javascript四种类型识别的方法

    × 目录 [1]typeof [2]instanceof [3]constructor[4]toString 前面的话 javascript有复杂的类型系统,类型识别则是基本的功能.javascrip ...

  3. [转]Javascript removeChild()删除节点及删除子节点的方法(同样适用于jq)

    Javascript removeChild()删除节点及删除子节点的方法 这篇文章主要介绍了Javascript removeChild()删除节点及删除子节点的方法的相关资料,需要的朋友可以参考下 ...

  4. Python解压ZIP、RAR等常用压缩格式的方法

    解压大杀器 首先祭出可以应对多种压缩包格式的python库:patool.如果平时只用基本的解压.打包等操作,也不想详细了解各种压缩格式对应的python库,patool应该是个不错的选择. pato ...

  5. 最新的JavaScript核心语言标准——ES6,彻底改变你编写JS代码的方式!【转载+整理】

    原文地址 本文内容 ECMAScript 发生了什么变化? 新标准 版本号6 兑现承诺 迭代器和for-of循环 生成器 Generators 模板字符串 不定参数和默认参数 解构 Destructu ...

  6. CSS, JavaScript 压缩, 美化, 加密, 解密

    CSS, JavaScript 压缩, 美化, 加密, 解密 JS压缩, CSS压缩, javascript compress, js在线压缩,javascript在线压缩,css在线压缩,YUI C ...

  7. 2016年学习JavaScript是怎样的一种体验(转)

    转自:http://www.zcfy.cc/article/how-it-feels-to-learn-javascript-in-2016-hacker-noon-1871.html 在这篇文章的写 ...

  8. javascript中数组的22种方法 (转载)

    前面的话 数组总共有22种方法,本文将其分为对象继承方法.数组转换方法.栈和队列方法.数组排序方法.数组拼接方法.创建子数组方法.数组删改方法.数组位置方法.数组归并方法和数组迭代方法共10类来进行详 ...

  9. 最新的JavaScript核心语言标准——ES6,彻底改变你编写JS代码的方式!

    原文地址 迁移到:http://www.bdata-cap.com/newsinfo/1741515.html 本文内容 ECMAScript 发生了什么变化? 新标准 版本号6 兑现承诺 迭代器和f ...

随机推荐

  1. SQLExecption:Operation not allowed after ResultSet closed解决办法

    原网址:http://blog.csdn.net/sku0923/article/details/1722370 一个stmt多个rs进行操作引起的ResultSet已经关闭错误 一个stmt多个rs ...

  2. 《Administrator's Guide》之Managing Memory

    Automatic Memory Management 1. 如果要启动Automatic Memory Management,如何确定MEMORY_TARGET的值呢? 1> 在SQL*Plu ...

  3. bootstrap插件思路整理

    知识有时也需温故知新嘛,本次做一次bs插件梳理. $.support.transition 通过判断自定义元素是否支持WebkitTransition.MozTransition.OTransitio ...

  4. Asp.Net回车键触发Button的OnClick事件解决方案

    在aspx页面有textbox文本框,还有三个button按钮.启用textbox的TextChanged事件和button的click事件. 问题: 现在在textbox文本框输入完数据按“回车”后 ...

  5. prototype.js源码

    prototype 1.3.1 版本和之前的 1.2.0 版本有了不少改进,并增加了新的功能: 1. 增加了事件注册管理2. 增加了空间定位的常用函数3. 改善了 xmlhttp 的封装4. 移除了 ...

  6. 增强学习(五)----- 时间差分学习(Q learning, Sarsa learning)

    接下来我们回顾一下动态规划算法(DP)和蒙特卡罗方法(MC)的特点,对于动态规划算法有如下特性: 需要环境模型,即状态转移概率\(P_{sa}\) 状态值函数的估计是自举的(bootstrapping ...

  7. SQLServer学习笔记系列2

    一.写在前面的话 继上一次SQLServer学习笔记系列1http://www.cnblogs.com/liupeng61624/p/4354983.html以后,继续学习Sqlserver,一步一步 ...

  8. sqlserver 存储过程中使用临时表到底会不会导致重编译

    曾经在网络上看到过一种说法,SqlServer的存储过程中使用临时表,会导致重编译,以至于执行计划无法重用, 运行时候会导致重编译的这么一个说法,自己私底下去做测试的时候,根据profile的跟踪结果 ...

  9. SQL Server安全(6/11):执行上下文与代码签名(Execution Context and Code Signing)

    在保密你的服务器和数据,防备当前复杂的攻击,SQL Server有你需要的一切.但在你能有效使用这些安全功能前,你需要理解你面对的威胁和一些基本的安全概念.这篇文章提供了基础,因此你可以对SQL Se ...

  10. JavaScript之旅(DOM)

    JavaScript之旅(DOM) [TOC] 一.认识DOM 什么是 DOM? DOM 是 Document Object Model(文档对象模型)的缩写. DOM 是 W3C(万维网联盟)的标准 ...