有靠谱的 js 加密方式吗?

2017-09-05 22:39:37 +08:00
 gamexg

从网上找了几个,试了下去掉最后的括号后直接秒解... 即使这么搞不定,直接把 eval 改成打印也就 ok 了。

google 家的混淆方案倒是挺牛,可惜目的是压缩代码及提升性能,没往加密上面考虑。

目前有实现到语义级别的加密吗?

比如将单个函数内容拆分到多个函数。 然后将函数内容互相交叉,互相调用的方式来使用。

对变量名、函数名等能混淆就混淆,库名等不能混淆的就加密。 变量能复用就复用,前一段代码表示是用户名,用完下一句就改成存放用户年龄。

不直接使用标准库,改成动态映射,和变量名一样复用着玩。

实在想坑人还可以改成动态加密,加密时随机数参与进去,每次加密结果都变化,刚刚解密完一部分下次又需要从头再来...

这么搞应该没人愿意解密了,但是对性能应该很大。

2568 次点击
所在节点    问与答
7 条回复
f2f2f
2017-09-05 22:42:27 +08:00
不是说 js 再怎么加密,执行一下不都全出来了。
gamexg
2017-09-05 22:46:40 +08:00
@f2f2f #1 是的,我试的几个都是执行下就出来了。那几种公开的只是将代码整体加密,运行时解密传递给 eval 执行,只要拦截到 eval 内容就出来了。

但是如果做到上面那几条,机器解密很麻烦,人肉识别也会很头疼。
rogwan
2017-09-05 23:11:37 +08:00
最终你还是要考虑浏览器看的懂哇😭 所以是无解的。
icedx
2017-09-05 23:17:10 +08:00
没有
去年自己写了个把 JS 脚本转成字节码的小玩意
基本上吊锤那些加密混淆过的 JS
KeepPro
2017-09-05 23:34:42 +08:00
你说的方案只能是混淆,不能叫加密吧
shiji
2017-09-05 23:52:52 +08:00
参考 datatables editor, 试用 30 天,js 文件上来就是 var remaining = ......
小白一想,啊哈,这个真弱智,直接乘以一万。。。顺手写个博客得瑟一下。。。
结果 30 天后所有功能都依旧被锁死。。。
wdlth
2017-09-06 00:03:28 +08:00
试试把一些算法用 asm.js 处理,至少看上去不是 JS 的样子。
完全加密是不好做的,毕竟最终使用者还是浏览器的 JS 引擎,如果有心人在引擎上做手脚,把 opcode 弄到,也可以知道程序在干什么。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/388446

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX