澳门新萄京官方网站-www.8455.com-澳门新萄京赌场网址

澳门新萄京官方网站:爬虫实战,JavaScript学习总

2019-06-01 作者:www.8455.com   |   浏览(193)

 

网络中存在大量由VBScript和Jscript或者其他Windows脚本宿主相关的语言编写的代码,其中相当一部分用对应语言实现很简短,而且有部分代码甚至不能转换为PowerShell代码。丢弃所有这些代码并且完全使用PowerShell重写很不明智,因此需要在PowerShell中有一种重用Jscript和VBScript脚本的代码方法。

前言: 在Swift3中, 这些又发生了改变.

原书参考:

1、JS流程控制语句

  (1)、if 判断

  if 语句是基于条件成立时才执行相应的代码。

  if...else  语句是在指定的条件成立时执行if后的代码,在条件不成立时执行else后的代码。

  if...else  嵌套语句是在多种条件下选择相应的代码快之一来执行。

  if 语句适用于任意类型的数据,可处理复杂的逻辑关系。

  (2)、switch语句

  当有很多种选择的时候,switch 比 if...else 使用更方便,结构简洁,专为多重选择设计,但是仅能处理多个枚举型逻辑关系。**该语句使用 if 也可以完成,**这个看个人喜好。

  switch 语句的工作原理:首先创建一个表达式,通常为变量,之后表达式的值与 switch 语句中每个 case 的值做比较,如果**匹配,则执行该 case 后的语句,若与所有 case 值都不匹配,则执行 default 后的语句。在使用 switch 语句时,每个 case 语句后必须使用 break 跳出循环,阻止运行下一个 case。**

 1 var d = new Date().getDay();
 2 //如果今天不是周末,则提示默认消息
 3 switch (d){
 4     case 6:
 5         alert("今天是星期六");
 6         break;
 7     case 0:
 8         alert("今天是星期天");
 9         break;
10     default:
11         alert("同志尚未努力,革命仍需成功。");
12 }

 

  switch 语句在做比较时,使用的是全等,而不是相等,所以在字符串与数字匹配时,需要特别注意。

 1 //使用switch语句将字符串与数字做比较
 2 //返回:不等于,执行default语句
 3 var n = '5';
 4 switch(n){
 5     case 5:
 6         alert('等于,执行case语句');
 7         break;
 8     default:
 9         alert('不等于,执行default语句');
10 }
11 
12 //使用if语句将字符串与数字做比较
13 //返回:等于
14 var n = '2';
15 if(n == 2){
16     alert('等于');
17 }else{
18     alert('不等于');
19 }
20 
21 //将case的值改为字符串再做比较
22 //返回:等于,执行case语句
23 var n = '2';
24 switch(n){
25     case '2':
26         alert('等于,执行case语句');
27         break;
28     default:
29         alert('不等于,执行default语句');
30 }
31 
32 
33 //使用全等再做比较
34 //返回:不等于
35 var n = '2';
36 if(n===2){
37     alert('等于');
38 }else{
39     alert('不等于');
40 }

 

  (3)、for 循环

  很多事情不只是做一次,需要重复做。比如打印 10 份文件,每次打印 1 份,重复这个动作,直到打印完成。这样的事情就用 for 循环来完成,循环就是重复执行一段代码,每次的值不同。

  下面是一个 for 循环的小应用,假设有 1.2.3. ... 10 不同面值的 RMB,计算一共有多少 RMB。

1 var sum = 0;
2 for(var rmb=1; rmb<=10; rmb  ){ 
3     sum  = rmb;
4 }
5 alert('一共有: '   sum   '元');    //返回:一共有:55元

 

  (4)、while 循环

  while 循环和 for 循环具有相同的功能,只要指定条件为 ture,循环就可以一直执行,直到条件不再满足。

1 //使用while循环输出5个数字
2 var i = 0;      //第一部分:初始化,给一个初始的值,让i从0循环
3 while(i < 5){    //第二部分:条件。成立继续循环,不成立退出
4     alert(i);    //第三部分:语句
5     i  ;     //第四部分:自增
6 }
7 //while循环使用比较复杂,使用for循环更简洁。
8 //for(初始化;条件;自增){语句}

 

  (5)、do...while 循环

  do...while 循环与 while 循环的原理结构是基本相同的,但是该循环会在检查条件是否为 ture 之前执行一次代码块,如果条件为 ture,则重复循环。**该循环有一点小问题,因为他是先执行代码,后判断条件,如果条件不当,则进入死循环,导致浏览器崩溃。**

 1 /*
 2 语法:
 3 do{
 4   执行语句
 5 }
 6 while(条件);
 7 */
 8 
 9 //操作有风险,尝试需谨慎
10 //若将循环条件改为:num <= 6 会导致浏览器崩溃  
11 var num = 6;
12 do{
13     document.write("数字:"   num   "<br>");
14     num -= 1;
15 }
16 while(num > 0);

 

  (6)、JS 错误处理语句

  try...catch 语句用于进行异常处理。try 语句用于检测代码块的错误,指明需要处理的代码段,catch 语句用于处理 try 语句中抛出的错误。try 语句首先被执行,如果运行中发生了错误,try 语句中的代码将被跳过执行 catch 中的语句。如果没有发生错误,则不执行 catch 中的语句。一般针对可预见性的错误,可使用 try...catch 语句进行处理。

 1 try{
 2     document.write("开始执行try语句"   '<br>');
 3     document.write("还没抛出错误"   '<br>');
 4     alert(x);        //抛出错误
 5     alert('123');    //没被执行
 6 }
 7 catch(e){
 8     document.write("捕捉到错误,开始执行catch语句"   '<br>');
 9     document.write("错误类型: "   e.name   '<br>');
10     document.write("错误信息: "   e.message);
11     alert('x');
12 }

 

  throw 语句可用于创建自定义错误。官方术语为:创建或抛出异常(exception)。语法:throw '异常对象'。  

  throw 语句可以配合 try...catch 语句一起使用,以达到控制程序流,生成精确的错误消息。

 1 //输入0到10之间的数字,如果输入错误,会抛出一个错误,catch会捕捉到错误,并显示自定义的错误消息。
 2 <body>
 3 <input id="txt" type="text"/>
 4 <br>
 5 <input type="button" value="检测输入" onclick="error()">
 6 <script>
 7 function error(){
 8     try{
 9         var x = document.getElementById("txt").value;
10         var y = document.getElementById("demo");
11         y.style.color = 'red';
12         if(x == '') throw '输入不能为空';
13         if(isNaN(x)) throw '请输入数字';
14         var num = [7,8,9];
15         for(var i=0; i<num.length; i  ){
16             if(x == num[i]){
17                 throw '该数字已经存在';
18             }
19         }
20         if(x == 0){
21             throw '输入不能为0';
22         }
23         else if(x > 10){
24             throw '数字太大了';
25         }
26         else if(x <= 3){
27             throw '数字太小了';
28         }
29         else{
30             y.style.color = 'green';
31             y.innerHTML = 'OK';
32         }
33     }
34     catch(e){
35         y.innerHTML = '错误提示:'   e   '!';
36     }
37 }
38 </script>
39 </body>

 

  (7)、跳出循环

  break 语句用于跳出当前循环,直接退出循环执行后面的代码,即终止整个循环,不再进行判断。continue 语句仅仅是跳出本次循环,继续执行后面的循环,即结束本次循环,接着去判断是否执行下次循环。return 可以终止函数体的运行,并返回一个值。

1 for(var i=0; i<6; i  ){
2     if(i == 3) break;    //当i=3时跳出整个循环,不再执行循环
3     alert(i);    //返回:0,1,2
4 }
5 
6 for(var i=0; i<6; i  ){
7     if(i == 3) continue;    //当i=3时跳出本次循环,继续执行后面循环
8     alert(i);    返回:0,1,2,4,5
9 }

 

 

MSScriptControl这个COM对象可以作为脚本环境的宿主,其ProgID是MSScriptControl.ScriptControl。用户可以用其注册并执行代码,使用这个对象作为从PowerShell中调用现有VBScript和Jscript脚本的方法。一旦导入脚本,即可调用其中的函数,传递参数并返回值。

“Swift 中,许多基本类型,诸如String,Array和Dictionary类型均以结构体的形式实现。这意味着被赋值给新的常量或变量,或者被传入函数或方法中时,它们的值会被拷贝。”

上一篇:翻译《Writing Idiomatic Python》(二):函数、异常

2、JSON

  JSON(JavaScript Object Notation):JS 对象表示法。JSON 主要用于存储和交换数据信息,类似于 XML,**但是相比 XML,JSON 易于阅读和编写,也易于解析。**

   JSON 语法是 JS 对象表示语法的子集:数据在键值对中,并由逗号分隔,花括号保存对象,方括号保存数组。

  JSON 语法的书写格式:"名称" : "值", "名称" : "值"

  名称和值包含在双引号中,并用冒号分隔,每条数据用逗号分隔。这很容易理解,相对于 JS 中 名称 = "值"。

  JSON 的值可以是:数字(包括整数和小数),字符串(包含在双引号中),布尔值(true 或 false),对象(包含在花括号中),数组(包含在方括号中),或者为 null。

  JSON 是纯文本,通常用于服务端向网页传递数据,从服务器上获取 JSON 数据,然后在网页中使用该数据。

  (1)、JSON对象

1 var json = {"a": 12, "b": "abc", "c":[1,2,3]};
2 //返回第一项的值:
3 alert(json.a);
4 
5 //修改第二项的值
6 alert(json.b = "xyz");
7 
8 //返回第三项数组中第一项的值
9 alert(json.c[0]);

 

  (2)、JSON 和数组

  相同点:

  都可以通过下标返回某项的值。都可以使用循环。虽然 JSON 没有 length 属性,不能使用 for 循环,但是可以使用 for...in 循环,完成与 for 循环相同的动作。

  数组也可以使用 for...in 循环,但最好还是使用 for 循环。for...in 循环遍历的是对象的属性,而不是数组元素。

  不同点:

  JSON 的下标是字符串,数组的下标为数字。JSON 没有 length 属性,数组有该属性。

 1 var arr = [12,5,7];
 2 var json = {"a":12,"b":5,"c":7};
 3 
 4 alert(arr[0]);      //返回:12
 5 alert(json["a"]);    //返回:12
 6 
 7 alert(arr.length);    //返回:3
 8 alert(json.length);   //返回:undefined
 9 
10 //数组for循环
11 for(var i=0; i<arr.length; i  ){
12     alert('第'   (i 1)   '个数据是:'   arr[i]);
13 }
14 alert(typeof i);    //返回:number
15 
16 //数组使用for...in循环
17 for(var i in arr){
18     alert('第'   (i 1)   '个数据是:'   arr[i]);
19 }
20 alert(typeof i);    //返回:string
21 
22 //JSON使用for...in循环
23 for(var i in json){
24     alert('第'   i   '个数据是:'   json[i]);
25 }

 

  (3)、JSON 数组对象

 1 <body>
 2 <p>
 3 姓 名: <br> 
 4 性 别: <br>
 5 员工号: <br> 
 6 修改姓名: <br> 
 7 </p> 
 8 <script>
 9 var staff = [
10     {"name" : "小明", "sex" : "男", "id" : 1}, 
11     {"name" : "小白", "sex" : "男", "id" : 2}, 
12     {"name" : "小红", "sex" : "女", "id" : 3}
13 ];
14 var x = document.getElementById("fname");
15 var y = document.getElementById("gender");
16 var z = document.getElementById("num");
17 var n = document.getElementById("lname");
18 //访问对象数组中第一项的值:
19 x.innerHTML = staff[0].name;
20 y.innerHTML = staff[0].sex;
21 z.innerHTML = staff[0].id;
22 
23 //修改数据:
24 n.innerHTML = staff[1].name = '大白';
25 </script>
26 </body>

 

   (4)、JSON 字符串对象

var str = '{"name":"小明", "sex":"男", "age":21}';
var toObj = JSON.parse(str);  //JSON字符串转换为JSON对象
alert(toObj.name);
alert(typeof toObj);    //返回:object

var json = {"name":"小红", "sex":"女", "age":18};
var toStr = JSON.stringify(json);  //JSON对象转换为JSON字符串
alert(toStr);    //返回字符串
alert(json.age);
alert(typeof toStr);    //返回:string

 

  (5)、JSON 应用

  当需要表示一组数据时,JSON 不但能够提高可读性,而且还可以减少复杂性。JSON 能够表示多个值,每个值又可包含多个值,例如要表示一个用户列表信息,就可以将所有信息存储在一个变量中,分成多项,每项中又可分成多个条目,每个条目中记录一个用户的信息。

 1 var userName = {
 2     "first": [{
 3         "name": "路飞",
 4         "sex": "男",
 5         "tel": "aaa"
 6     }, {
 7         "name": "索罗",
 8         "sex": "男",
 9         "tel": "bbb"
10     }, {
11         "name": "娜美",
12         "sex": "女",
13         "tel": "ccc"
14     }],
15 
16     "second": [{
17         "name": "卡卡西",
18         "sex": "男",
19         "tel": "ddd"
20     }, {
21         "name": "鸣人",
22         "sex": "男",
23         "tel": "fff"
24     }, {
25         "name": "佐助",
26         "sex": "男",
27         "tel": "eee"
28     }, {
29         "name": "皱田",
30         "sex": "女",
31         "tel": "sss"
32     }],
33 
34     "third": [{
35         "name": "小明",
36         "sex": "男",
37         "tel": "xxx"
38     },{
39         "name": "小红",
40         "sex": "女",
41         "tel": "zzz"
42     }]
43 };
44 
45 //获取用户的信息:
46 alert(userName.first[1].name   ' n '   userName.first[1].sex   'n '  userName.first[1].tel);
47 alert(userName.second[3].name   ' n '   userName.second[3].sex  ' n '  userName.second[3].tel);
48 alert(userName.third[0].name   ' n '   userName.third[0].sex   ' n '  userName.third[0].tel);

 

  **说到 JSON,就不得不提一下 JSONP。JSONP (JSON with Padding) 是 JSON 的一种 "使用模式",可以让网页从别的域名(网站)那获取资料,即跨域读取数据。可用于解决主流浏览器的跨域数据访问的问题。为什么从不同的域(网站)访问数据需要一个特殊的技术 (JSONP) 呢?这是因为同源策略。同源策略,它是由 Netscape 提出的一个著名的安全策略,现在所有支持 JavaScript 的浏览器都会使用这个策略。由于该策略,一般来说位于 server1 的 demo.com 的网页无法与不是 server1 的 demo.com 的网页的服务器沟通,而 HTML 的 <script> 元素是一个例外。利用 <script> 元素的这个开放策略,网页可以得到从其他来源动态产生的 JSON 资料,而这种使用模式就是所谓的 JSONP。**用 JSONP 抓到的资料并不是 JSON,而是任意的 JavaScript,用 JavaScript 直译器执行而不是用 JSON 解析器解析。

 

