"); //-->
本文分享自天翼云开发者社区《如何让JS代码变的安全?》,作者:温****双
前端JS代码,直接暴露在浏览器中,任何访问者,都可以随意查看代码。这就导致代码可以被分析、复制、盗用等,进而引发安全问题,如被利用代码bug攻击、揭露功能逻辑、复制出雷同应用等等。
对JS代码进行保护:混淆&加密,使代码不可读。即:它人依然可以看到代码,但看到的是加密的代码、无法理解代码,更无法修改。通过混淆加密,使代码变的难以阅读和理解。
如果说混淆后机器能执行,人就能理解,只是需要的时间长短问题。这种极端的说法,从理论上来说没错,如果可以投入足够长的时间,程序员甚至可以直接用0101写代码。而从实际角度而言,一段代码如果保护后分析需要的时长,超过开发需要的时长,保护的目的就达到了,就会劝退99.9999%对它有想法的正常人类。
从技术上说用JS编程实现对JS代码混淆加密。Eval思路不可用:可以被下断点调试或API HOOK,而轻松还原出原始代码。可逆加密方式不可用:加密方式可逆,则必然有解密函数,只需定位于解密出口,即可得到原始代码。异步代码获取并执行不可用:同样可被调试或hook,得到代码。可取的方式:代码混淆+数据加密。
混淆原理是非replace或regexp方式字符串替换,而是对JS源码进行重编译。从源码,进行词法分析、语法分析、得到AST(抽象语法树),此处是重点,得到AST后,在AST中执行关键混淆加密操作,如:字符算阵列化、字符加密、平展控制流、僵尸代码值入、反调试埋雷、花指令插入等,最后,再将AST重建为JS代码。这样就得到了一份被更改的面目全非的安全JS代码:不可读、不可理解、不可修改、不可还原。
专栏文章内容及配图由作者撰写发布,仅供工程师学习之用,如有侵权或者其他违规问题,请联系本站处理。 联系我们
相关推荐
基于SPI的访问控制技术
促进网络安全和信息化的协调发展
为什么汽车制造商正在重新思考空中更新策略
思科表示,中国黑客正在利用新的零日漏洞利用其客户
基于AT0600的GPS接收机射频前端电路
计算机网络安全系统设计
MX2740构成的GPS射频前端电路
数字集成电路前端设计
Gartner发布2026年网络安全重要趋势
华恒平台成功应用于网络安全领域
网络安全解决方案
如何保障半导体晶圆厂的网络安全
RFMD推出CDMA双频手机/GPS前端接收器方案
OpenAI推出GPT-5.4-Cyber安全模型,仅面向通过审核的网络安全专业人士
数显高灵敏度FM调频立体声前端的制作
招聘IC设计工程师(前端设计 数字)
VxWorks操作系统下IKE协议的IPv6实现
【IEEE好文分享】网络安全从业者正在如何使用生成式AI
数字集成电路前端设计就业班(第二期) 热报中!
IC培训
Keysight推出SBOM网络安全合规管理器
基于MRFICl505R2的GPS接收机射频前端电路
PT100的前端电路
OpenAI Atlas 浏览器漏洞允许恶意代码注入 ChatGPT
网络安全产业的结构性演进——从系统工程到电子与底层能力的再分配
在生成式人工智能和前端升级的推动下,以太网交换技术创下新高