首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

JS代码混淆

AST 在线解析 AST explorer js 在线混淆工具 JavaScript Obfuscator Tool 书籍 《反爬虫 AST 原理与还原混淆实战》 相关混淆代码 kuizuo/js-de-obfuscator...js 代码中混淆与还原的对抗,而所使用的技术便是 AST,通过 AST 能很轻松的将 js代码混淆成难以辨别的代码。...(后文代码将会省略模块引入、js 代码读取、解析与生成的代码) const fs = require('fs') const parser = require('@babel/parser') const...parser 与 generator​ 前者用于将 js 代码解析成 AST,后者则是将 AST 转为 js 代码,两者的具体参数可通过 babel 手册查看,这就不做过多介绍了。...个人推荐这种写法,因为能有 js代码提示,如果是 TypeScript 效果也一样。

21.9K10

JS代码还原

基于 Babel 对 JS 代码进行混淆与还原操作的网站 JS 代码混淆与还原 (kuizuo.cn) 还原前言​ AST 仅仅只是静态分析,但可以将还原出来的代码替换原来的代码,以便更好的动态分析找出相关点...在还原时,并不是所有的代码都能还原成一眼就识破代码执行逻辑的,ast 也并非万能,如果你拥有强大的 js 逆向能力,有时候动态调试甚至比 AST 静态分析来的事半功倍。...还原也不是万能的​ 混淆的方式有很多,与对应还原的方式也有很多,上面那套混淆的还原可能只针对那一套混淆的代码,如果拿另一份混淆过的代码,然后执行这个还原程序的话,那程序多半有可能报错。...贴上代码 git 地址 js-de-obfuscator/example/deobfuscator/cx 注:该 js 文件是通过工具JavaScript Obfuscator Tool进行混淆处理的。...JS 混淆与还原的网站​ 针对上述还原操作其实还不够明显,于是就编写了一个在线对 JS 代码混淆与还原的网站(主要针对还原)– JS 代码混淆与还原 (kuizuo.cn) 其实也就是对上述的还原代码进行封装成工具使用

19.1K20

火焰图系列使用火焰图隐藏功能提高绘制精度

(还不熟悉什么是火焰图的可以看看文章末尾火焰图系列文章汇总) 1.小实验 这是一个简单C程序,其实就是一个死循环,如下: #include int globalv; void dosth... out.svg 得到的火焰图: ?...我们可以看到,火焰图显示, func程序占用了近四分之一的CPU时间。...这样,我们绘制出来的火焰图是这个样子的: ? 嗯,的确有点丑,但是6.26%才是 func真正消耗了的CPU时间比例。 4.关于CPU时间准确性的讨论 怎样才算是绘制了准确的火焰图呢?...因此,从程序优化角度而言,采用第三节所描述的方法计算CPU满负载下应用程序的时间占比对于我们优化代码更具有指导性意义。 (END)

1.8K30

【Node.js丨主题周】理解perf 与火焰