本篇介绍如何破解汽车之家配置页面的伪元素和混淆的JS。 

为了示范脚本如何控制对象的操作,下面演示计算文件大小的两个实例,分别是Jscript编写的FileSize.js和VBScirpt编写的FileSize.vbs。两个脚本中包括定义为“GetFileSize()”的函数接受一个文件路径为参数,并返回文件路径及其大小。Jscript脚本的源代码如下:

在Swift3之前的情况:

下一篇:翻译《Writing Idiomatic Python》(四):字典、集合、元组

3、JS 定时器

  定时器可以在指定的时间间隔之后再执行代码,而不是在函数被调用后立即执行。**定时器在网页中应用非常广泛,最常见的就是动态时钟,还有比如购物网站的倒计时抢购。定时器的类型可分为两类:一类是间隔型,即 setInterval,在执行时,从页面加载后每隔一段时间执行一次,可无限执行。另一类是延迟型,即 setTimeout,在页面加载后延迟指定的时间,去执行一次,而且仅仅只执行一次。该方法属于 window 对象的两个方法。**

  (1)、setInterval

  setInterval(function, time)  方法可间隔指定的毫秒数,不停的执行指定的代码。该方法有两个参数,第一个参数是函数,指定定时器要调用的函数或要执行的代码串,第二个参数是时间,用毫秒计,1000 毫秒是 1 秒,指定执行的间隔时间。

  (2)、setTimeout

  setTimeout(function, time)  方法可延迟指定的毫秒数后,再执行一次指定的代码。该方法也有两个参数,第一个参数为函数,指定要调用的函数或代码串,第二个参数指定在执行代码前需要等待多少毫秒。

1 function show(){
2     alert(1);
3 }
4 //当页面加载后,每隔1秒弹出一个1,无限次执行
5 setInterval(show,1000);
6 
7 //当页面加载后,在1秒后弹出一个1,只执行一次
8 setTimeout(show,1000);

 

  setInterval **动态时钟**效果:

 1 //动态显示时钟
 2 <p id="demo"></p>
 3 <script>
 4 function clock(){
 5     var d = new Date();   
 6     var time = d.getHours()   ":"   d.getMinutes()   ":"   d.getSeconds() ;
 7     var oP = document.getElementById("demo").innerHTML = time;
 8 }
 9 setInterval(clock,1000);
10 </script>

 

  setTimeout 统计效果:

 1 //setTimeout可实现统计:
 2 <input type="text" id="demo" >
 3 <script>
 4 var num = 0;
 5 function start() {
 6     document.getElementById('demo').value = num;
 7     num  = 1;
 8     setTimeout(start,1000);
 9 }
10 setTimeout(start,1000);
11 </script>

 

  可以开启定时器,也就可以关闭定时器。两种类型对应着两种方法。

  (1)、clearInterval

  clearInterval()  方法可关闭由 setInterval() 方法执行的函数代码。使用该方法关闭定时器时,在创建间隔定时器时必须使用全局变量。

  开始、停止动态时钟效果:

 1 //开始、停止动态时钟
 2 <input type="text" id="txt1" >
 3 <input type="button" value="停止" onclick="stop()" >
 4 <input type="button" value="开始" onclick="start()" >
 5 <script>
 6 var time = null;
 7 function start(){
 8     time = setInterval(function (){
 9         var d = new Date();   
10         var t = d.getHours()   ":"   d.getMinutes()   ":"   d.getSeconds();
11         var oTxT = document.getElementById("txt1").value = t;
12     },1000);
13 };
14 start();
15 function stop(){
16     clearInterval(time);
17 }
18 </script>

 

  (2)、clearTimeout

  clearTimeout()  方法用于停止执行由 setTimeout() 方法执行的函数代码。使用该方法时关闭定时器时,在创建延迟定时器时必须使用全局变量。

  开始、停止统计效果:

 1 //开始、停止统计:
 2 <input type="text" id="txt1" >
 3 <input type="button" value="停止" onclick="stop()" >
 4 <input type="button" value="开始" onclick="start()" >
 5 <script>
 6 var num = 0;
 7 var time = null;
 8 function start(){
 9     var oTxt = document.getElementById('txt1').value = num;
10     num  = 1;
11     time = setTimeout('start()',1000);
12 }
13 start();
14 function stop(){
15     clearTimeout(time);
16 }
17 </script>

 

 

function GetFileSize(filePath)

Swift中数组(Array)和字典(Dictionary)类型均以结构体的形式实现.然而当数组被赋予一个常量或者变量, 或被传递给一个函数或方法时, 其拷贝行为与字典和其他结构体有些许不同.

2.1 变量

4、Event 对象

  e**vent 对象代表事件的状态,用于获取事件的详细信息,如鼠标按钮、鼠标位置、键盘按键。事件通常与函数一起使用,函数不会在事件发生前被执行。澳门新萄京官方网站,**

  (1)、获取鼠标坐标

  screenX 和 screenY 返回鼠标相对于屏幕的水平坐标和垂直坐标。参照点为屏幕的左上角。

  clientX 和 clientY 返回鼠标相对于当前窗口可视区的水平坐标和垂直坐标。参照点为浏览器页面的左上角。

1 document.onclick = function (){
2     //可视区坐标
3     alert(event.clientX   ','   event.clientY);
4     //屏幕坐标
5     alert(event.screenX   ','   event.screenY);
6 }

 

  (2)、获取鼠标**钮按**

  button 事件属性用于获取鼠标哪个按钮被点击了。返回一个整数,0 代表左键,1 代表中键,2 代表右键。

1 //鼠标左右按键
2 document.onmousedown = function (){
3     alert(event.button);
4 }

 

  (3)、获取键盘按键

  keyCode 事件属性用于获取按下了键盘的哪个键,返回键码,表示键盘上真实键的数字。

1 //键盘按键
2 document.onkeydown=function (){
3     alert(event.keyCode);
4 };

 

  键盘按键的 ctrlKey、shiftKey 和 altKey 快捷属性,可判断是否按下了该键,返回一个布尔值,指示在事件发生时,改键是否被按下。1 表示被按下,0 表示没有按下。

 1 document.onkeydown = function (){
 2     if(event.ctrlKey == 1){
 3         alert('Ctrl键被按了');
 4     }
 5     else if(event.shiftKey == 1){
 6         alert('Shift键被按了');
 7     }
 8     else if(event.altKey == true){
 9         alert('Alt键被按了');
10     }
11     else{
12         alert('都没被按下');
13     }
14 };

 

    实例:**按键提交消息**

 1 <!DOCTYPE html>
 2 <html>
 3 <head>
 4     <meta charset="utf-8" />
 5     <title>JavaScript示例</title>
 6 <script>
 7 window.onload=function (){
 8     var oTxt1 = document.getElementById('txt1');
 9     var oTxt2 = document.getElementById('txt2');
10     var oBtn = document.getElementById('btn1');
11 
12     //点击按钮提交
13     oBtn.onclick = function (){
14         //输入框的值等于文本框的值。
15         oTxt2.value  = oTxt1.value   'n';
16         //清空输入框的值,以便再次输入
17         oTxt1.value = '';
18     };
19 
20 
21     //按Enter或Ctrl Enter提交
22     oTxt1.onkeydown = function (){
23         //回车键的键码为13
24         if(event.keyCode == 13 || event.keyCode == 13 && event.ctrlKey){
25             oTxt2.value  = oTxt1.value   'n';
26             oTxt1.value = '';
27         }
28     };
29 }
30 </script>
31 </head>
32 <body>
33 <input id="txt1" type="text" >
34 <input id="btn1" type="button" value="提交"><br>
35 <textarea id="txt2" rows="10" cols="50" ></textarea>
36 </body>
37 </html>

 

  (4)、事件流

  事件的传递有两种方式:冒泡与捕获。事件传递定义了元素触发事件的顺序。

  **事件冒泡:当一个元素发生事件后,事件会顺着层级(父级

  • 父级的父级 --)关系依次向上传递直到 document。**

  事件捕获:事件捕获与事件冒泡正好相反,外部元素的事件会先被触发,然后才会触发内部元素的事件,即从祖先到后代。

  事件流同时支持两种事件方式,冒泡型事件和捕获型事件,但是捕获型事件先发生。

  两种事件流会触发 DOM 中的所有对象,从 document 对象开始,也在 document 对象结束。

  语法:addEventListener('事件名称',函数,冒泡/捕获)

  addEventListener()  方法用于向指定元素添加事件,该方法不会覆盖已存在的事件,可同时向一个元素添加多个事件。该方法有三个参数,第一个参数定义事件的类型,

  第二个参数规定事件触发后调用的函数,第三个参数是布尔值,用于定义该事件是冒泡还是捕获,若为 false,则表示冒泡事件,若是 ture,则表示捕获事件。

  这里需要注意是的该方法的事件类型,不需要加”on“,比如平时写点击事件:“onclick”,该方法中则使用“click”即可。

 1 <!DOCTYPE html>
 2 <html id="htm">
 3 <head>
 4     <meta charset="utf-8" />
 5     <title>JavaScript示例</title>
 6 <style>
 7 div{padding:50px;}
 8 </style>
 9 <script>
10 window.onload = function (){
11     var x = document.getElementById("div1");
12     var y = document.getElementById("div2");
13     var z = document.getElementById("div3");
14 
15     var o = document.getElementById("bod");
16     var n = document.getElementById("htm");
17 
18     x.addEventListener("click", function() {
19         alert("1冒泡");
20     }, false);
21 
22     y.addEventListener("click", function() {
23         alert("2冒泡");
24     }, false);
25 
26     z.addEventListener("click", function() {
27         alert("3冒泡");
28     }, false);
29 
30     o.addEventListener("click", function() {
31         alert("body捕获");
32     }, true);
33 
34     n.addEventListener("click", function() {
35         alert("html冒泡");
36     }, false);
37 };
38 </script>
39 </head>
40 <body id="bod">
41 <div style="background:lightgreen;margin-bottom:10px;">我是body元素,我捕获。祖先html也会冒泡。</div>
42 <div id="div3" style="background:#ccc;">我是div3,我冒泡
43     <div id="div2" style="background:green;">我是div2,我冒泡
44         <div id="div1" style="background:red;">我是div1,我冒泡</div>
45     </div>
46 </div>
47 </body>
48 </html>

 

  removeEventListener()  方法用于移除由 addEventListener() 方法添加的事件监听。这里需要注意**在绑定函数时不能使用匿名函数,否则无法删除。**

 1 <!DOCTYPE html>
 2 <html>
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>JavaScript示例</title>
 6 <style>
 7 #div1{
 8     background:green;
 9     padding:50px;
10     color:white;
11 }
12 </style>
13 </head>
14 <body>
15 <div id="div1">
16 div元素添加了onmousemove事件监听,鼠标在绿色区域内移动时会显示随机数。
17 <p>点击按钮可移除div的事件监听。</p>
18     <button id="btn1">点击移除</button>
19 </div>
20 <p id="p1"></p>
21 
22 <script>
23 var oDiv = document.getElementById("div1");
24 var oP = document.getElementById("p1");
25 var oBtn = document.getElementById("btn1");
26 
27 oDiv.addEventListener("mousemove", block, false);
28 function block(){
29     oP.innerHTML = Math.random()*10;
30 }
31 oBtn.onclick = function (){
32     oDiv.removeEventListener("mousemove", block, false);
33 };
34 </script>
35 </body>
36 </html>

 

  cancelBubble  方法可取**消事件冒泡,不会往父级传递。实例:仿百度翻译效果,点击显示按钮显示 div,随便点击页面其他位置隐藏 div。**

  如果不取消事件冒泡,则在点击按钮的同时 div 先是显示了,然后又立马被隐藏了,可以注释掉取消事件冒泡代码,用弹窗查看效果。

 1 <!DOCTYPE html>
 2 <html>
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>JavaScript示例</title>
 6 <style>
 7 #div1{
 8     width:500px;
 9     height:300px;
10     background:lightgreen;
11     display:none;
12 }
13 </style>
14 <script>
15 window.onload = function (){
16     var oBtn = document.getElementById("btn1");
17     var oDiv = document.getElementById("div1");
18 
19     //点击按钮显示div
20     oBtn.onclick = function (){
21         oDiv.style.display = 'block';
22         //alert('显示');
23     
24         //取消事件冒泡,不会往父级传递。
25         event.cancelBubble = true;
26     };
27 
28     //点击document隐藏div
29     document.onclick = function (){
30         oDiv.style.display = 'none';
31     };
32 };
33 </script>
34 </head>
35 <body>
36 <input id="btn1" type="button" value="显示">
37 <div id="div1"></div>
38 </body>
39 </html>

 

  (5)、默认事件

  所谓的默认事件,就是浏览器自带的事件。比如按下键盘按键,浏览器会自动将按键值写入输入框。再比如新建一个空白页面在浏览器打开,点击右键出现菜单项。我们并没有用 JS 写相关判断,如果点击右键触发什么事件。这就是浏览器的默认事件,也叫默认行为。**如果我们想弹出自定义的右键菜单项,这时候就需要阻止掉浏览器的默认行为,阻止默认事件最简单的写法就是 return false; 。**

  实例:只能输入数字键的输入框,不考虑小键盘区。

  实现思路:键盘区数字键 0 的键码是 48,1 是 49,9 是 57,那么就可以做出判断,如果按键小于 48 或大于 57,则阻止掉,这说明按下的不是数字键,考虑到写错了需要删除,或者少写了,需要光标移动到少写的位置补上,再移回继续输入,那么就再加上判断条件,如果按键不是退格键或者不是左右方向键,则阻止掉。删除键(退格键)的键码是 8,左方向键是 37,右方向键为 39。

 1 <!DOCTYPE html>
 2 <html>
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>JavaScript示例</title>
 6 <script>
 7 window.onload = function (){
 8     var oTxt = document.getElementById('txt1');
 9     oTxt.onkeydown = function (){
10 
11         //如果按下的不是删除键8,并且不是左方向键37,并且不是右方向键39,并且按键键码小于48或大于57,则阻止掉
12         if(event.keyCode !=8 && event.keyCode != 37 && event.keyCode != 39 && event.keyCode < 48 || event.keyCode > 57){
13             return false;
14         }
15     };
16 };
17 </script>
18 </head>
19 <body>
20 <input id="txt1" type="text" placeholder="请输入数字">
21 </body>
22 </html>

 

