压缩和混淆

随着Js文件体积的增大和前后端交互增多,为了加快http传输速度并提高接口的安全性,出现了很多的压缩工具和混淆加密工具。

**代码压缩:**在对用户体验造成影响的因素中,最重要的是"网页打开速度",即资源加载速度和页面渲染速度。资源加载速度的常用优化方法是压缩,压缩的对象包括HTML文档、图片和JavaScript文件等。压缩后的文件体积相对较小,不仅有利于网络传输,还能起到保护代码的作用。这是因为在压缩过程中会删除注释、空格和换行符等元素,将多个JavaScript文件合并以及缩短变量名。

随着浏览器和各大IDE推出代码格式化功能,文件压缩对代码的保护就被削弱了。为了更好地保护代码,开发者想到了代码混淆的办法。

**代码混淆:**常用的混淆方法有正则替换、代码编码和代码复杂化等。为了防止有心人在浏览器中调试,开发者甚至会在代码中加入一些能够干扰调试的代码。

  • 正则替换之变量名替换:这实际上是用简短的字母替换方法中的变量名,也可以在此基础上增加空格和换行符的删除操作。

  • 正则替换之进制替换:除了能解析Base64编码外,浏览器还能解析十六进制的字符。将原代码中的字符串和数字转为十六进制,并删除空格和换行符,最终将代码的可读性变差。

  • 代码编码之Base64:浏览器会自动解析Base64编码后的内容,我们可以利用这一特点实现"掩人耳目"的混淆效果。

  • 代码编码之AAEncode与JJEncode:AAEncode能将JavaScript代码转换为颜文字,而JJEncode则将代码转换为"$"、"_"、"+"组成的字符。

  • 代码复杂化之访问符:有些混淆方法则是改变对象访问符,如将原本用"."访问对象的方式改为用"[]"访问。

  • 代码复杂化之Packer:Packer是代码混淆中常用的方法,它能将原代码变得复杂,降低可读性。

**代码加密:**将JavaScript代码转成人无法阅读或解析的代码,如借用WebAssembly技术,可以直接将JavaScript代码用C/C++实现,JavaScript调用其编译后形成的文件来执行相应的功能。

要注意的是,无论混淆手段多么复杂,都要确保代码能够正确执行。

相关推荐
杨荧20 小时前
基于Python的宠物服务管理系统 Python+Django+Vue.js
大数据·前端·vue.js·爬虫·python·信息可视化
上海云盾第一敬业销售2 天前
小程序被爬虫攻击,使用waf能防护吗?
爬虫·小程序
小小码农一只2 天前
Python 爬虫实战:玩转 Playwright 跨浏览器自动化(Chromium/Firefox/WebKit 全支持)
爬虫·python·自动化
weixin_443353313 天前
小红书帖子评论的nodejs爬虫脚本
前端·爬虫
TLuoQiu4 天前
小电视视频内容获取GUI工具
爬虫·python
麦麦大数据4 天前
F004 新闻可视化系统爬虫更新数据+ flask + mysql架构
爬虫·mysql·flask·可视化·新闻
python-行者4 天前
akamai鼠标轨迹
爬虫·python·计算机外设·akamai
NEUMaple5 天前
python爬虫(四)----requests
开发语言·爬虫·python
电商API_180079052475 天前
大规模调用淘宝商品详情 API 的分布式请求调度实践
服务器·数据库·分布式·爬虫
小白学大数据5 天前
1688商品数据抓取:Python爬虫+动态页面解析
爬虫·python·okhttp