本文选自《Node.js调试指南》 火焰图(Flame Graph)看起来就像一团跳动的火焰,因此得名,它可以将 CPU 的使用情况可视化,使我们直观地了解到程序的性能瓶颈。...从上面的火焰图可以看出, 最上面的绿色小块( 即 JavaScript 代码) 指向 test/app.js 的第 18 行, 即 GET /auth 这个路由;再往上看, 黄色的小块( 即 C++ 代码...原因是 Node.js 底层的libuv 用了多个线程进行计算,这里就不再深入介绍了。 svg 火焰图的其他小技巧如下。...红蓝差分火焰图 虽然我们有了火焰图,但要处理性能回退问题,还需要在修改代码前后的火焰图之间不断切换和对比,来找出问题所在,很不方便。于是 Brendan D....总之,红蓝差分火焰图可能只在代码变化不大的情况下使用时效果明显,在代码变化较大的情况下使用时效果可能就不明显了。 本文选自《Node.js调试指南》

1.9K31

差分火焰图,让你的代码优化验证事半功倍

引 在性能分析中,我们常常会用到如下所示的火焰图: 火焰图 一般来说,我们将这种火焰图称为on-cpu火焰图,可以用来记录CPU上运行的程序的占比情况。...除此之外,还有多种其他种类的火焰图,如: Memory 火焰图 off-cpu火焰图 差分火焰图 CPI火焰图 本文我们将介绍差分火焰图。...主要介绍以下的内容: 为什么要有差分火焰图 如何生成差分火焰图 差分火焰图的形成原理 开源项目pyroscope 为什么要有差分火焰图?...因此,我们尝试引入差分火焰图: 差分火焰图-brendangregg.com 差分火焰图是两个火焰图A、B比较之后的结果,我们可以认为是B-A。...我们将数据生成火焰图看看: 差分火焰图 我们不妨生成一个B数据的火焰图看看: B数据火焰图 可以看到除了配色,这两个火焰图的结构是完全一致的。我们可以得出一个结论:「差分火焰图以采样数据B为基准」。

48110

调试JS代码

记录下近期对JS代码的调试过程 性能分析 启动程序之后,打开google浏览器对应页面,按F12或者Ctrl+Shift+I进入 开发者工具页面 目前主要使用的功能有: Performance....性能评估,比如我想看下页面刷新的性能瓶颈所在,先点击 按钮,然后进行页面操作,当页面刷新完成,再点击 按钮,则会生成性能报告,可以看到资源消耗,JS代码的执行逻辑等 Sources....性能报告页面的 部分,可以通过点击色块查看其所在的js代码文件,如 点击则会跳转到 功能栏,有了源文件就可以进行断点调试;这里注意部分js文件是压缩后的文件,建议手动修改程序替换成可读性更强的原始代码文件...查看程序的打印输出,比如我想知道某个函数的执行时间,可以在js代码中进行修改 当js代码执行之后,可以在console输出中看到foo的执行时间 Network....代码使用for循环进行操作,也就是线性复杂度,计算耗时随数据量的增大而线性增大 通过debug观察发现颜色数组会有不少重复的数值,而同样的输入会导致相同的输出,然后对整个数据的1M个点进行统计分析,发现重复率相当高

19K10

js代码规范

前言 在js代码开发中,我简单的总结出了以下规则,后面会陆续补充并且对规范进行分类。...js代码建议保存到后缀名.js的文件中 js代码不建议放在html中,原因有:不能被缓存,会增大网页文件的大小,可维护性不高,会影响页面的加载。...js吧任何表达式都当一条简单语句,会导致一些隐性的错误。如果自己没加分号,那么js解释器会自动添加分号,按照自己能读懂的断句。 9.2 复合语句 也称为语句块,被包在大括号内部。...比如对象 var obj={} ;var arr=[] eval eval是最容易混乱使用的js函数,他可以执行内部入参的js函数或者表达式,可以直接解析变量。不建议使用 。...尽量使用语法严格模式 消除代码之中的不友好;代码运行更快 ;保证运行的安全 ;为新版本的js做好铺垫。 22.

8.8K30

JS代码混淆 | js 逆向系列

/UglifyJS/ https://github.com/LiPinghai/UglifyJSDocCN/blob/master/README.md 使用方法 npm install uglify-js...-g uglifyjs example.js -c -m --mangle-props -c 代码压缩 -m 代码混淆 --mangle-props 混淆属性名 -b 美化显示 // 原代码 const...JShaman https://www.jshaman.com/ JShaman 是国内公司开发的js代码加密商业产品 免费版可以直接使用 // 原代码 const person = { age...,通过数组、字典等各种形式存储、拼接、替换等,最终进行还原,这里面没有利用到复杂的语法以及js 语言本身的特性,所以我们一点点解开也学不到什么; 这个代码就不一样了,我们一步一步解开它,尝试去学习其中的思路...console.log(c) 这次我们设计三个返回值,分别是函数定义、数值、字符串 看到这,我都蒙了,经过查询资料,我找到了两个维度的复杂的原因 JavaScript 中函数只能有一个返回值,你就说这玩意如果没学过 js

1.7K10
领券