** 温馨提示:如需转载本文,请注明内容出处。**

{

字典类型的赋值和拷贝行为

无论何时将一个字典实例赋值给一个常量或变量, 或者传递给一个函数或方法, 这个字典都会在赋值或者调用发生时被拷贝.
如果字典实例中所存储的键和值是值类型(结构体或枚举), 当赋值或调用发生时, 都会被拷贝, 是值拷贝, 相反, 如果键和值是引用类型, 被拷贝的将会是引用, 而不是被它们引用的类实例或函数.

var ages = ["Peter": 23, "Wei": 35, "Anish": 65, "Katya": 19]
var copiedAges = ages

修改:

copiedAges["Peter"] = 24
print(ages["Peter"])
 // 输出 "23"

是值拷贝

2.1.1 对多个变量要赋同一个值时,使用链式赋值让语句变得简明

Python支持链式赋值使多个变量可以在一次链式赋值中被设置为同一个值,这使得语句更加简明。

不良风格:

1 x = 'foo'
2 y = 'foo'
3 z = 'foo'

地道Python:

1 x = y = z = 'foo'

5、JS 知识点

  (1)、JS 引擎的预解析机制

  JS 引擎的解析过程可分为两个阶段:预解析阶段和执行阶段。

  JS 预解析是在程序进入一个新环境时,把该环境中的变量和函数预解析到他们能调用的环境中,即每一次的预解析单位是一个执行环境。当文档流中有多个 JS 代码段,每个代码段用 script 标签分隔,包括外部引入的 JS 文件,JS 引擎并非是逐行的解析程序,而是分段进行的,即一个执行环境。预解析不能跨代码段执行,简单说就是不能在一个代码段声明,在另一个代码段调用。

  变量和函数的预解析就是提升,所谓提升(hoisting),就是 JS 引擎在执行时,默认将所有的变量声明和函数声明都提升到当前作用域的最前边去的行为。**所以函数可以在声明之前调用。需要注意的是在使用表达式定义函数时无法提升。**

 1 <script>
 2 alert(a(2));    //返回:4
 3 function a(x){
 4     return x * x;
 5 }
 6 
 7 alert(b);    //返回:undefined
 8 var b = 'hello'; 
 9 
10 alert(c(2));    //报错
11 //实际上是以变量声明提升
12 //相当于:c(); var c = undefined; c = function (){}
13 var c = function (y){
14     return y * y;
15 }
16 
17 function d(){
18     var n = 'hello';
19 }
20 alert(n);    //报错
21 </script>

 

  通过上面的代码可以看出,function 定义的函数声明 (a) 在代码开始执行之前(预解析阶段)对其实现了函数声明提升,先将其放入内存中,所以在函数声明之前可以调用该函数。和函数声明一样,变量声明 (b) 也会在一开始被放入内存中,但是并没有赋值,所以在他赋值之前,他的值就是 undefined。但是函数表达式 (c) 不同,函数表达式用 var 声明,也就是说解析器会对其变量提升,并对其赋值为 undefined,然后在执行期间,等到执行到该 var 变量的时候再将其变量指向一个 function 函数,所以在函数表达式之前执行该函数就会报错。函数 (d) 是在函数内声明的变量,那么这个变量是属于该函数的私有变量,所以在外部调用时会报错。

  下面实例实例说明了**每一次 JS 预解析的单位是一个执行环境,不会跨一个代码段去执行,直接会报错。**

1 <script>
2     alert(a);//报错:a is not defined
3 </script>
4 
5 <script>
6     var a = 'hello';
7 </script>

 

  若定义了两个同名的函数 (b),则在预解析时后面的一个会覆盖掉前边的一个。若变量 (a) 和函数重名 (a),则函数的优先级高于变量的优先级。

 1 <script>
 2 alert(a); //返回:function a(){alert('hi');} 
 3 var a = 'hello'; 
 4 
 5 function a(){
 6     alert('hi');
 7 }
 8 alert(a); //返回:hello
 9 
10 b();    //返回:2
11 function b(){
12     alert(1);
13 }
14 b();    //返回:2
15 function b(){
16     alert(2);
17 }
18 </script>

 

  (2)、回调函数

  简单理解,所谓回调,就是回头调用,那么回调函数就是一个函数调用的过程。比如函数 a 有一个参数,这个参数是一个函数 b,当函数 a 执行完以后再执行函数 b,那么这就是一个回调的过程。用官方术语解释就是:回调是一个函数作为参数传递给另一个函数,其母函数完成后执行。那么函数 a 就是母函数。这里需要注意:函数 b 是以参数的形式传递给函数 a 的,那么这个函数 b 就被称为回调函数。回调函数不是由母函数直接调用的,而是在特定的事件或者条件发生时由另外的一方调用,用于对该事件进行响应。回调函数必须使用关键字 callback,并且回调函数本身必须是全局函数。

  JS 回调的原理是一个异步的流程,在异步调用的情况下使用性能很好,举个简单的例子更能具体的说明,比如朋友要来找你,等到门口了给你打电话。"来找你" 就是函数 a 开始执行,而这时候"你"可以去做任何事情,"到门口"就是函数 a 执行完毕,"给你打电话"这就属于回调函数 b,然后你们就可以一起愉快的玩耍了。

  下面是一个简单的回调函数实例,点击按钮,当函数 a 执行完成后,分别调用回调函数 b、c、d。

 1 <!DOCTYPE html>
 2 <html>
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>JavaScript示例</title>
 6 <script>
 7 function a(callback){
 8     alert("我是母函数a");
 9     alert("现在要开始调用回调函数");
10     callback();
11 }
12 function b(){
13     alert("我是回调函数b");
14 }
15 function c(){
16     alert("我是回调函数c");
17 }
18 function d(){
19     alert("我是回调函数d");
20 }
21 function back(){
22     a(b);
23     a(c);
24     a(d);
25 }
26 </script>
27 </head>
28 <body>
29 <button onclick="back()">点击按钮</button>
30 </body>
31 </html>

 

  (3)、自调用函数

  自调用函数也叫立即执行函数。使用关键字 function 定义一个函数,在给这个函数指定一个函数名,这叫函数声明。使用关键字 function 定义一个函数,未给函数命名,在将这个匿名函数赋值个一个变量,这叫做函数表达式,这也是最常见的函数表达式语法。匿名函数就是使用关键字 function 定义一个函数,但是不给函数命名,匿名函数属于函数表达式。匿名函数有很多作用,可赋予变量创建函数,赋予一个事件则称为事件处理程序。

  函数声明和函数表达式的区别:**JS 引擎在解析 JS 代码时当前执行环境中的函数声明会提升,而函数表达式只能等到 JS 引擎执行到他所在的作用域时,才会逐行的解析函数表达式。函数声明不能使用自调用,而函数表达式可以使用自调用。**

  函数的自调用就是在函数体后加括号,再用括号整个包起来。这样说明该函数是一个函数表达式。

1 (function (a, b) {
2     alert(a * b);
3 }(2, 3));    //返回:6

 

  (4)、构造函数

  函数通过关键字 function 定义,也可以使用关键字 new 定义。函数即对象,对象具有属性和方法,构造函数就是将定义的函数作为某个对象的属性,函数定义作为对象的属性,则称之为对象方法。函数如果用于创建新的对象,就叫做对象的构造函数。

  (5)、闭包

  简单理解就是:子函数可以使用父函数中的局部变量。之前好几个例子中都用到了闭包,就是 window.onload 函数下定义的点击事件函数。

  JS 的变量可以是全局变量或局部变量,在函数之外声明的变量就是全局变量,函数之内声明的变量就是局部变量,私有变量可以用到闭包。函数可以访问全局的变量,也可以访问局部的变量。作用域就是变量和函数的可访问范围,即作用域控制着变量和函数的可见性与生命周期,忽略块级作用域,作用域可分为全局作用域和局部作用域。全局变量是全局对象的属性,局部变量是调用对象的属性。全局变量属于 window 对象,全局变量在任何地方都可以访问,局部变量只能用于定义他的函数内部,这就是 JS 的作用域链,即内层函数可以访问外层函数的局部变量,外层函数不能访问内层函数的局部变量。全局变量和局部变量即便名称相同,他们也是两个不同的变量。修改其中一个,不会修改另一个的值。这里需要注意:在函数内声明的量,如果不使用关键字 var ,那么他就是一个全局变量。

  所有函数都能访问全局变量,也就是所有的函数都可以访问他上一层的作用域。JS 支持函数嵌套,嵌套函数可以访问上一层的函数变量。闭包就是可以访问上一层函数作用域中的变量函数,即便上一层函数已经关闭。

  闭包实例解析:

  如果想实现点击按钮计数,可以声明一个变量,并赋初始值为 0,函数设置值加 1。但是这个全局变量在任何地方都可以使用,即便没有调用这个函数,计数也会改变。

 1 <body>
 2 <input type="button" value="全局变量计数" onclick="show()">
 3 <input type="button" value="调用一次变量" onclick="change()">
 4 <p id="p1">0</p>
 5 <script>
 6 var num = 0;
 7 function count() {
 8     return num  = 1;
 9 }
10 var oP = document.getElementById("p1");
11 function show(){
12     oP.innerHTML = count();
13 }
14 function change(){
15     alert(num = 10);
16 }
17 </script>
18 </body>

 

  上面例子,每次点击按钮计数正常,但如果调用一次变量,给变量赋值为 10,再点按钮将从 11 开始计数。那么可以将这个变量声明在函数内,如果没有调用这个函数,计数将不会改变。

 1 <body>
 2 <input type="button" value="点击计数" onclick="show()">
 3 <p id="p1">0</p>
 4 <script>
 5 function count() {
 6     var num = 0;
 7     return num  = 1;
 8 }
 9 var oP = document.getElementById("p1");
10 function show(){
11     oP.innerHTML = count();
12 }
13 </script>
14 </body>

 

  点击按钮可以看到事与愿违,虽然这样不能在函数外部使用变量,也就不能修改计数,但是每次点击按钮值都为 1。因为变量是在函数内声明的,只有该函数可以使用,每点击按钮一次,调用一次该函数,每次调用变量的初始值都为 0,再加 1 就是 1。那么使用 JS 的嵌套函数可以完成这一问题,内嵌函数可以访问父函数的变量。

 1 <body>
 2 <input type="button" value="计数" onclick="show()">
 3 <p id="p1">0</p>
 4 <script>
 5 function count(){
 6     var num = 0;
 7     function add(){
 8         num  = 1;
 9     }
10     add();
11     return num;
12 }
13 add();    //报错:未定义
14 function show(){
15     document.getElementById("p1").innerHTML = count();
16 }
17 </script>
18 </body>

 

  虽然这样可以解决变量的问题,但是如果可以在外部调用 add() 函数的话,那么点击按钮计数就完美了,梦想总是美好的,现实却是残酷的,内嵌函数不能在外部被调用。这时候我们的闭包就来了,我们需要闭包,有了闭包这个问题就真的完美了。

 1 <body>
 2 <input type="button" value="计数" onclick="show()">
 3 <p id="p1">0</p>
 4 <script>
 5 var count = (function (){
 6     var num = 0;
 7     return function (){
 8         return num  = 1;
 9     };
10 }());
11 var oP = document.getElementById('p1');
12 function show(){
13     oP.innerHTML = count();
14 }
15 </script>
16 </body>

 

  变量 count 指定了函数自我调用返回值,自我调用函数只执行一次,计数初始值为 0,并返回函数表达式,计数受匿名函数作用域的保护,只能通过 count() 方法修改。

  变量 count 可以作为一个函数使用,他可以访问函数上一层作用域的计数,这就叫做 JS 闭包,函数拥有自己的私有变量。

 

 

  

 

本文链接:https://www.cnblogs.com/grom/p/9242156.html 

var fileSystem = new ActiveXObject("Scripting.FileSystemObject");

数组的赋值和拷贝行为

在Swift中, 数组类型的赋值和拷贝行为要比字典复杂很多. 当操作数组内容时, 数组能提供接近C语言的性能, 并且拷贝行为只有在必要时才会发生.
如果你将一个数组实例赋值给一个变量或常量, 或者将其作为参数传递给函数或方法调用, 在事件发生时数组的内容不会被拷贝. 相反, 数组公用相同的元素序列. 当你在一个数组内修改某一个元素, 修改结果也会在另一数组显示.
对数组来说 拷贝行为仅仅当操作有可能修改数组长度时才会发生. 这种行为包括了appending. inserting. removing或者使用范围下边去替换这一范围内的元素. 只有当数组拷贝确定要发生时, 数组内容的行为规则与字典中键值得相同.

var a=[1,2,3]
var b=a
var c=a

使用下标语法以得到数组的第一个元素

 print(a[0]) 
// 1
 print(b[0]) 
// 1
print(c[0]) 
// 1

如果通过下标语法修改数组中某一元素的值, 那么a,b,c中的对应值都会发生改变.当用下标语法修改某一值时, 并没有拷贝行为伴随发生, 因为下标语法修改值时没有改变数组长度:

a[0] = 42
print(a[0])
// 42
 print(b[0])
// 42
 println(c[0])
// 42

2.1.2 避免使用临时变量来实现值交换

在Python中完全没有必要使用一个额外的临时变量来实现值交换。使用元组来实现不仅方便并且可读性更强。

不良风格:

1 foo = 'Foo'
2 bar = 'Bar'
3 temp = foo
4 foo = bar
5 bar = temp

地道Python:

1 foo = 'Foo'
2 bar = 'Bar'
3 (foo, bar) = (bar, foo)

(本文分多次编辑,可从原文章查看最新更新)

var file = fileSystem.GetFile(filePath);

Swift 管理所有的值拷贝以确保性能最优化的性能,所以你也没有必要去避免赋值以保证最优性能。(实际赋值由系统管理优化)

然而当你给a附加新元素时, 数组的长度会改变, 当附加元素这一事件发生时, Swift会创建这个数组的一个拷贝, 从此以后, a将会是原数组的一个独立拷贝. 从此以后, a将会是原数组的一个独立拷贝. 拷贝发生后, 如果再修改a中元素值得话, a将会返回与b,c不同的结果,因为后者引用的是原来的数组.

a.append(4)
a[0] = 777
print(a[0])
// 777
print(b[0])
// 42 
print(c[0])
// 42

2.2 字符串

 

return (filePath " has " file.Size " bytes.");

2.2.1 对字符串相关的函数使用链式调用使意图更简明

当对某个字符串数据进行一系列的处理时,直接在上一个调用后接下一个调用常常比起创建一系列临时变量的方法更加明确和简单。当然,如果链式调用太多也会破坏可读性,一般来说如果操作不超过三个使用链式调用会更好。

不良风格:

1 book_info = ' The Three Musketeers: Alexandre Dumas'
2 formatted_book_info = book_info.strip()
3 formatted_book_info = formatted_book_infor.upper()
4 formatted_book_info = formatted_book_infor.replace(':', 'by')

地道Python:

1 book_info = ' The Three Musketeers: Alexandre Dumas'
2 formatted_book_info = book_info.strip().upper().replace(':', 'by')

笔者爬取得网站中,印象最为深刻的就是汽车之家的网站了,也是麻烦最多的网站之一了,特点是页面大面积使用伪元素代替关键字,解析伪元素的JS进行了动态混淆,每次刷新后的JS都是不同的,页面被禁用右键菜单,无法选中或复制。

}

