JavaScript 之 解码类似eval(function(p,a,c,k,e,d){}))的JavaScript代码

  这里以解码百度访问统计代码构造函数为示例:

  以下为要统计JavaScript源码:红色加粗部分将是要修改的地方。

eval(function(p,a,c,k,e,d){e=function(c){return(c<a?"":e(parseInt(c/a)))+((c=c%a)>35?String.fromCharCode(c+29):c.toString(36))};if(!‘‘.replace(/^/,String)){while(c--){d[e(c)]=k[c]||e(c)}k=[function(e){return d[e]}];e=function(){return‘\\w+‘};c=1};while(c--){if(k[c]){p=p.replace(new RegExp(‘\\b‘+e(c)+‘\\b‘,‘g‘),k[c])}}return p}(‘p w(E,D,A,C,B){5.R=8.14(E);5.o=D;5.d=A;5.r=(8.e)?C:(C-2);5.q=0;5.b=B+((8.e)?0:-2);5.x=5.d[0];5.O=5.d[5.d.c-1]}w.P.y=p(B){9 A=15.16(((B-5.x)*5.b/(5.O-5.x)))+((8.e)?2:0);s(A>5.b){A=5.b}17 A};w.P.18=p(){9 A=8.i("k");A.a="1a";A.6.z=5.b+"7";5.R.j(A);9 K=8.i("k");A.j(K);K.a="1b";9 J=0;Q(9 G=0;G<5.o.c;G+=2){9 B=5.y(5.o[G]);9 I=5.o[G+1];9 F=8.i("k");A.j(F);F.a="u";F.6.n=5.r+"7";F.6.z=B+"7";F.6.m=5.b-B-1+"7";F.6.g=(J-1)+"7";F.h="&v;";F.f=K;F.T=p(){5.a="V";5.f.6.L="";5.f.h=5.t.l(3,5.t.c);5.f.6.g=5.6.g;5.f.6.m=S(5.6.m)-S(5.f.19)+"7"};F.W=p(){5.a="u";5.f.6.L="Z"};9 E=8.i("k");A.j(E);E.6.n=5.r+"7";E.6.m=(8.e)?5.b:5.b+3+"7";9 C=I.10(".");F.t="u"+I.l(0,C)+"\\11"+I.l(C+1,I.c)+"\\12&v;&v;"+5.o[G];s(G%4==0){s((I.l(C+1,I.c)=="1"||I.l(C+1,I.c)=="2")){E.a="13";E.6.g=(J-4)+"7";E.h=I}N{E.a="M";E.6.g=(J-1)+"7";E.h=I.l(C+1,I.c)}}N{E.a="M";E.6.g=(J-1)+"7";E.h=""}J+=5.r+((8.e)?-1:1)}5.q=J+((8.e)?1:-1);A.6.n=5.q+"7";Q(9 G=0;G<5.d.c;G++){9 D=5.y(5.d[G]);s(G!=0&&G!=5.d.c-1){9 H=8.i("k");A.j(H);H.a="X";H.6.n=(5.q-((8.e)?1:-1))+"7";H.6.m=(5.b-D-1)+"7"}9 E=8.i("k");A.j(E);E.a="1c";E.6.n="Y";E.6.m=(5.b-D-2)+"7";E.6.g=-U+"7";E.h=5.d[G]}};‘,62,75,‘|||||this|style|px|document|var|className|charth|length|yl|all|ohit|left|innerHTML|createElement|appendChild|div|substring|top|width|xl|function|chartw|barw|if|id|bar|nbsp|Chart|minpv|GetPVHeight|height||||||||||||display|titx|else|maxpv|prototype|for|parent|parseInt|onmouseover|42|barhl|onmouseout|liney|35px|none|indexOf|u6708|u65e5|titxhl|getElementById|Math|round|return|Create|offsetHeight|chart|hit|tity‘.split(‘|‘),0,{}));

  其实这个eval(function(p,a,c,k,e,d){}))中自带解码函数e()。
  while(c--){if(k[c]){p=p.replace(new RegExp(‘\\b‘+e(c)+‘\\b‘,‘g‘),k[c])}}return p
  while循环产生的每个p就是解码后的函数代码,我们删掉源码中的return p,不用将结果返回,而是直接输出在一个文本区域中,如document.getElementById(”textareaID”).innerText=p。

  最终代码:
< !DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
< html xmlns="http://www.w3.org/1999/xhtml">
< head>
< title> Crack Baidu统计构造函数</title>
< meta http-equiv="content-type" content="text/html; charset=UTF-8" />
< meta http-equiv="X-UA-Compatible" content="IE=EmulateIE7" />
< meta name="Author" content=www.gemingcao.com />
< meta name="Keywords" content="" />
< meta name="Description" content="" />  
< /head>
< body>
<textarea id="textareaID" rows="25" cols="50"></textarea>
< script type="text/javascript">
eval(function(p,a,c,k,e,d){e=function(c){return(c<a?"":e(parseInt(c/a)))+((c=c%a)>35?String.fromCharCode(c+29):c.toString(36))};if(!‘‘.replace(/^/,String)){while(c--){d[e(c)]=k[c]||e(c)}k=[function(e){return d[e]}];e=function(){return‘\\w+‘};c=1};while(c--){if(k[c]){p=p.replace(new RegExp(‘\\b‘+e(c)+‘\\b‘,‘g‘),k[c]);document.getElementById(‘textareaID‘).innerText=p;}}}(‘p w(E,D,A,C,B){5.R=8.14(E);5.o=D;5.d=A;5.r=(8.e)?C:(C-2);5.q=0;5.b=B+((8.e)?0:-2);5.x=5.d[0];5.O=5.d[5.d.c-1]}w.P.y=p(B){9 A=15.16(((B-5.x)*5.b/(5.O-5.x)))+((8.e)?2:0);s(A>5.b){A=5.b}17 A};w.P.18=p(){9 A=8.i("k");A.a="1a";A.6.z=5.b+"7";5.R.j(A);9 K=8.i("k");A.j(K);K.a="1b";9 J=0;Q(9 G=0;G<5.o.c;G+=2){9 B=5.y(5.o[G]);9 I=5.o[G+1];9 F=8.i("k");A.j(F);F.a="u";F.6.n=5.r+"7";F.6.z=B+"7";F.6.m=5.b-B-1+"7";F.6.g=(J-1)+"7";F.h="&v;";F.f=K;F.T=p(){5.a="V";5.f.6.L="";5.f.h=5.t.l(3,5.t.c);5.f.6.g=5.6.g;5.f.6.m=S(5.6.m)-S(5.f.19)+"7"};F.W=p(){5.a="u";5.f.6.L="Z"};9 E=8.i("k");A.j(E);E.6.n=5.r+"7";E.6.m=(8.e)?5.b:5.b+3+"7";9 C=I.10(".");F.t="u"+I.l(0,C)+"\\11"+I.l(C+1,I.c)+"\\12&v;&v;"+5.o[G];s(G%4==0){s((I.l(C+1,I.c)=="1"||I.l(C+1,I.c)=="2")){E.a="13";E.6.g=(J-4)+"7";E.h=I}N{E.a="M";E.6.g=(J-1)+"7";E.h=I.l(C+1,I.c)}}N{E.a="M";E.6.g=(J-1)+"7";E.h=""}J+=5.r+((8.e)?-1:1)}5.q=J+((8.e)?1:-1);A.6.n=5.q+"7";Q(9 G=0;G<5.d.c;G++){9 D=5.y(5.d[G]);s(G!=0&&G!=5.d.c-1){9 H=8.i("k");A.j(H);H.a="X";H.6.n=(5.q-((8.e)?1:-1))+"7";H.6.m=(5.b-D-1)+"7"}9 E=8.i("k");A.j(E);E.a="1c";E.6.n="Y";E.6.m=(5.b-D-2)+"7";E.6.g=-U+"7";E.h=5.d[G]}};‘,62,75,‘|||||this|style|px|document|var|className|charth|length|yl|all|ohit|left|innerHTML|createElement|appendChild|div|substring|top|width|xl|function|chartw|barw|if|id|bar|nbsp|Chart|minpv|GetPVHeight|height||||||||||||display|titx|else|maxpv|prototype|for|parent|parseInt|onmouseover|42|barhl|onmouseout|liney|35px|none|indexOf|u6708|u65e5|titxhl|getElementById|Math|round|return|Create|offsetHeight|chart|hit|tity‘.split(‘|‘),0,{}));
</script>
</body>
< /html>

  保存为html文件,运行。
  格式化文本区域中的JavaScript代码,代码如下:

function Chart(E, D, A, C, B) {
    this.parent = document.getElementById(E);
    this.xl = D;
    this.yl = A;
    this.barw = (document.all) ? C: (C - 2);
    this.chartw = 0;
    this.charth = B + ((document.all) ? 0 : -2);
    this.minpv = this.yl[0];
    this.maxpv = this.yl[this.yl.length - 1]
}
Chart.prototype.GetPVHeight = function(B) {
    var A = Math.round(((B - this.minpv) * this.charth / (this.maxpv - this.minpv))) + ((document.all) ? 2 : 0);
    if (A > this.charth) {
        A = this.charth
    }
    return A
};
Chart.prototype.Create = function() {
    var A = document.createElement("div");
    A.className = "chart";
    A.style.height = this.charth + "px";
    this.parent.appendChild(A);
    var K = document.createElement("div");
    A.appendChild(K);
    K.className = "hit";
    var J = 0;
    for (var G = 0; G < this.xl.length; G += 2) {
        var B = this.GetPVHeight(this.xl[G]);
        var I = this.xl[G + 1];
        var F = document.createElement("div");
        A.appendChild(F);
        F.className = "bar";
        F.style.width = this.barw + "px";
        F.style.height = B + "px";
        F.style.top = this.charth - B - 1 + "px";
        F.style.left = (J - 1) + "px";
        F.innerHTML = "&nbsp;";
        F.ohit = K;
        F.onmouseover = function() {
            this.className = "barhl";
            this.ohit.style.display = "";
            this.ohit.innerHTML = this.id.substring(3, this.id.length);
            this.ohit.style.left = this.style.left;
            this.ohit.style.top = parseInt(this.style.top) - parseInt(this.ohit.offsetHeight) + "px"
        };
        F.onmouseout = function() {
            this.className = "bar";
            this.ohit.style.display = "none"
        };
        var E = document.createElement("div");
        A.appendChild(E);
        E.style.width = this.barw + "px";
        E.style.top = (document.all) ? this.charth: this.charth + 3 + "px";
        var C = I.indexOf(".");
        F.id = "bar" + I.substring(0, C) + "\u6708" + I.substring(C + 1, I.length) + "\u65e5&nbsp;&nbsp;" + this.xl[G];
        if (G % 4 == 0) {
            if ((I.substring(C + 1, I.length) == "1" || I.substring(C + 1, I.length) == "2")) {
                E.className = "titxhl";
                E.style.left = (J - 4) + "px";
                E.innerHTML = I
            } else {
                E.className = "titx";
                E.style.left = (J - 1) + "px";
                E.innerHTML = I.substring(C + 1, I.length)
            }
        } else {
            E.className = "titx";
            E.style.left = (J - 1) + "px";
            E.innerHTML = ""
        }
        J += this.barw + ((document.all) ? -1 : 1)
    }
    this.chartw = J + ((document.all) ? 1 : -1);
    A.style.width = this.chartw + "px";
    for (var G = 0; G < this.yl.length; G++) {
        var D = this.GetPVHeight(this.yl[G]);
        if (G != 0 && G != this.yl.length - 1) {
            var H = document.createElement("div");
            A.appendChild(H);
            H.className = "liney";
            H.style.width = (this.chartw - ((document.all) ? 1 : -1)) + "px";
            H.style.top = (this.charth - D - 1) + "px"
        }
        var E = document.createElement("div");
        A.appendChild(E);
        E.className = "tity";
        E.style.width = "35px";
        E.style.top = (this.charth - D - 2) + "px";
        E.style.left = -42 + "px";
        E.innerHTML = this.yl[G]
    }
};

  修正后发现一个更简单的方法。将eval直接替换成document.write,将代码输出,但是要注意一点.在输出前,先输出一个<xmp>标记,如:
  document.write("<xmp>");
  /*eval*/document.write("function(){.....代码}");
  document.write("</xmp>");

  输出解码后的JavaScript代码,把输出的代码格式化后可以查看参考修改。
  格式化的网页工具:http://tool.chinaz.com/Tools/JsFormat.aspx

时间: 2024-10-24 15:06:26

JavaScript 之 解码类似eval(function(p,a,c,k,e,d){}))的JavaScript代码的相关文章

