javascript 正则提取页面中的变量值

更新日期: 2019-07-07 阅读次数: 1769 字数: 312 分类: Javascript

有的网页为了防止 tampermonkey 这类插件读取页面中的 js 变量,把变量写到了匿名自调用函数 self-invocation 中,例如

<script type="text/javascript">
(function() {
  var a = 1;
  console.log(a);
})();
</script>

而我为了某些不可告人的目的必须读取到变量 a 的值。

一种有效的方式是,使用 ajax 获取当前页面的源代码,然后正则匹配中某个指定变量的值。

正则匹配

var s = 'var name = "hahahaha"';
var s = 'var name = "hahahaha";';

s.match(/var \w+ = (.+);/);
0: "var name = "hahahaha";"
1: ""hahahaha""

var s = 'var name = "hahahaha"; var age = 10;';
s.match(/var \w+ = (.+);/);
0: "var name = "hahahaha"; var age = 10;"
1: ""hahahaha"; var age = 10"

// 避免贪婪匹配
s.match(/var \w+ = (.+?);/);
0: "var name = "hahahaha";"
1: ""hahahaha""

s.match(/var age = (.+?);/);
0: "var age = 10;"
1: "10"

避免贪婪匹配

*  - zero or more
*? - zero or more (non-greedy)
+  - one or more
+? - one or more (non-greedy)
?  - zero or one
?? - zero or one (non-greedy)

漏洞

使用分号 “;” 来判断一个变量的结束,实际上是不严谨的。

举个例子,如果一个变量的内容是一个字符串,字符串中包含分号,那这个一定会出错。

爱评论不评论

近期节日

2019年07月23日 大暑
2019年07月30日 非洲妇女日
2019年08月01日 八一建军节
2019年08月06日 国际电影节
2019年08月07日 七夕
2019年08月08日 立秋
2019年08月15日 日本投降日
2019年08月15日 中元节
2019年08月23日 处暑
2019年09月03日 抗日胜利纪念日
2019年09月08日 白露
2019年09月08日 国际扫盲日
查看更多节日