您当前的位置:首页 > 电脑百科 > 程序开发 > 语言 > javascript

如何保护前端JS代码?

时间:2020-09-23 16:34:39  来源:今日头条  作者:淘宝攻略

淘宝攻略

Web前端JS代码需要保护吗?

这得具体情况具体分析:

  1. 如果只是写一段web页面图片轮播,或是跑马灯效果等等之类简单的功能。那不需要保护。
  2. 如果是精心设计一个绚丽的特效,如果想要保护这段自己付诸幸苦实现的特效代码不被他人随意拿去使用,那应该保护这段JS代码!
  3. 如果页面上有重要的功能是用JS代码管控的,比如交易逻辑、帐号密码信息、个人隐私、甚至有与远程服务器或数据库的通信等等,那么相关的js代码非常应该被保护、应该做JS代码防盗保护!否则可能引起被黑客分析、攻击等严重问题。安全相关的事情,从来都要防患于未然、不可心存侥幸。除非它对你毫不重要。

如何保护Web前端JS代码?

  1. 打包&压缩
    有人认为打包、压缩就是对JS代码的保护。确实,打包在一定程度上可以起码些许保护作用,好像看起来是如此。但打包、压缩的目的并不是为了保护JS代码,而是为了使用方便、减小代码体积,方便使用、便于传输。比如模块化的编程可能产生200个JS文件,如果使用时逐一用“script src”进行引用……这是种折磨,不管是对于代发人员,还是网络加载(浏览器也会生气!x_x)。类似Webpacket、Gulp进行打包,可以将这些多个JS合成到一个文件,并且可能会进行回车、换行、空格的删除,以实现代码压缩,也有一些简单混淆操作:把长变量名改为统一风格的短变量名等。然后,最终生成的一个文件。代码总量减小了、可读性差了、使用方便了。同时让有些人认为这也实现了JS代码保护。其实、实际上、当然的代码并没有被保护:可读性依旧,只是代码量大了一些而已,只要稍稍耐心的读代码,会发现,代码依然是很易理解的,没有多少安全性可言。
  2. 混淆&加密
    前端JS代码的保护,必需要混淆和加密共用。单独的JS源代码加密,是行不通的,更不可能有所谓的JS不可逆加密。因为代码在浏览器端执行时,必须转解密还原成原始代码,才能被浏览器的JS引擎识别和运行。在解密后,会存在完整的原始JS代码。这是非常不安全的存在,有多种方法可将原始的JS代码显示出来。

JS代码混淆被不少开发人员认为是不够高端的JS代码保护方式,听起来不如JS源码加密更具安全性。事实上,混淆也有多个级别。比如比较低端的字符搜索和串替换、随机插入伪僵尸代码、字符串十六进制化等等。而也有高端的手法,会先进行语法分析、词法分析,重建语法树,相当于已经实现了一个JS引擎,在引擎中处理代码,那么,就可以在其中任意一步进行自由度极高的操作,比如在语法树中插入新的语法结构、比如可以将字符串全部提取并进行加密、可以对变量进行整体有规则化的重定义使无意义化等等。这样就可以实现真正的代码重建。这样重建的JS代码安全性,将会有一个质的提升。

当正真的混淆和加密联合使用,可以实现真正的JS代码安全保护。JS混淆中融入JS加密,JS加密中又嵌入JS混淆。这样保护后的代码,即使在客户端执行环境中被逆向还原,得到的也是大量含义不明的函数、代码、字符串。特别重点是:代码已经经过了重建,这时逆向得到的也是分离后的重建的无意义JS代码、大量的僵尸代码、混淆的字符串、不明含意的变量。可读性与原始代码相比……天壤之别。

固执的人或许还会说:没有破解不了的保护方案,只要我认真、用心、用时的分析,还是能分析出原始代码含意的,确实,可能如此。

但是,原本的代码,可能只需要读10分钟,而从这样保护后的JS代码读取原始含意,可能需要……10个月。而这时候,我们的JS代码可能已经更新到下一版了。

JS代码保护的目的已经达到了,不是吗?



Tags:JS代码   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,不构成投资建议。投资者据此操作,风险自担。如有任何标注错误或版权侵犯请与我们联系,我们将及时更正、删除。
▌相关推荐
多次混淆加密JS代码能得到不同的结果吗?
一份相同的JavaScript代码,进行多次混淆加密,能得到不同的结果吗?答案是肯定的,能。JShaman可以实现这个效果。即:加密结果具有多态性、变化性。下面实测展示。来到JShaman网站,用...【详细内容】
2023-11-28  Search: JS代码  点击:(224)  评论:(0)  加入收藏
python模块之PyExecJS 执行js代码
一、简介PyExecJS是一个Python库,它提供了一种在Python中执行JavaScript代码的方式。它基于ExecJS库,可以使用多个JavaScript运行时(如Node.js、PhantomJS、JScript等)来执行Jav...【详细内容】
2023-11-08  Search: JS代码  点击:(303)  评论:(0)  加入收藏
网页JS代码,加密与不加密,效果对比
网页中用JS实现的功能,不加密时,是对所有访问者透明的,任何人都可以直接查看、分析其中的功能逻辑。而经混淆加密后的JS,以密文形式存在,可防止它人窥探。例1,某网站JS代码:使用JSh...【详细内容】
2023-11-06  Search: JS代码  点击:(127)  评论:(0)  加入收藏
在Node.JS中调用JShaman接口,实现JS代码加密。
在Node.JS中调用JShaman接口,实现JS代码加密。使用axios库实现https的post请求,代码如下:const axios = require("axios");const jshamanConfig = { //源码 "js_code": 'fu...【详细内容】
2022-12-06  Search: JS代码  点击:(370)  评论:(0)  加入收藏
js代码保护,如何保护js代码呢?
如何保护js代码呢?对JS代码进行混淆加密,就是js代码保护的正确方法。JS代码保护有不少产品可用,有免费开源的,也有商业的。免费的比如uglifyjs 、ob、商业的比如jscrambler、JSh...【详细内容】
2022-12-02  Search: JS代码  点击:(322)  评论:(0)  加入收藏
JS代码混淆加密:赋值花指令
JS代码混淆加密,有很多加密技术,本文演示赋值花指令。该技术可以将赋值内容进行花指令化,增加代码阅读难度。如下所示:首先来到JShaman网站,输入要测试的代码: 在配置中,有众多混...【详细内容】
2022-09-16  Search: JS代码  点击:(360)  评论:(0)  加入收藏
动画演示,JS代码是怎样被混淆加密的
本文分享的是一个动画效果源码,演示JS代码是如何被加密的。先看效果: 一般我们在进行JS加密时,提交原始代码,紧接着就直接得到了加密代码,混淆加密过程是黑盒状态,是不被我们知道...【详细内容】
2022-09-15  Search: JS代码  点击:(405)  评论:(0)  加入收藏
一行JS代码,实现字符串内容翻转。
一行代码,实现字符串内容或数组翻转(倒序)。代码: var str = "JShaman,专注于JS代码混淆加密。"; console.log("原字符串:",str) var new_str = str.split("").reverse().join("")...【详细内容】
2022-09-14  Search: JS代码  点击:(275)  评论:(0)  加入收藏
JShaman JS代码混淆加密效果
关键字:js加密、js混淆、js代码混淆加密JShaman是专业的JS代码混淆加密平台,拥有数十种自研JS代码保护技术。以下展示部分功能效果。注1:代码中红色、绿色字符为加密前后差异内...【详细内容】
2022-08-17  Search: JS代码  点击:(387)  评论:(0)  加入收藏
加密的JS代码,变量名能破解还原吗?
假如有以下JS代码:变量名含义非常清晰。试想:经过js代码混淆加密后,加密的变量名能被还原吗?把代码复制到JShaman网站进行加密:配置中不选择更多加密选项(这样是为了只混淆变量名...【详细内容】
2022-06-24  Search: JS代码  点击:(248)  评论:(0)  加入收藏
▌简易百科推荐
JavaScript的异步编程常见模式
在JavaScript中,异步编程是一种处理长时间运行操作(如网络请求或I/O操作)的常见方式。它允许程序在等待这些操作完成时继续执行其他任务,从而提高应用程序的响应性和性能。JavaS...【详细内容】
2024-04-12  靳国梁    Tags:JavaScript   点击:(2)  评论:(0)  加入收藏
17 个你需要知道的 JavaScript 优化技巧
你可能一直在使用JavaScript搞开发,但很多时候你可能对它提供的最新功能并不感冒,尽管这些功能在无需编写额外代码的情况下就可以解决你的问题。作为前端开发人员,我们必须了解...【详细内容】
2024-04-03  前端新世界  微信公众号  Tags:JavaScript   点击:(6)  评论:(0)  加入收藏
你不可不知的 15 个 JavaScript 小贴士
在掌握如何编写JavaScript代码之后,那么就进阶到实践——如何真正地解决问题。我们需要更改JS代码使其更简单、更易于阅读,因为这样的程序更易于团队成员之间紧密协...【详细内容】
2024-03-21  前端新世界  微信公众号  Tags:JavaScript   点击:(27)  评论:(0)  加入收藏
又出新JS运行时了!JS运行时大盘点
Node.js是基于Google V8引擎的JavaScript运行时,以非阻塞I/O和事件驱动架构为特色,实现全栈开发。它跨平台且拥有丰富的生态系统,但也面临安全性、TypeScript支持和性能等挑战...【详细内容】
2024-03-21  前端充电宝  微信公众号  Tags:JS   点击:(26)  评论:(0)  加入收藏
构建一个通用灵活的JavaScript插件系统?看完你也会!
在软件开发中,插件系统为应用程序提供了巨大的灵活性和可扩展性。它们允许开发者在不修改核心代码的情况下扩展和定制应用程序的功能。本文将详细介绍如何构建一个灵活的Java...【详细内容】
2024-03-20  前端历险记  微信公众号  Tags:JavaScript   点击:(20)  评论:(0)  加入收藏
对JavaScript代码压缩有什么好处?
对JavaScript代码进行压缩主要带来以下好处: 减小文件大小:通过移除代码中的空白符、换行符、注释,以及缩短变量名等方式,可以显著减小JavaScript文件的大小。这有助于减少网页...【详细内容】
2024-03-13  WangLiwen    Tags:JavaScript   点击:(2)  评论:(0)  加入收藏
跨端轻量JavaScript引擎的实现与探索
一、JavaScript 1.JavaScript语言JavaScript是ECMAScript的实现,由ECMA 39(欧洲计算机制造商协会39号技术委员会)负责制定ECMAScript标准。ECMAScript发展史: 2.JavaScript...【详细内容】
2024-03-12  京东云开发者    Tags:JavaScript   点击:(2)  评论:(0)  加入收藏
面向AI工程的五大JavaScript工具
令许多人惊讶的是,一向在Web开发领域中大放异彩的JavaScript在开发使用大语言模型(LLM)的应用程序方面同样大有价值。我们在本文中将介绍面向AI工程的五大工具,并为希望将LLM...【详细内容】
2024-02-06    51CTO  Tags:JavaScript   点击:(53)  评论:(0)  加入收藏
JS小知识,使用这6个小技巧,避免过多的使用 if 语句
最近在重构我的代码时,我注意到早期的代码使用了太多的 if 语句,达到了我以前从未见过的程度。这就是为什么我认为分享这些可以帮助我们避免使用过多 if 语句的简单技巧很重要...【详细内容】
2024-01-30  前端达人  今日头条  Tags:JS   点击:(58)  评论:(0)  加入收藏
18个JavaScript技巧:编写简洁高效的代码
本文翻译自 18 JavaScript Tips : You Should Know for Clean and Efficient Code,作者:Shefali, 略有删改。在这篇文章中,我将分享18个JavaScript技巧,以及一些你应该知道的示例...【详细内容】
2024-01-30  南城大前端  微信公众号  Tags:JavaScript   点击:(71)  评论:(0)  加入收藏
站内最新
站内热门
站内头条