密码学笔记——eval(function(p,a,c,k,e,d) 加密破解

密码学笔记--eval(function(p,a,c,k,e,d) 的加密破解 例题: 小明某天在看js的时候,突然看到了这么一段代码,发现怎么也理不出代码逻辑,你能帮帮他吗? 格式:SimCTF{} eval(function(p,a,c,k,e,d){e=function(c){return(c<a?"":e(parseInt(c/a)))+((c=c%a)>35?String.fromCharCode(c+29):c.toString(36))};if(!''.rep

eval(function(p,a,c,k,e,r)解密程序

以eval(function(p,a,c,k,e,r){e=function(c)开头的js文件是经过加密的 使用下面方法可以对js文件进行加密.解密 步骤:1.新建html页面,内容如下列代码 2.把加密的代码粘进[原脚本]文本域,点击[解密]按钮: 3.把需要加密的原代码粘进[原脚本]文本域,点击[加密]按钮: HTML代码如下: <script> a=62; function encode() { var code = document.getElementById('code').va

JavaScript语言实现类似这样的效果: 3.grams.flour

JavaScript语言实现类似这样的效果: 3.grams.flour 参考 Javascript: The Good Parts,第33页 代码如下: <html> <body> <script type="text/javascript"> // copied from page 33 of Javascript: The Good Parts Function.prototype.method = function (name, func)

js javascript加载类似星座、血型的函数

 javascript加载类似星座.血型的函数 //加载血型 function bloodtypelaod(constellation) { var obj = document.getElementById('bloodtype'); obj.options.length = 0; var option = document.createElement("option"); option.value = "0"; option.text = "请选择&q

Javascript自执行匿名函数(function() { })()的原理分析

匿名函数指没有指定函数名或指针的函数,自执行匿名函数只是其中一种,下文中称这种函数为:自执行函数 下面是一个最常见的自执行函数: 1 // 传统匿名函数 2 (function() { 3 alert('hello'); 4 })(); 这段代码的执行效果就是在页面再载入时弹出:"hello" 是什么促使它自动执行的?,来看下面的代码 // 在传统写法上去掉小括号,并在前面加上运算符 ~,!,+,- ~function(){ alert('hello'); }(); !function

JavaScript学习总结(十五)——Function类

在JavaScript中,函数其实是对象,每个函数都是Function类的实例,既然函数对象,那么就具有自己的属性和方法,因此,函数名实际上也是一个指向函数对象的指针,不会与某个函数绑定. 一.函数的声明 方式一:常规方式 1 function sum1(num1,num2){ 2 return num1+num2 3 } 方式二:函数表达式 1 var sum2=function(num1,num2){ 2 return num1+num2; 3 }; 方式三:动态创建函数(这种方式用得不多)

Javascript自执行匿名函数(function() { })()的原理浅析

匿名函数就是没有函数名的函数.这篇文章主要介绍了Javascript自执行匿名函数(function() { })()的原理浅析的相关资料,需要的朋友可以参考下 函数是JavaScript中最灵活的一种对象,这里只是讲解其匿名函数的用途.匿名函数指没有指定函数名或指针的函数,自执行匿名函数只是其中一种,下文中称这种函数为:自执行函数 下面是一个最常见的自执行函数: // 传统匿名函数 (function() { alert('hello'); })(); 这段代码的执行效果就是在页面再载入时弹出

如何在程序开发项目中选择合适的 JavaScript 框架,节省时间和成本的9款极佳的JavaScript框架介绍

从技术上来看,iOS,Android 和 Windows Phone 上的移动应用是使用不同的程序语言开发的,iOS 应用使用 Objective-C,Android 应用使用 Java,而 Windows Phone 应用使用 .NET. .随着 JavaScript,CSS 和 HTML 知识技能的提升,相信你也可以构建一个超赞的移动应用.在这篇博客里,我们将会介绍一些极好的 JavaScript 移动应用程序开发框架. 说到网络开发,就不得不说 JavaScript,这是一款很有前途的程序

JavaScript网站设计实践(四)编写about.html页面,利用JavaScript和DOM,选择性的显示和隐藏DIV元素

一.现在我们在网站设计(三)的基础上,来编写about.html页面. 这个页面要用到的知识点是利用JavaScript和DOM实现选择性地显示和隐藏某些DIV about.html页面在前面我们为了看导航栏菜单项高亮显示时,已经写了部分内容,只是那时写的代码没有实现div显示和隐藏,现在就在之前编写的基础上,为页面添加显示和隐藏div的效果. 没有写JavaScript之前看到的效果: 实现后的效果图: 这个就是我们现在要做的效果. 1.背景: 我们在about.html页面中写了一个ul列表