2.2.2 使用''.join连接列表中的字符串元素

这样做更快,占用更低内存,并且这个用法在Python中非常普遍。注意下面的例子中使用的是用''连接字符串,实际在使用的时候可以替换为你想要的分隔符。

不良风格:

1 result_list = ['True', 'False', 'File not found']
2 result_string = ''
3 for result in result_list:
4     result_string  = result

地道Python:

1 result_list = ['True', 'False', 'File not found']
2 result_string = ''.join(result_list)

(因为破解了一周,怕分享出来后汽车之家就改了所以到现在运行了半年后才分享出来= =)

VBScript脚本的代码如下:

2.2.3 使用ord获取字符的ASCII码,使用chr从ASCII码获取字符

获取一个字符的ASCII码是一个有用的功能(比如字符串散列化),相应的,从ASCII得到对应的字符也常常很有用。

Python中提供了两个内建的函数,chrord,可以实现字符和ASCII码之间的相互转化。

不良风格:

 1 hash_value = 0
 2 character_hash = {
 3     'a': 97,
 4     'b': 98,
 5     'c': 99,
 6     # ...
 7     'y': 121,
 8     'z': 122,
 9 }
10 for e in some_string:
11     hash_value  = character_hash[e]
12 return hash_value

地道Python:

1 hash_value = 0
2 for e in some_string:
3     hash_value  = ord(e)
4 return hash_value

澳门新萄京官方网站:爬虫实战,JavaScript学习总结。网站地址:

Function GetFileSize(filePath)

2.2.4 用format函数来进行字符串格式化

一般来说又三种方式来进行字符串格式化:最简单但是最不推荐的就是用 来连接字符串。另一种方式是老式的利用%来格式化字符串的办法,在其他许多语言中也能看到这种方式,比如一些语言中的printf。这种方法比用 的方法好一些。

在Python中,最地道和清晰的用法当属用format函数来进行字符串格式化。和老式的格式化方法类似,这种办法用带有格式的字符串作为模板并用一些值替换占位符生成最终字符串。比老式的格式化方法更好的地方是,在format函数中,我们可以命名占位符,获取占位符的对应变量的属性,控制字符宽度和填充等。format函数让字符串格式化显得简明。

不良风格:

1 def get_formatted_user_info_worst(user):
2     # Tedious to type and prone to conversion errors
3     return 'Name: '   user.name   ', Age: '   str(user.age)   ', Sex: '   user.sex
4 
5 def get_formatted_user_info_slightly_better(user):
6     # No visible connection between the format string placeholders
7     # and values to use. Also, why do I have to know the type?
8     # Don't these types all have __str__ functions?
9     return 'Name: %s, Age: %i, Sex: %c' % (user.name, user.age, user.sex)

地道Python:

1 def get_formatted_user_info(user):
2     # Clear and concise. At a glance I can tell exactly what
3     # the output should be. Note: this string could be returned
4     # directly, but the string itself is too long to fit on the
5     # page.
6     output = 'Name: {user.name}, Age: {user.age}, Sex: {user.sex}'.format(user=user)
7     return output

 

Dim fileSystem

2.3 列表

澳门新萄京官方网站 1

Set fileSystem = CreateObject("Scripting.FileSystemObject")

2.3.1 使用列表解析从一个列表生成新的列表

在恰当使用的情况下,列表解析会增加代码从一个列表中创建新列表的明确性。尤其是当新创建的列表是源列表的某种变换或者条件检查时。

除了使代码更清晰,列表解析在执行效率上也非常高(CPython中)。

不良风格:

1 some_other_list = range(10)
2 some_list = list()
3 for element in some_other_list:
4     if is_prime(element):
5         some_list.append(element   5)

地道Python:

1 some_other_list = range(10)
2 some_list = [element   5 for element in some_other_list if is_prime(element)]

澳门新萄京官方网站 2

Dim file

2.3.2 使用负数下标

一个常被很多Python初用者忽视的特性是,在Python的列表和字符串中是可以使用负数下标的。和正数下标从列表开头向后数不同,附属下标从列表的末尾往回数。

不良风格:

1 def get_suffix(word):
2     word_length = len(word)
3     return word[word_length - 2:]

地道Python:

1 def get_suffix(word):
2     return word[-2:]

 

Set file = fileSystem.GetFile(filePath)

2.3.3 和内建的map()以及filter()函数相比,优先使用列表解析

Python是一门自诞生以来就一直在演化的语言。也正因为如此,一直有一些历史遗留被保留了下来。mapfilter函数就是例子,尽管曾经在一些情况下用mapfilter是最佳的选择,但是现在几乎所有的使用都可以用列表解析来代替。并且列表解析的可读性和清晰性更好,所以至少在我的书里我认为应该优先使用列表解析而不是mapfilter的组合。

不良风格:

1 the_list = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
2 def is_odd(number):
3     return number % 2 == 1
4 odd_numbers = filter(is_odd, the_list)
5 odd_numbers_times_two = list(map(lambda x: x * 2, odd_numbers))

地道Python:

1 the_list = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
2 odd_numbers_times_two = [n * 2 for n in the_list if n % 2 == 1]

// 其实这是个很见仁见智的问题,在stackoverflow上也有很多关于map/filter和list comprehension的争论,就效率而言,对不同的情况下两种办法互有胜负,就可读性而言其实我觉得map和filter比list comprehension好很多。。另外别忘了还有个函数叫reduce

基本就是这样,如果单纯的抓取页面元素后会是这样:

GetFileSize = filePath & " has " & file.Size & " bytes."

2.3.4 使用内建的sum函数对列表中的元素求和

对于一些已经用习惯sum的人来说可能会觉得这条比较奇怪。然而对更多的Python新手而言他们做的是自己重新实现了sum函数。如果一个函数已经是内建的,那么我们不应该重新发明轮子。

不良风格:

1 the_list = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
2 the_sum = 0
3 for element in the_list:
4     the_sum  = element

地道Python:

1 the_list = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
2 the_sum = sum(the_list)

澳门新萄京官方网站 3

End Function

2.3.5 使用all检查一个可遍历结构中是否所有元素都是真

sum一样,all也是一个被新手频繁重写的内建函数。它可以检查一个可遍历结构中的元素是否都为真。

不良风格:

1 def contains_zero(iterable):
2     for e in iterable:
3         if e == 0:
4             return True
5     return False

地道Python:

1 def contains_zero(iterable):
2     # 0 is "Falsy," so this works
3     return not all(iterable)

 

能够看到每种语言都有其相对特殊的函数声明方法、变量,以及与COM对象操作的方法。为了能够从PowerShell中调用Jscript函数,需要读取FileSize.js文件内容并且传递给脚本空间的AddCode()方法。这个方法将会执行函数定义,并使其在后面可用。

2.3.6 优先使用xrange而不是range,除非你需要的就是range生成的列表

xrangerange都能让你遍历一个数值列表。区别是,xrange不会再内存中存储一个完整的列表。大多数情况下这两者不会再实际使用时产生区别,但是当你需要遍历的数值范围非常大时,在内存占用和执行效率上就能看到很大差别了。

不良风格:

1 # A loop over a large range that breaks out
2 # early: a double whammy!
3 even_number = int()
4 for index in range (1000000):
5     if index % 2 == 0:
6         even_number = index
7         break

地道Python:

1 even_number = int()
2 for index in xrange(1000000):
3     if index % 2 == 0:
4         even_number = index
5         break

转载请注明出处:達聞西@博客园

上一篇:翻译《Writing Idiomatic Python》(二):函数、异常

下一篇:翻译《Writing Idiomatic Python》(四):字典、集合、元组

 开始分析:

1 执行代码

1.整个页面通过及配置数据都是直接Write出来的,因为配置项的详情在页面JS里同页面一起生成,并非通过接口。

在将脚本代码包含在脚本控件中后,即可调用在Jscript中定义的函数,为此可以使用Eval()或者Run()方法。Eval()方法将字符串作为输入并执行,其返回值将会把结果返回给调用方,本实例为PowerShell;Run()方法可以接受多个参数,其中第1个是函数名,后续是将要传递给函数的参数,该方法返回函数的返回值给PowerShell的脚本。在这里创建一个名为“JScriptEval.ps1”的脚本,分别使用Eval()和Run()调用Jscript函数,代码如下:

2.配置项数据在页面上

$jscript = New-Object -COM MSScriptControl.ScriptControl

澳门新萄京官方网站 4

$jscript.Language = "JScript"

 

$jsLines = Get-Content "FileSize.js"

(PS小妙招:将网页保存本地后发现文字依旧显示,然后大面积删除JS后刷新页面,如果文字依旧显示,继续删,直到找到加载数据的JS为止)

$jsCode = [string]::Join("`n", $jsLines)

事后发现第一个变量keyLink是左边配置名称的超链接

$jscript.AddCode($jsCode)

澳门新萄京官方网站 5

$fileName = (dir FileSize.js).FullName

第二个变量config是我们要的配置上半页(到车轮制动那),

Write-Host "Using Eval"

第三个变量option是主/被动安全装备及以下,

$jscript.Eval("GetFileSize(`"$($fileName.Replace('', '\'))`")")

第三四个变量color和innerColor是外观内饰颜色澳门新萄京官方网站 6

Write-Host "Using Run"

 

$jscript.Run("GetFileSize", $fileName)

 其他的没什么用,第五个可能是什么运动套装之类的,豪车才有,没仔细看。

其中将Language属性设置为“JScript”,表示其后调用的所有代码都是Jscript。接下来用Get-Content cmdlet获取FileSize.js文件中包含的所有内容,然后为各行代码添加换行符,并将其拼接后传递给AddCode()方法。

3.解密JS在这里澳门新萄京官方网站 7

Eval()方法需要将双引号转义为Jscript字符串,把反斜杠替换为双反斜杠。因为反斜杠在Jscript中是一个有特殊含义的转义字符,需要被转义;Run()方法不需要执行任何转义操作,因为使用的是脚本控件的机制传递参数。图1所示为该脚本的执行结果。

这个JS是被混淆过的,不可以根据变量名去获取。

澳门新萄京官方网站 8

 

图1 执行结果

4.破解流程,拿到这个配置JSON串,然后找到解析JS,计算JS的变量得到字典集(一大串文字)和下标集(一大串数字集合)根据下标取字典里对应的文字,得到真正的数据字典,然后替换指定的伪元素。

Eval()和Run()方法的执行结果相同,使用Run()方法可避免很多不必要的麻烦。

5.解析被混淆的JS,格式化后可以得到这样的一串JS

下面创建一个名为“VBScriptEval.ps1”的脚本,通过调用VBScript代码定义的GetFileSize()函数,代码如下:

 

$vbscript = New-Object -COM MSScriptControl.ScriptControl

澳门新萄京官方网站 9

$vbscript.Language = "VBScript"

提供一个完整的JS,有兴趣的小伙伴可以去研究研究

$vbsLines = Get-Content "FileSize.vbs"

澳门新萄京官方网站 10澳门新萄京官方网站 11

$vbsCode = [string]::Join("`n", $vbsLines)

function(nv_) {
    var pk_ = function () {
        'return pk_';
        return 'S';
    };

    function AH_() {
        function _A() {
            return 'UV';
        };
        if (_A() == 'UV,') {
            return 'AH_';
        } else {
            return _A();
        }
    }

    function cU_() {
        'return cU_';
        return '万价';
    }
    var xN_ = '元全准';

    function $GetCustomStyle$() {
        var $customstyle$ = '';
        try {
            if (HS_GetCustomStyle) {
                $customstyle$ = HS_GetCustomStyle();
            } else {
                if (navigator.userAgent.indexOf('Windows NT 5') != -1) {
                    $customstyle$ = 'margin-bottom:-4.8px;';
                } else {
                    $customstyle$ = 'margin-bottom:-5px;';
                }
            }
        } catch (e) { }
        return $customstyle$;
    }
    var Qz_ = '前力功';
    var rC_ = function () {
        'rC_';
        var _r = function () {
            return '动助华';
        };
        return _r();
    };
    var cO_ = function () {
        'cO_';
        var _c = function () {
            return '压';
        };
        return _c();
    };

    function ts_() {
        'return ts_';
        return '号合';
    }
    var vO_ = function (vO__) {
        var _v = function (vO__) {
            'return vO_';
            return vO__;
        };
        return _v(vO__);
    };
    var zS_ = '喷';

    function Gm_() {
        function _G() {
            return 'Gm_';
        };
        if (_G() == 'Gm__') {
            return _G();
        } else {
            return '器国';
        }
    }

    function Fo_() {
        function _F() {
            return '地';
        };
        if (_F() == '地') {
            return '地';
        } else {
            return _F();
        }
    }
    var wo_ = function (wo__) {
        var _w = function (wo__) {
            'return wo_';
            return wo__;
        };
        return _w(wo__);
    };
    var zk_ = function (zk__) {
        var _z = function (zk__) {
            'return zk_';
            return zk__;
        };
        return _z(zk__);
    };

    function WT_() {
        function _W() {
            return '子实容';
        };
        if (_W() == '子实容') {
            return '子实容';
        } else {
            return _W();
        }
    }
    var Ma_ = '宽';
    var vk_ = function () {
        'vk_';
        var _v = function () {
            return '寸导小';
        };
        return _v();
    };
    var zl_ = '度式弗';
    var ZS_ = function () {
        'ZS_';
        var _Z = function () {
            return '径';
        };
        return _Z();
    };

    function Wh_() {
        'return Wh_';
        return '悬';
    }

    function fG_() {
        function _f() {
            return '成';
        };
        if (_f() == '成') {
            return '成';
        } else {
            return _f();
        }
    }

    function $GetClassName$($index$) {
        return '.hs_kw'   $index$   '_configMd';
    }

    function $RuleCalss1$() {
        return '::before {content:'
    }

    function kE_() {
        function _k() {
            return '或';
        };
        if (_k() == '或') {
            return '或';
        } else {
            return _k();
        }
    }

    function wp_() {
        'return wp_';
        return '扭';
    }
    var yW_ = '承';

    function bc_() {
        'return bc_';
        return '指';
    }

    function tk_() {
        function _t() {
            return 'tk__';
        };
        if (_t() == 'tk__') {
            return '排';
        } else {
            return _t();
        }
    }
    var Yp_ = function () {
        'return Yp_';
        return '数';
    };

    function pR_() {
        function _p() {
            return 'pR__';
        };
        if (_p() == 'pR__') {
            return '整';
        } else {
            return _p();
        }
    }

    function BS_() {
        function _B() {
            return '最';
        };
        if (_B() == '最') {
            return '最';
        } else {
            return _B();
        }
    }
    var Bi_ = '构';
    var fQ_ = '架';

    function $GetWindow$() {
        return this[''   YE_()   (function (MR__) {
            'return MR_';
            return MR__;
        })('in')   zh_()];
    }
    var Bh_ = function () {
        'Bh_';
        var _B = function () {
            return '标';
        };
        return _B();
    };
    var JW_ = function () {
        'return JW_';
        return '格';
    };

    function wd_() {
        function _w() {
            return 'wd__';
        };
        if (_w() == 'wd__') {
            return '梁';
        } else {
            return _w();
        }
    }

    function UX_() {
        function _U() {
            return 'UX__';
        };
        if (_U() == 'UX__') {
            return '械';
        } else {
            return _U();
        }
    }

    function QU_() {
        function _Q() {
            return '气油';
        };
        if (_Q() == '气油,') {
            return 'QU_';
        } else {
            return _Q();
        }
    }
    var Ed_ = function () {
        'return Ed_';
        return '测';
    };

    function cZ_() {
        'return cZ_';
        return '海液';
    }
    var UZ_ = function (UZ__) {
        var _U = function (UZ__) {
            'return UZ_';
            return UZ__;
        };
        return _U(UZ__);
    };
    var vI_ = function () {
        'return vI_';
        return '燃';
    };
    var EI_ = function () {
        'EI_';
        var _E = function () {
            return '版独率';
        };
        return _E();
    };

    function DT_() {
        function _D() {
            return '盖';
        };
        if (_D() == '盖') {
            return '盖';
        } else {
            return _D();
        }
    }
    var JI_ = function (JI__) {
        var _J = function (JI__) {
            'return JI_';
            return JI__;
        };
        return _J(JI__);
    };

    function $Split$($item$, $index$) {
        if ($item$) {
            return $item$[''   jn_()   Dg_()   iu_()]($index$);
        } else {
            return '';
        }
    }

    function YY_() {
        'return YY_';
        return '积';
    }

    function hb_() {
        function _h() {
            return '称程立';
        };
        if (_h() == '称程立') {
            return '称程立';
        } else {
            return _h();
        }
    }
    var DC_ = function () {
        'return DC_';
        return '箱';
    };
    var ec_ = function () {
        'return ec_';
        return '综';
    };
    var $ruleDict$ = '';
    var $rulePosList$ = '';
    var Wr_ = function () {
        'Wr_';
        var _W = function () {
            return '缩';
        };
        return _W();
    };

    function zq_() {
        function _z() {
            return 'zq_';
        };
        if (_z() == 'zq__') {
            return _z();
        } else {
            return '胎自';
        }
    }
    var YS_ = function (YS__) {
        'return YS_';
        return YS__;
    };
    var Hj_ = '距车转';

    function Du_() {
        function _D() {
            return '轮';
        };
        if (_D() == '轮') {
            return '轮';
        } else {
            return _D();
        }
    }
    var cQ_ = function () {
        'return cQ_';
        return '轴载进';
    };

    function WM_() {
        'return WM_';
        return '适';
    }

    function yQ_() {
        'return yQ_';
        return '速';
    }
    var uC_ = function () {
        'return uC_';
        return '配量铝';
    };
    var lz_ = function (lz__) {
        var _l = function (lz__) {
            'return lz_';
            return lz__;
        };
        return _l(lz__);
    };
    var Te_ = '间隙风';
    var Ph_ = function () {
        'Ph_';
        var _P = function () {
            return '马';
        };
        return _P();
    };

    function UO_() {
        function _U() {
            return '驱驻';
        };
        if (_U() == '驱驻,') {
            return 'UO_';
        } else {
            return _U();
        }
    }

    function Iw_() {
        'return Iw_';
        return '高麦';
    }
    var KE_ = '7;107;3';

    function HA_() {
        function _H() {
            return ';9';
        };
        if (_H() == ';9,') {
            return 'HA_';
        } else {
            return _H();
        }
    }

    function PI_() {
        function _P() {
            return 'PI_';
        };
        if (_P() == 'PI__') {
            return _P();
        } else {
            return '5;70';
        }
    }

    function yr_() {
        'return yr_';
        return '82,29';
    }
    var mK_ = function () {
        'return mK_';
        return '1';
    };
    var Ff_ = '16,117;';

    function $Innerhtml$($item$, $index$) {
        var $tempArray$ = $GetElementsByCss$($GetClassName$($item$));
        for (x in $tempArray$) {
            $tempArray$[x].innerHTML = $index$;
            try {
                $tempArray$[x].currentStyle = '';
            } catch (e) { }
        }
    }

    function vs_() {
        function _v() {
            return 'vs_';
        };
        if (_v() == 'vs__') {
            return _v();
        } else {
            return '5,31';
        }
    }
    var Ds_ = ';102,11';

    function DV_() {
        function _D() {
            return '0;42,';
        };
        if (_D() == '0;42,') {
            return '0;42,';
        } else {
            return _D();
        }
    }

    function lU_() {
        function _l() {
            return '49;57,3';
        };
        if (_l() == '49;57,3') {
            return '49;57,3';
        } else {
            return _l();
        }
    }
    var yc_ = function (yc__) {
        'return yc_';
        return yc__;
    };

    function lf_() {
        function _l() {
            return '66,';
        };
        if (_l() == '66,') {
            return '66,';
        } else {
            return _l();
        }
    }
    var IN_ = function () {
        'return IN_';
        return '115';
    };

    function Fb_() {
        function _F() {
            return 'Fb__';
        };
        if (_F() == 'Fb__') {
            return ',54;1';
        } else {
            return _F();
        }
    }

    function $InsertRule$($index$, $item$) {
        $sheet$[''   Mn_()   BP_   Ni_()   FS_()   qg_()   KK_()   (function (cT__) {
            'return cT_';
            return cT__;
        })('e')]($GetClassName$($index$)   $RuleCalss1$()   '"'   $item$   '" }', 0);
        var $tempArray$ = $GetElementsByCss$($GetClassName$($index$));
        for (x in $tempArray$) {
            try {
                $tempArray$[x].currentStyle = '';
            } catch (e) { }
        }
    }
    var GE_ = function () {
        'GE_';
        var _G = function () {
            return '01,11';
        };
        return _G();
    };

    function Xq_() {
        function _X() {
            return '5';
        };
        if (_X() == '5') {
            return '5';
        } else {
            return _X();
        }
    }
    var UE_ = function () {
        'return UE_';
        return ',54;7';
    };
    var Xv_ = function () {
        'return Xv_';
        return '4';
    };
    var wv_ = ';40';

    function Kb_() {
        function _K() {
            return ',3';
        };
        if (_K() == ',3,') {
            return 'Kb_';
        } else {
            return _K();
        }
    }
    var Ej_ = '0,0,1';

    function Xm_() {
        function _X() {
            return 'Xm_';
        };
        if (_X() == 'Xm__') {
            return _X();
        } else {
            return ';1';
        }
    }

    function NT_() {
        'return NT_';
        return '21,101';
    }

    function rN_() {
        'return rN_';
        return ';';
    }
    var Fc_ = function () {
        'Fc_';
        var _F = function () {
            return '7,60;';
        };
        return _F();
    };

    function $ChartAt$($item$) {
        return $ruleDict$[''   (function () {
            'return Sm_';
            return 'c'
        })()   aT_()   wF_()](parseInt($item$));
    }

    function vC_() {
        'return vC_';
        return '98;53';
    }
    var iB_ = function () {
        'iB_';
        var _i = function () {
            return ',';
        };
        return _i();
    };

    function sn_() {
        'return sn_';
        return '11';
    }

    function ZU_() {
        function _Z() {
            return 'ZU_';
        };
        if (_Z() == 'ZU__') {
            return _Z();
        } else {
            return '2;51';
        }
    }

    function lM_() {
        'return lM_';
        return ',105,';
    }

    function CF_() {
        function _C() {
            return '44;67,9';
        };
        if (_C() == '44;67,9') {
            return '44;67,9';
        } else {
            return _C();
        }
    }

    function Ri_() {
        'return Ri_';
        return '2;6,67';
    }

    function Ye_() {
        function _Y() {
            return 'Ye_';
        };
        if (_Y() == 'Ye__') {
            return _Y();
        } else {
            return ';111';
        }
    }

    function HB_() {
        'return HB_';
        return ',66;1';
    }

    function EW_() {
        'return EW_';
        return '3,10';
    }
    var cW_ = function () {
        'return cW_';
        return '3';
    };

    function $GetDefaultView$() {
        return nv_[''   Tb_()   Vo_()   'au'   FI_()   ak_()   (function () {
            'return Ya_';
            return 'Vie'
        })()   (function () {
            'return Ki_';
            return 'w'
        })()];
    }

    function Yf_() {
        'return Yf_';
        return ',100;37';
    }
    var oh_ = function (oh__) {
        var _o = function (oh__) {
            'return oh_';
            return oh__;
        };
        return _o(oh__);
    };
    var Jn_ = '3';

    function tl_() {
        function _t() {
            return ';48,';
        };
        if (_t() == ';48,,') {
            return 'tl_';
        } else {
            return _t();
        }
    }
    var xY_ = function () {
        'return xY_';
        return '15;88,2';
    };
    var AD_ = function () {
        'AD_';
        var _A = function () {
            return '1;4';
        };
        return _A();
    };
    var iX_ = function (iX__) {
        var _i = function (iX__) {
            'return iX_';
            return iX__;
        };
        return _i(iX__);
    };
    var Cy_ = function () {
        'Cy_';
        var _C = function () {
            return ';90,79;';
        };
        return _C();
    };

    function CV_() {
        'return CV_';
        return '1,10;94';
    }

    function Xx_() {
        function _X() {
            return 'Xx__';
        };
        if (_X() == 'Xx__') {
            return ',';
        } else {
            return _X();
        }
    }
    var QW_ = function () {
        'QW_';
        var _Q = function () {
            return '7';
        };
        return _Q();
    };

    function Vh_() {
        function _V() {
            return 'Vh__';
        };
        if (_V() == 'Vh__') {
            return '2';
        } else {
            return _V();
        }
    }

    function Bw_() {
        'return Bw_';
        return ';13,1';
    }
    var Vs_ = '2,1';
    var Sq_ = '6';

    function ed_() {
        function _e() {
            return ',27;1';
        };
        if (_e() == ',27;1') {
            return ',27;1';
        } else {
            return _e();
        }
    }

    function Tn_() {
        function _T() {
            return 'Tn_';
        };
        if (_T() == 'Tn__') {
            return _T();
        } else {
            return '23,45,';
        }
    }

    function pr_() {
        function _p() {
            return 'pr__';
        };
        if (_p() == 'pr__') {
            return '8';
        } else {
            return _p();
        }
    }
    var aZ_ = function () {
        'return aZ_';
        return ';31,9';
    };
    var CL_ = '116';

    function fk_() {
        function _f() {
            return 'fk__';
        };
        if (_f() == 'fk__') {
            return ';78';
        } else {
            return _f();
        }
    }
    var pz_ = function (pz__) {
        'return pz_';
        return pz__;
    };

    function bC_() {
        function _b() {
            return 'bC__';
        };
        if (_b() == 'bC__') {
            return '5';
        } else {
            return _b();
        }
    }

    function $ResetSystemFun$() {
        if ($GetWindow$()[''   iH_()   Ct_()   Ap_()   XV_()   GP_()   BJ_()   fB_()   iz_()] != undefined) {
            if (window.hs_fuckyou == undefined) {
                window.hs_fuckyou = $GetWindow$()[''   iH_()   Ct_()   Ap_()   XV_()   GP_()   BJ_()   fB_()   iz_()];
            }
        }
        if ($GetDefaultView$()) {
            if ($GetDefaultView$()[''   iH_()   Ct_()   Ap_()   XV_()   GP_()   BJ_()   fB_()   iz_()] != undefined) {
                if (window.hs_fuckyou_dd == undefined) {
                    window.hs_fuckyou_dd = $GetDefaultView$()[''   iH_()   Ct_()   Ap_()   XV_()   GP_()   BJ_()   fB_()   iz_()];
                }
            }
        }
    }
    var YD_ = function () {
        'return YD_';
        return '8,64;15';
    };
    var Dl_ = ',76;5';

    function $InsertRuleRun$() {
        for ($index$ = 0; $index$ < $rulePosList$.length; $index$  ) {
            var $tempArray$ = $Split$($rulePosList$[$index$], ',');
            var $temp$ = '';
            for ($itemIndex$ = 0; $itemIndex$ < $tempArray$.length; $itemIndex$  ) {
                $temp$  = $ChartAt$($tempArray$[$itemIndex$])   '';
            }
            $InsertRule$($index$, $temp$);
        }
    }
    var dl_ = function (dl__) {
        var _d = function (dl__) {
            'return dl_';
            return dl__;
        };
        return _d(dl__);
    };

    function jK_() {
        function _j() {
            return 'jK__';
        };
        if (_j() == 'jK__') {
            return '3,91;32';
        } else {
            return _j();
        }
    }

    function fI_() {
        function _f() {
            return ',71;';
        };
        if (_f() == ',71;,') {
            return 'fI_';
        } else {
            return _f();
        }
    }

    function Wm_() {
        function _W() {
            return '24,';
        };
        if (_W() == '24,') {
            return '24,';
        } else {
            return _W();
        }
    }
    var CP_ = function () {
        'return CP_';
        return '6';
    };
    var Ga_ = function (Ga__) {
        var _G = function (Ga__) {
            'return Ga_';
            return Ga__;
        };
        return _G(Ga__);
    };

    function pT_() {
        'return pT_';
        return ';12';
    }

    function Ae_() {
        function _A() {
            return '2,43;';
        };
        if (_A() == '2,43;') {
            return '2,43;';
        } else {
            return _A();
        }
    }
    var Ry_ = function () {
        'Ry_';
        var _R = function () {
            return '1';
        };
        return _R();
    };
    var rM_ = '23,103,';

    function XI_() {
        function _X() {
            return 'XI_';
        };
        if (_X() == 'XI__') {
            return _X();
        } else {
            return '93;9';
        }
    }
    var gk_ = '7,6';

    function oQ_() {
        function _o() {
            return '2;4;1';
        };
        if (_o() == '2;4;1') {
            return '2;4;1';
        } else {
            return _o();
        }
    }

    function kp_() {
        'return kp_';
        return '04';
    }

    function NC_() {
        function _N() {
            return '100;28';
        };
        if (_N() == '100;28,') {
            return 'NC_';
        } else {
            return _N();
        }
    }

    function NP_() {
        function _N() {
            return 'NP_';
        };
        if (_N() == 'NP__') {
            return _N();
        } else {
            return ';52;';
        }
    }
    var sT_ = '50,14,6';

    function ux_() {
        function _u() {
            return 'ux__';
        };
        if (_u() == 'ux__') {
            return '3;50,81';
        } else {
            return _u();
        }
    }

    function hT_() {
        function _h() {
            return 'hT__';
        };
        if (_h() == 'hT__') {
            return ';';
        } else {
            return _h();
        }
    }

    function tL_() {
        'return tL_';
        return '90,5;';
    }
    var sX_ = '114,4';

    function qx_() {
        'return qx_';
        return '14;78,';
    }
    var kS_ = function () {
        'return kS_';
        return '26;96,8';
    };
    var OC_ = function (OC__) {
        'return OC_';
        return OC__;
    };
    var eT_ = function (eT__) {
        var _e = function (eT__) {
            'return eT_';
            return eT__;
        };
        return _e(eT__);
    };

    function yV_() {
        'return yV_';
        return '8;90,';
    }

    function $GetLocationURL$() {
        return $GetWindow$()[''   Kp_()   Ka_()   Lw_][''   rI_()   hw_()   MU_('f')];
    }

    function Ra_() {
        function _R() {
            return 'Ra__';
        };
        if (_R() == 'Ra__') {
            return '46;25';
        } else {
            return _R();
        }
    }

    function Hh_() {
        'return Hh_';
        return ';18';
    }

    function $SystemFunction1$($item$) {
        $ResetSystemFun$();
        if ($GetWindow$()[''   iH_()   Ct_()   Ap_()   XV_()   GP_()   BJ_()   fB_()   iz_()] != undefined) {
            $GetWindow$()[''   iH_()   Ct_()   Ap_()   XV_()   GP_()   BJ_()   fB_()   iz_()] = function (element, pseudoElt) {
                if (pseudoElt != undefined && typeof (pseudoElt) == 'string' && pseudoElt.toLowerCase().indexOf(':before') > -1) {
                    var obj = {};
                    obj.getPropertyValue = function (x) {
                        return x;
                    };
                    return obj;
                } else {
                    return window.hs_fuckyou(element, pseudoElt);
                }
            };
        }
        return $item$;
    }

    function Wc_() {
        function _W() {
            return ';';
        };
        if (_W() == ';') {
            return ';';
        } else {
            return _W();
        }
    }
    var $imgPosList$ = '';
    var Rd_ = function () {
        'Rd_';
        var _R = function () {
            return '75,86;7';
        };
        return _R();
    };
    var uZ_ = function () {
        'uZ_';
        var _u = function () {
            return '3';
        };
        return _u();
    };

    function nn_() {
        function _n() {
            return ',67;9';
        };
        if (_n() == ',67;9') {
            return ',67;9';
        } else {
            return _n();
        }
    }

    function Kj_() {
        function _K() {
            return 'Kj__';
        };
        if (_K() == 'Kj__') {
            return ',41,3';
        } else {
            return _K();
        }
    }
    var Zk_ = '8;36,';

    function JK_() {
        function _J() {
            return '83;35,6';
        };
        if (_J() == '83;35,6') {
            return '83;35,6';
        } else {
            return _J();
        }
    }
    var Zn_ = function (Zn__) {
        var _Z = function (Zn__) {
            'return Zn_';
            return Zn__;
        };
        return _Z(Zn__);
    };

    function hV_() {
        function _h() {
            return 'hV_';
        };
        if (_h() == 'hV__') {
            return _h();
        } else {
            return ',93;';
        }
    }
    var JL_ = '58,';

    function $SuperInsertRule$() {
        if ($sheet$ !== undefined && $sheet$[''   Mn_()   BP_   Ni_()   FS_()   qg_()   KK_()   (function (cT__) {
            'return cT_';
            return cT__;
        })('e')]) {
            return true;
        } else {
            return false;
        }
    }
    var UA_ = function () {
        'UA_';
        var _U = function () {
            return '59;106,';
        };
        return _U();
    };
    var bQ_ = '6';
    var zR_ = function () {
        'zR_';
        var _z = function () {
            return '6';
        };
        return _z();
    };
    var JD_ = function (JD__) {
        var _J = function (JD__) {
            'return JD_';
            return JD__;
        };
        return _J(JD__);
    };

    function gs_() {
        function _g() {
            return 'gs_';
        };
        if (_g() == 'gs__') {
            return _g();
        } else {
            return '7;66,9';
        }
    }

    function pf_() {
        function _p() {
            return '0;';
        };
        if (_p() == '0;,') {
            return 'pf_';
        } else {
            return _p();
        }
    }
    var Hz_ = function (Hz__) {
        'return Hz_';
        return Hz__;
    };

    function Ix_() {
        'return Ix_';
        return '20;';
    }
    var fV_ = function () {
        'return fV_';
        return '6';
    };

    function xQ_() {
        function _x() {
            return 'xQ_';
        };
        if (_x() == 'xQ__') {
            return _x();
        } else {
            return '9,119;';
        }
    }

    function CE_() {
        function _C() {
            return 'CE__';
        };
        if (_C() == 'CE__') {
            return '2';
        } else {
            return _C();
        }
    }
    var fN_ = '3,12,16';

    function DG_() {
        function _D() {
            return ',27';
        };
        if (_D() == ',27') {
            return ',27';
        } else {
            return _D();
        }
    }

    function JZ_() {
        'return JZ_';
        return ';19,';
    }

    function uk_() {
        function _u() {
            return '89,65;1';
        };
        if (_u() == '89,65;1') {
            return '89,65;1';
        } else {
            return _u();
        }
    }
    var jW_ = function () {
        'return jW_';
        return '09,11';
    };
    var Hu_ = function () {
        'Hu_';
        var _H = function () {
            return '8;23,10';
        };
        return _H();
    };

    function Jw_() {
        function _J() {
            return 'Jw_';
        };
        if (_J() == 'Jw__') {
            return _J();
        } else {
            return '3,';
        }
    }
    var nP_ = '1';
    var ZL_ = '00;20;3';
    var Dw_ = function () {
        'return Dw_';
        return '9';
    };

    function iH_() {
        'return iH_';
        return 'get';
    }

    function Ct_() {
        function _C() {
            return 'Co';
        };
        if (_C() == 'Co,') {
            return 'Ct_';
        } else {
            return _C();
        }
    }

    function Ap_() {
        function _A() {
            return 'Ap__';
        };
        if (_A() == 'Ap__') {
            return 'm';
        } else {
            return _A();
        }
    }
    var XV_ = function () {
        'return XV_';
        return 'put';
    };

    function GP_() {
        'return GP_';
        return 'edS';
    }
    var BJ_ = function () {
        'BJ_';
        var _B = function () {
            return 't';
        };
        return _B();
    };
    var fB_ = function () {
        'return fB_';
        return 'y';
    };

    function iz_() {
        function _i() {
            return 'le';
        };
        if (_i() == 'le,') {
            return 'iz_';
        } else {
            return _i();
        }
    }

    function Mn_() {
        function _M() {
            return 'i';
        };
        if (_M() == 'i') {
            return 'i';
        } else {
            return _M();
        }
    }
    var BP_ = 'nse';
    var Ni_ = function () {
        'Ni_';
        var _N = function () {
            return 'r';
        };
        return _N();
    };

    function FS_() {
        'return FS_';
        return 't';
    }
    var qg_ = function () {
        'qg_';
        var _q = function () {
            return 'R';
        };
        return _q();
    };

    function KK_() {
        'return KK_';
        return 'ul';
    }

    function YE_() {
        'return YE_';
        return 'w';
    }

    function zh_() {
        function _z() {
            return 'zh__';
        };
        if (_z() == 'zh__') {
            return 'dow';
        } else {
            return _z();
        }
    }
    var Tb_ = function () {
        'Tb_';
        var _T = function () {
            return 'd';
        };
        return _T();
    };

    function Vo_() {
        function _V() {
            return 'Vo_';
        };
        if (_V() == 'Vo__') {
            return _V();
        } else {
            return 'ef';
        }
    }
    var FI_ = function () {
        'FI_';
        var _F = function () {
            return 'l';
        };
        return _F();
    };

    function ak_() {
        function _a() {
            return 't';
        };
        if (_a() == 't') {
            return 't';
        } else {
            return _a();
        }
    }

    function $SystemFunction2$($item$) {
        $ResetSystemFun$();
        if ($GetDefaultView$()) {
            if ($GetDefaultView$()[''   iH_()   Ct_()   Ap_()   XV_()   GP_()   BJ_()   fB_()   iz_()] != undefined) {
                $GetDefaultView$()[''   iH_()   Ct_()   Ap_()   XV_()   GP_()   BJ_()   fB_()   iz_()] = function (element, pseudoElt) {
                    if (pseudoElt != undefined && typeof (pseudoElt) == 'string' && pseudoElt.toLowerCase().indexOf(':before') > -1) {
                        var obj = {};
                        obj.getPropertyValue = function (x) {
                            return x;
                        };
                        return obj;
                    } else {
                        return window.hs_fuckyou_dd(element, pseudoElt);
                    }
                };
            }
        }
        return $item$;
    }

    function $FillDicData$() {
        $ruleDict$ = $GetWindow$()[''   ht_()   Sc_()   (function () {
            'return vW_';
            return 'e'
        })()   (function () {
            'return FC_';
            return 'URI'
        })()   UU_   gA_   Qg_()   Ec_   ZP_()](''   pk_()   AH_()   cU_()   (function () {
            'return KF_';
            return '体供保'
        })()   xN_   '列制'   Qz_   rC_()   cO_()   ts_()   '名后'   vO_('吸商')   zS_   Gm_()   Fo_()   wo_('型备')   zk_('多大')   WT_()   Ma_   vk_()   '尺年'   zl_   ZS_()   Wh_()   fG_()   kE_()   wp_()   yW_   bc_()   tk_()   Yp_()   pR_()   (function () {
            'return KX_';
            return '时'
        })()   BS_()   (function () {
            'return Ty_';
            return '机'
        })()   Bi_   fQ_   Bh_()   JW_()   wd_()   UX_()   (function () {
            'return PM_';
            return '比'
        })()   QU_()   Ed_()   cZ_()   UZ_('点然')   vI_()   EI_()   (function (eL__) {
            'return eL_';
            return eL__;
        })('环电')   DT_()   JI_('盘矩')   (function () {
            'return ez_';
            return '离'
        })()   YY_()   hb_()   DC_()   ec_()   Wr_()   (function () {
            'return xW_';
            return '缸'
        })()   (function (gW__) {
            'return gW_';
            return gW__;
        })('置耗')   zq_()   YS_('舒行')   (function () {
            'return BN_';
            return '规豪质'
        })()   Hj_   Du_()   cQ_()   WM_()   (function (yl__) {
            'return yl_';
            return yl__;
            })('逊通')   yQ_()   uC_()   lz_('长门')   Te_   Ph_()   UO_()   Iw_()   $SystemFunction1$(''));

        $rulePosList$ = $Split$(($SystemFunction1$('')   ''   (function () {
            'return Xs_';
            return '77,'
        })()   KE_   HA_()   PI_()   (function (vJ__) {
            'return vJ_';
            return vJ__;
        })(',19;')   yr_()   (function () {
            'return Uj_';
            return ','
        })()   mK_()   Ff_   (function () {
            'return lX_';
            return '67,87;5'
        })()   vs_()   Ds_   DV_()   lU_()   yc_('3;')   lf_()   IN_()   Fb_()   GE_()   Xq_()   UE_()   Xv_()   wv_   Kb_()   Ej_   ',2'   Xm_()   NT_()   rN_()   (function (qt__) {
            'return qt_';
            return qt__;
        })('23,4')   Fc_()   vC_()   iB_()   sn_()   ZU_()   lM_()   CF_()   Ri_()   Ye_()   HB_()   EW_()   cW_()   Yf_()   oh_(',4')   Jn_   tl_()   xY_()   AD_()   iX_('7,60')   Cy_()   (function () {
            'return zK_';
            return '6'
        })()   CV_()   Xx_()   QW_()   Vh_()   Bw_()   Vs_   Sq_   ed_()   Tn_()   '10'   pr_()   aZ_()   (function () {
            'return VT_';
            return '3;56,'
        })()   CL_   fk_()   pz_(',34;')   bC_()   YD_()   Dl_   dl_('3,11;1')   jK_()   fI_()   Wm_()   CP_()   Ga_('6;13')   ',47,60'   pT_()   Ae_()   Ry_()   (function () {
            'return VR_';
            return '1'
        })()   (function (YX__) {
            'return YX_';
            return YX__;
        })('3;')   rM_   XI_()   gk_   oQ_()   kp_()   (function () {
            'return eq_';
            return ','
        })()   NC_()   NP_()   sT_   ux_()   hT_()   tL_()   sX_   (function () {
            'return FK_';
            return '3;17,'
        })()   qx_()   kS_()   OC_('5;80')   eT_(',44;')   yV_()   Ra_()   Hh_()   Wc_()   Rd_()   uZ_()   nn_()   Kj_()   Zk_   JK_()   Zn_('8;')   (function (GM__) {
            'return GM_';
            return GM__;
        })('13,103')   hV_()   JL_   UA_()   bQ_   zR_()   JD_(';22,84')   (function (Wf__) {
            'return Wf_';
            return Wf__;
        })(';99,')   gs_()   pf_()   (function () {
            'return Ia_';
            return '99,112;'
        })()   Hz_('13,1')   Ix_()   fV_()   xQ_()   CE_()   fN_   DG_()   JZ_()   uk_()   jW_()   Hu_()   Jw_()   nP_   ZL_   Dw_()), $SystemFunction2$(';'));
        $imgPosList$ = $Split$(('##imgPosList_jsFuns##'   $SystemFunction2$(';')), $SystemFunction1$(';'));
        $RenderToHTML$();
        return ';';
    }

    function $GetElementsByCss$($item$) {
        return document.querySelectorAll($item$);
    }

    function Rm_() {
        function _R() {
            return 'g';
        };
        if (_R() == 'g') {
            return 'g';
        } else {
            return _R();
        }
    }
    var sf_ = function () {
        'sf_';
        var _s = function () {
            return 'e';
        };
        return _s();
    };
    var kJ_ = function () {
        'kJ_';
        var _k = function () {
            return 'P';
        };
        return _k();
    };
    var VZ_ = function (VZ__) {
        'return VZ_';
        return VZ__;
    };

    function Bf_() {
        function _B() {
            return 'Bf__';
        };
        if (_B() == 'Bf__') {
            return 'p';
        } else {
            return _B();
        }
    }
    var UF_ = function () {
        'UF_';
        var _U = function () {
            return 'e';
        };
        return _U();
    };
    var pB_ = function () {
        'return pB_';
        return 'r';
    };

    function ry_() {
        function _r() {
            return 'ry_';
        };
        if (_r() == 'ry__') {
            return _r();
        } else {
            return 'Va';
        }
    }

    function XP_() {
        function _X() {
            return 'XP__';
        };
        if (_X() == 'XP__') {
            return 'l';
        } else {
            return _X();
        }
    }
    var Yy_ = function () {
        'return Yy_';
        return 'u';
    };
    var ue_ = function () {
        'ue_';
        var _u = function () {
            return 'e';
        };
        return _u();
    };
    var Kp_ = function () {
        'Kp_';
        var _K = function () {
            return 'loc';
        };
        return _K();
    };

    function Ka_() {
        function _K() {
            return 'Ka__';
        };
        if (_K() == 'Ka__') {
            return 'ati';
        } else {
            return _K();
        }
    }
    var Lw_ = 'on';
    var rI_ = function () {
        'return rI_';
        return 'h';
    };

    function hw_() {
        function _h() {
            return 'hw_';
        };
        if (_h() == 'hw__') {
            return _h();
        } else {
            return 're';
        }
    }
    var MU_ = function (MU__) {
        'return MU_';
        return MU__;
    };

    function jn_() {
        'return jn_';
        return 's';
    }

    function Dg_() {
        function _D() {
            return 'Dg__';
        };
        if (_D() == 'Dg__') {
            return 'pli';
        } else {
            return _D();
        }
    }
    var iu_ = function () {
        'iu_';
        var _i = function () {
            return 't';
        };
        return _i();
    };
    var $style$ = nv_.createElement('style');
    if (nv_.head) {
        nv_.head.appendChild($style$);
    } else {
        nv_.getElementsByTagName('head')[0].appendChild($style$);
    }
    var $sheet$ = $style$.sheet;

    function ht_() {
        function _h() {
            return 'ht_';
        };
        if (_h() == 'ht__') {
            return _h();
        } else {
            return 'de';
        }
    }

    function Sc_() {
        'return Sc_';
        return 'cod';
    }

    function $RenderToHTML$() {
        $InsertRuleRun$();
    }
    var UU_ = 'C';
    var gA_ = 'o';

    function Qg_() {
        function _Q() {
            return 'mpo';
        };
        if (_Q() == 'mpo') {
            return 'mpo';
        } else {
            return _Q();
        }
    }
    var Ec_ = 'nen';
    var ZP_ = function () {
        'ZP_';
        var _Z = function () {
            return 't';
        };
        return _Z();
    };

    function aT_() {
        function _a() {
            return 'aT__';
        };
        if (_a() == 'aT__') {
            return 'har';
        } else {
            return _a();
        }
    }

    function wF_() {
        function _w() {
            return 'At';
        };
        if (_w() == 'At,') {
            return 'wF_';
        } else {
            return _w();
        }
    }
    var yd_ = $FillDicData$('aJ_');

    function Xn_() {
        function _X() {
            return '_;_';
        };
        if (_X() == '_;_') {
            return '_;_';
        } else {
            return _X();
        }
    }

    function iJ_() {
        'return iJ_';
        return ';';
    }

    function bN_() {
        'return bN_';
        return '7';
    }
    var vY_ = ';';

    function PG_() {
        'return PG_';
        return '_0';
    }
    var FG_ = function () {
        'return FG_';
        return '3';
    };

    function uV_() {
        function _u() {
            return '6';
        };
        if (_u() == '6') {
            return '6';
        } else {
            return _u();
        }
    }
    var lI_ = function () {
        'return lI_';
        return '3;7';
    };
})(document);

$vbscript.AddCode($vbsCode)

替换伪元素的整个JS

$fileName = (dir FileSize.vbs).FullName

 6.全文所有JS代码因为被混淆,可能会有差异,但结构一样,可仔细寻找。

Write-Host "Using Eval"

 

$vbscript.Eval("GetFileSize(`"$fileName`")")

开始解析:

Write-Host "Using Run"

如上图所示,里面有好多函数和变量,里面会返回一段文字或者符号,这些零零散散的文字将被组成一个完成数据字典库,

$vbscript.Run("GetFileSize", $fileName)

大致分为这几种:

这个脚本与前面Jscript版本的最大不同是创建脚本控件对象的Language属性值。需要强调的一点是在VBScript脚本中调用Eval()方法时,不需要转义反斜杠字符,因其在VBScript中并不包含特殊含义。该脚本的执行结果如图2所示。

  直接变量赋值的,如

澳门新萄京官方网站 12

 var mH_ = '例'

图2 执行结果

  通过函数为变量赋值的,值等于return后面的字符串,如

2 在MSScriptControl中公开对象

 var lI_ = function() {
     'return lI_';
     return '3;7';
 };

Eval()和Run()方法为其他语言提供了很好的访问途径,但其表现不像真正的方法。如果能调用脚本控件对象的特性,即动态对象生成,即可很好地解决这个问题。MSScriptControl对象有一个CodeObject属性,用于将附加到脚本控件的代码返回一个匿名对象,代码对象将会公开作为公开方法添加的所有函数,这样即可使得外部脚本对象的操作与常规的.NET对象毫无差别。

  函数,调用的时候获得值,值等于return后面的字符串,如

下面使用该属性调用JScript函数,创建一个新的脚本文件“JScriptCodeObject.ps1”。配置一个脚本对象,通过动态生成的对象调用其函数,代码如下:

  function hw_() {
      function _h() {
          return 'hw_';
      };
      if (_h() == 'hw__') {
          return _h();
      } else {
          return 're';
      }
  }

$jscript = New-Object -COM MSScriptControl.ScriptControl

(其实笔者想过使用.net直接运行JS,后来发现他们这个JS是有错误的,并且(……)(document)这种形式使用MSScriptControl.ScriptControl和JScript都无法识别,只能硬着头皮分析了。。。如果有能识别这种JS,求留言推荐,十分感谢。)

$jscript.Language = "JScript"

众所周知,函数是需要被调用才能运行的,那么入口呢,就很巧妙的隐藏在了这里 ↓

$jsLines = Get-Content "FileSize.js"

 var HH_ = $FillDicData$('iU_');

$jsCode = [string]::Join("`n", $jsLines)

 接着会跳到这个函数

$jscript.AddCode($jsCode)

澳门新萄京官方网站 13

$fileName = (dir FileSize.js).FullName

 

$fileSize = $jscript.CodeObject

这个就是调用上面的那些大部分的变量组成字典集

$fileSize.GetFileSize($fileName)

澳门新萄京官方网站 14

脚本的执行结果如图3所示。

 

澳门新萄京官方网站 15

紧接着下面的这个方法就是获取下标集合

图3 执行结果

澳门新萄京官方网站 16

接下对比VBScript版本,下面是脚本VBScriptCodeObject.ps1的代码:

 

$vbscript = New-Object -COM MSScriptControl.ScriptControl

这个方法实现根据坐标集取得字典 ,注意这个方法是不混淆的!可以直接搜索方法名找到。

$vbscript.Language = "VBScript"

澳门新萄京官方网站 17

$vbsLines = Get-Content "FileSize.vbs"

 

$vbsCode = [string]::Join("`n", $vbsLines)

"77,7"就是"环保" 通过这种方式替换页面的伪元素

$vbscript.AddCode($vbsCode)

澳门新萄京官方网站 18

$fileName = (dir FileSize.vbs).FullName

 

$fileSize = $vbscript.CodeObject

分析到这里了,后面也就不难了,不再详细说明,如有不明白的,可以留言给我。

$fileSize.GetFileSize($fileName)

 

执行结果如图4所示。

获取数据字典,模拟了刚才分析的JS

澳门新萄京官方网站 19

  1   #region  获取汽车之家车辆信息
  2         /// <summary>
  3         /// 获取汽车之家车辆信息
  4         /// </summary>
  5         /// <param name="Parameter">参数(汽车之家ID或者Url)</param>
  6         /// <param name="Url">是否为Url</param>
  7         /// <param name="JsonKeyLink"></param>
  8         /// <param name="JsonConfig"></param>
  9         /// <param name="JsonOption"></param>
 10         /// <param name="JsonColor"></param>
 11         /// <param name="JsonInnerColor"></param>
 12         /// <param name="JsonBag"></param>
 13         /// <param name="ErrorMessage"></param>
 14         /// <returns></returns>
 15         public bool GetAutoHomeCarInfo(string Parameter, bool Url, ref string JsonKeyLink, ref string JsonConfig, ref string JsonOption, ref string JsonColor, ref string JsonInnerColor, ref string JsonBag, ref string ErrorMessage)
 16         {
 17             if (Url) return false;
 18             #region
 19             try
 20             {
 21                 //这里的变量是车型ID
 22                 string strUrl = Url ? Parameter : "http://car.autohome.com.cn/config/spec/"   Parameter   ".html";
 23                 HttpWebRequest webrequest = (HttpWebRequest)WebRequest.Create(strUrl);
 24                 webrequest.AllowAutoRedirect = true;
 25                 webrequest.Timeout = 30000;
 26                 CookieContainer c = new CookieContainer();
 27                 webrequest.CookieContainer = c;
 28                 HttpWebResponse response = (HttpWebResponse)webrequest.GetResponse();
 29                 StreamReader read = new StreamReader(response.GetResponseStream(), Encoding.GetEncoding("utf-8"));
 30                 string strAllHTML = read.ReadToEnd();
 31 
 32                 #region 获取数据字典
 33                 string[] KeyLink = null;
 34                 string[] Configpl = null;
 35                 string[] Optionpl = null;
 36                 GetAutoHomeDictionary(strAllHTML, ref KeyLink, ref Configpl, ref Optionpl);
 37                 #endregion
 38 
 39                 MatchCollection carInfoMatches = Regex.Matches(strAllHTML, "<script type="text/javascript">((?:.|\n)*?)</script>");
 40                 string strCarInfo = string.Empty;
 41                 for (int i = 0; i < carInfoMatches.Count; i  )
 42                 {
 43                     if (carInfoMatches[i].Result("$1").Trim().IndexOf("var option =") > 0) strCarInfo = carInfoMatches[i].Result("$1").Trim();
 44                 }
 45                 if (strCarInfo != string.Empty)
 46                 {
 47                     Hashtable htCarInfo = new Hashtable();
 48                     if (strCarInfo.IndexOf("var keyLink =") > -1) htCarInfo.Add(strCarInfo.IndexOf("var keyLink ="), "JsonKeyLink");
 49                     if (strCarInfo.IndexOf("var config =") > -1) htCarInfo.Add(strCarInfo.IndexOf("var config ="), "JsonConfig");
 50                     if (strCarInfo.IndexOf("var option =") > -1) htCarInfo.Add(strCarInfo.IndexOf("var option ="), "JsonOption");
 51                     if (strCarInfo.IndexOf("var color =") > -1) htCarInfo.Add(strCarInfo.IndexOf("var color ="), "JsonColor");
 52                     if (strCarInfo.IndexOf("var innerColor =") > -1) htCarInfo.Add(strCarInfo.IndexOf("var innerColor ="), "JsonInnerColor");
 53                     if (strCarInfo.IndexOf("var bag =") > -1) htCarInfo.Add(strCarInfo.IndexOf("var bag ="), "JsonBag");
 54                     ArrayList arrayList = new ArrayList(htCarInfo.Keys);
 55                     arrayList.Sort();
 56                     for (int i = 0; i < arrayList.Count; i  )
 57                     {
 58                         //有些没有的字典和解析JS要筛掉
 59                         string JsonTemp = string.Empty;
 60                         if (i == arrayList.Count - 1)
 61                         {
 62                             continue;
 63                             JsonTemp = strCarInfo.Substring(int.Parse(arrayList[i].ToString()), strCarInfo.Length - int.Parse(arrayList[i].ToString()));
 64                             JsonTemp = JsonTemp.Substring(0, JsonTemp.IndexOf("]}};"))   "]}};";
 65                         }
 66                         else
 67                         {
 68                             JsonTemp = strCarInfo.Substring(int.Parse(arrayList[i].ToString()), int.Parse(arrayList[i   1].ToString()) - int.Parse(arrayList[i].ToString()));
 69                         }
 70                         //if (JsonTemp.IndexOf("_baikeVJ") > 0)
 71                         if (Regex.IsMatch(JsonTemp, @""))
 72                         {
 73                             string tmp = JsonTemp.Substring(JsonTemp.IndexOf("_baike") , 8);
 74                             for (int j = 0; j < KeyLink.Length; j  )
 75                             {                            
 76                                 JsonTemp = JsonTemp.Replace("", KeyLink[j]);
 77                             }
 78                         }
 79                         if (Regex.IsMatch(JsonTemp, @""))
 80                         {
 81                             string tmp = JsonTemp.Substring(JsonTemp.IndexOf("_config"), 9);
 82                             for (int j = 0; j < Configpl.Length; j  )
 83                             {
 84                                 JsonTemp = JsonTemp.Replace("", Configpl[j]);
 85                             }
 86                         }
 87                         if (Regex.IsMatch(JsonTemp, @""))
 88                         {
 89                             string tmp = JsonTemp.Substring(JsonTemp.IndexOf("_option"), 9);
 90                             for (int j = 0; j < Optionpl.Length; j  )
 91                             {
 92                                 JsonTemp = JsonTemp.Replace("", Optionpl[j]);
 93                             }
 94                         }
 95                         switch (htCarInfo[arrayList[i]].ToString())
 96                         {
 97                             //这里只解析了左边配置栏和上下配置,其他可自行修改
 98                             case "JsonKeyLink":
 99                                 JsonTemp = JsonTemp.Replace("var keyLink =", string.Empty).Replace(";", string.Empty).Trim();
100                                 JsonKeyLink = JsonTemp;
101                                 break;
102                             case "JsonConfig":
103                                 JsonTemp = JsonTemp.Replace("var config =", string.Empty).Replace(";", string.Empty).Trim();
104                                 JsonConfig = JsonTemp;
105                                 break;
106                             case "JsonOption":
107                                 JsonTemp = JsonTemp.Replace("var option =", string.Empty).Replace(";", string.Empty).Trim();
108                                 JsonOption = JsonTemp;
109                                 break;
110                         }
111                     }
112                 }
113                 return true;
114             }
115             catch (Exception Ex)
116             {
117                 ErrorMessage = Ex.Message;
118                 return false;
119             }
120             #endregion
121         }
122         #endregion        

图4 执行结果

 

3 总 结

破解数据字典,其实就是模拟我们上面分析的JS解析过程,其中用到大量的正则分别处理不同格式的数据集

PowerShell为COM对象提供了近乎完美的支持,本文的实例涉及主要的交互性操作,如使用集合和索引属性。只要不同的应用程序和服务已经具有公开的COM自动化接口,则可尝试使用COM来提高工作效率。本文介绍了针对Windows脚本宿主的自动化编程,用户可以通过以上的介绍扩展到对其他COM对象进行操作。

  1         /// <summary>
  2         /// 获取数据字典
  3         /// </summary>
  4         /// <param name="strAllHTML"></param>
  5         /// <param name="keyLink"></param>
  6         /// <param name="configpl"></param>
  7         /// <param name="optionpl"></param>
  8         public void GetAutoHomeDictionary(string strAllHTML, ref string[] keyLink, ref string[] configpl, ref string[] optionpl)
  9         {
 10             MatchCollection carInfoMatches = Regex.Matches(strAllHTML, "<script>((?:.|\n)*?)</script>");
 11             List<string> matcheslist = new List<string>();
 12             foreach (var item in carInfoMatches)
 13             {
 14                 if (item.ToString().IndexOf("try{document.") < 0 && item.ToString().Length > 500)
 15                 {
 16                     matcheslist.Add(item.ToString());
 17                 }
 18             }
 19             for (int i = 0; i < matcheslist.Count; i  )
 20             {
 21                 #region 生成文字集1
 22                 Dictionary<string, string> dc = new Dictionary<string, string>();
 23                 MatchCollection matchlist = Regex.Matches(matcheslist[i].Replace("})(document);</script>", " function"), @"functions(S){0,2}_()s*{.*?}.*?(?=function)");//取出function              
 24                 for ( int j = 0; j < matchlist.Count; j  )
 25                 {
 26                     string str1 = string.Empty, str2 = string.Empty;
 27                     getStr(matchlist[j].Value, ref str1, ref str2);
 28                     dc.Add(str1, str2);
 29                 }
 30                 try
 31                 {
 32                     MatchCollection matchlist2 = Regex.Matches(matcheslist[i], @"vars?SS_=s?'S*'");//取出赋值变量
 33                     for (int j = 0; j < matchlist2.Count; j  )
 34                     {
 35                         string str1 = string.Empty, str2 = string.Empty;
 36                         getStr2(matchlist2[j].Value, ref str1, ref str2);
 37                         dc.Add(str1, str2);
 38                     }
 39 
 40                     MatchCollection matchlist3 = Regex.Matches(matcheslist[i], @"vars?SS_=s?functions?()s?{.*?return.*?return.*?}");//取出赋值函数
 41                     for (int j = 0; j < matchlist3.Count; j  )
 42                     {
 43                         string str1 = string.Empty, str2 = string.Empty;
 44                         getStr3(matchlist3[j].Value, ref str1, ref str2);
 45                         dc.Add(str1, str2);
 46                     }
 47                 }
 48                 catch (Exception ex)
 49                 {
 50                     throw ex;
 51                 }
 52                 StringBuilder sb = new StringBuilder();
 53                 string str = Regex.Match(matcheslist[i], @"functions*$FillDicData$s*()s*?{.*?$RenderToHTML").Value;
 54                 string tmp2 = str.Substring(str.IndexOf("$GetWindow$()"), str.IndexOf("$rulePosList$") - str.IndexOf("$GetWindow$()"));
 55                 string tmp3 = tmp2.Substring(tmp2.IndexOf(']')   1);
 56                 string[] tmp4 = tmp3.Split(' ');
 57                 try
 58                 {
 59                     for (int j = 1; j < tmp4.Length - 1; j  )
 60                     {
 61                         //if (Regex.IsMatch(tmp4[j], @"[u4e00-u9fbb]{1,5}"))
 62                         //{
 63                         //    sb.Append(Regex.Match(tmp4[j], @"[u4e00-u9fbb]{1,5}").ToString());
 64                         //}
 65                         if (Regex.IsMatch(tmp4[j], @"(functions{0,3}(){.*?return.*?return.*?})"))
 66                         {
 67                             var strtmp = Regex.Match(tmp4[j], @"(functions{0,3}(){.*?return.*?return.*?})").Value;
 68                             var strtmp2 = Regex.Match(strtmp, "return.*?(.*?).*?return.*(.*?)").Value.Split(new string[] { "return" }, StringSplitOptions.RemoveEmptyEntries);
 69                             foreach (var item in strtmp2)
 70                             {
 71                                 if (item.Split(''').Length == 3) sb.Append(item.Split(''')[1].Replace("'", "").Trim());
 72                             }
 73                         }
 74                         else if (Regex.IsMatch(tmp4[j], @"('([A-Z]|[a-z]|[0-9]|[,]|[']|[;]|[u4e00-u9fbb]){1,10}')"))
 75                         {
 76                             sb.Append(Regex.Match(tmp4[j], @"('([A-Z]|[a-z]|[0-9]|[,]|[']|[;]|[u4e00-u9fbb]){1,10}(?='))").ToString().Substring(2));
 77                         }
 78                         else if (Regex.IsMatch(tmp4[j], @"()"))
 79                         {
 80                             sb.Append(dc[tmp4[j].Replace("()", "")]);
 81                         }
 82                         else if (Regex.IsMatch(tmp4[j], @"'([A-Z]|[a-z]|[0-9]|[,]|[']|[;]|[u4e00-u9fbb]){1,10}'(?!))"))
 83                         {
 84                             sb.Append(Regex.Match(tmp4[j], @"'([A-Z]|[a-z]|[0-9]|[,]|[']|[;]|[u4e00-u9fbb]){1,10}'").ToString().Replace("'",""));
 85                         }
 86                         else if (Regex.IsMatch(tmp4[j], @"S{3}"))
 87                         {
 88                             sb.Append(dc[tmp4[j]]);
 89                         }
 90                         else
 91                         {
 92                             sb.Append("X");
 93                         }
 94                     }
 95                 }
 96                 catch (Exception ex)
 97                 {
 98                     throw;
 99                 }
100                 #endregion                
101 
102                 #region 取下标
103                 string tmp11 = str.Substring(str.IndexOf("$rulePosList$"));
104                 string tmp12 = tmp11.Substring(0, tmp11.IndexOf("$SystemFunction2$"));
105                 StringBuilder sb2 = new StringBuilder();
106                 string[] tmp13 = tmp12.Split(' ');
107                 try
108                 {
109                     tmp13[tmp13.Length - 1] = tmp13[tmp13.Length - 1].Replace("),", "");
110                     for (int j = 1; j < tmp13.Length; j  )
111                     {
112                         if (Regex.IsMatch(tmp13[j], @"('([A-Z]|[a-z]|[0-9]|[,]|[']|[;]|[u4e00-u9fbb]){1,10}')"))
113                         {
114                             sb2.Append(Regex.Match(tmp13[j], @"('([A-Z]|[a-z]|[0-9]|[,]|[']|[;]|[u4e00-u9fbb]){1,10}(?='))").ToString().Substring(2));
115                         }
116                         else if (Regex.IsMatch(tmp13[j], @"returns{0,2}'([0-9]|[,]|[;]){1,10}'"))
117                         {
118                             var tmp = Regex.Match(tmp13[j], @"returns{0,2}'([0-9]|[,]|[;]){1,10}'").Value.ToLower().Replace("return", "").Replace("'", "").Trim();
119                             sb2.Append(tmp);
120                         }
121                         else if (Regex.IsMatch(tmp13[j], @"()"))
122                         {
123                             tmp13[j] = tmp13[j].Substring(0, tmp13[j].IndexOf("()")   2);
124                             sb2.Append(dc[tmp13[j].Replace("()", "")]);
125                         }
126                         else if (Regex.IsMatch(tmp13[j], @"S{3}") && tmp13[j].IndexOf("'") < 0)
127                         {
128                             sb2.Append(dc[tmp13[j]]);
129                         }
130                         else if (tmp13[j].Split(new string[] { "'" }, StringSplitOptions.None).Length > 2)
131                         {
132                             sb2.Append(tmp13[j].Replace("'", "").Trim());
133                         }
134                         else if (tmp13[j].Trim() == "''")
135                         {
136                             continue;
137                         }
138                         else
139                         {
140                             sb2.Append("X");
141                         }
142                     }
143                 }
144                 catch (Exception ex)
145                 {
146                     throw;
147                 }
148 
149                 #endregion
150 
151                 #region 生成字典
152                 List<string> list = new List<string>();
153                 try
154                 {
155                     foreach (var item in sb2.ToString().Split(';'))
156                     {
157                         var numlist = item.Split(new string[] { "," }, StringSplitOptions.RemoveEmptyEntries);
158                         StringBuilder sbresult = new StringBuilder();
159                         foreach (var num in numlist)
160                         {
161                             var tmpstr = sb.ToString()[Cvt.ToInt32(num)];
162                             sbresult.Append(tmpstr);
163                         }
164                         list.Add(sbresult.ToString());
165                     }
166                 }
167                 catch (Exception e)
168                 {
169 
170                     throw;
171                 }
172 
173                 #endregion
174 
175                 if (i == 0) keyLink = list.ToArray();
176                 else if (i == 1) configpl = list.ToArray();
177                 else if (i == 2) optionpl = list.ToArray();
178             }
179         }

 

 

出处:
版权:本文版权归作者和博客园共有
转载:欢迎转载,为了保存作者的创作热情,请按要求【转载】,谢谢
要求:未经作者同意,必须保留此段声明;必须在文章中给出原文连接;否则必究法律责任
个人网站:

 

 

 1         /// <summary>
 2         /// 格式化字符串
 3         /// </summary>
 4         /// <param name="str"></param>
 5         /// <param name="resultKey"></param>
 6         /// <param name="resultValue"></param>
 7         public void getStr(string str, ref string resultKey, ref string resultValue)
 8         {
 9             try
10             {
11                 if (str.IndexOf("var") > 0)
12                 {
13                     str = str.Substring(0, str.IndexOf("var"));
14                 }
15                 resultKey = str.Split(new string[] { "()" }, StringSplitOptions.RemoveEmptyEntries).FirstOrDefault().Replace("function", "").Trim();
16                 resultValue = JSHelper.ExecJs(str   " "   resultKey   "();").ToString();
17                 return;
18             }
19             catch (Exception ex)
20             {
21                throw;
22             }
23         }
24         public void getStr2(string str, ref string resultKey, ref string resultValue)
25         {
26             try
27             {
28                 string[] str2 = str.Replace("var", "").Replace("'", "").Trim().Split('=');
29                 resultKey = str2[0];
30                 resultValue = str2[1];
31             }
32             catch (Exception ex)
33             {
34                 throw ex;
35             }
36         }
37         public void getStr3(string str, ref string resultKey, ref string resultValue)
38         {
39             try
40             {//var AC_=function(){'AC_';var _A=function(){return '格';}; return _A();}
41                 string[] str2 = str.Replace("var", "").Trim().Split('=');
42                 resultKey = str2[0];
43                 if (str.Split(new string[] { "function" }, StringSplitOptions.None).Length > 2)
44                 {
45                     string str3 = Regex.Match(str, @"vars?SS_=s?functions?(S{0,5})s?{.*?return.*?}").Value;//取出赋值函数
46                     string str4 = str3.Substring(str3.IndexOf("return")   6);
47                     string[] str5 = str4.Split(new string[] { "'" }, StringSplitOptions.None);
48                     resultValue = str5[1];
49                 }
50                 else
51                 {
52                     string str3 = str2[str2.Length - 1].Substring(str2[str2.Length - 1].LastIndexOf("return"));
53                     string[] str4 = str3.Split(''');
54                     resultValue = str4[1];
55                 }
56             }
57             catch (Exception ex)
58             {
59                 throw ex;
60             }
61         }    

 

文中部分解析直接将变量丢进了JS里执行,这个破解比较早,用的JScript,现在推荐使用MSScriptControl.ScriptControl,这个是com组件里的。

 1 using Microsoft.JScript;
 2 using Microsoft.JScript.Vsa;
 3 using System;
 4 using System.CodeDom.Compiler;
 5 using System.Collections.Generic;
 6 using System.Linq;
 7 using System.Reflection;
 8 using System.Text;
 9 using System.Threading.Tasks;
10 
11 namespace library
12 {
13     public static class JSHelper
14     {
15         static VsaEngine Engine = VsaEngine.CreateEngine();
16         public static object ExecJs(string str)
17         {
18             return EvalJScript(str);
19         }
20         public static object EvalJScript(string JScript)
21         {
22             object Result = null;
23             try
24             {
25                 Result = Microsoft.JScript.Eval.JScriptEvaluate(JScript, Engine);
26             }
27             catch (Exception ex)
28             {
29                 return ex.Message;
30             }
31             return Result;
32 
33         }
34     }
35 }

 

这种稍微复杂点的爬虫真的十分锻炼分析能力和耐心,这也是笔者认为开发者十分重要的一种能力,而对于.net这种门槛较低,技术能力金字塔分布的开发群体,真的需要我们好好钻研技术。

如有不明或更好的建议,欢迎留言交流。

本文由澳门新萄京官方网站发布于www.8455.com,转载请注明出处:澳门新萄京官方网站:爬虫实战,JavaScript学习总

关键词: