我的想法是给他一个注册码,他用这个注册码在本地激活了软件,就无法再在其他机器上激活了,这个怎么实现?
1
gimp Apr 11, 2023
能联网激活吗
|
2
gimp Apr 11, 2023
或者提供给他一个工具,获取他机器的唯一机器编码的,把这个编码给你,你用这个编码生成 KEY 发给他激活。
|
3
zyxk Apr 11, 2023
基本原理就是获取 cpu 硬盘 网卡 等的唯一 id, 再组合一下, 加密生成响应的激活码, 没用过 Electron, 应该可以读取硬件吧.
|
4
yolee599 Apr 11, 2023 via Android
联网:这个不用我说了吧。
离线:让用户生成机器唯一 ID ,发给你生成激活码,你再把激活码发给用户。 |
6
babytomas Apr 11, 2023
可以利用 canvas 渲染偏差生成指纹,并以此作为设备 ID 获取授权。
|
7
hefish Apr 11, 2023
联网就好办了。
生成一个 kv 对给客户,提交到服务器上来,验证了就行。 |
9
proxytoworld Apr 11, 2023
生成机器唯一 id
|
10
chengxy Apr 11, 2023
可以参考这个 https://webauthn.io/
|
12
0o0O0o0O0o Apr 11, 2023
既然 electron 那就用 js fingerprint 技术获取唯一 ID ,其实你初次启动随机生成个 uuid 就行;
能联网才是关键,提交 key-uuid 进行激活,每个 key 只能激活一次;用带 seq 的心跳包确保同一时间只能一台机器用,发现作弊就 ban 了。 这样的方案实现起来成本低,别的太 hack 的技术实在没必要,攻防太累,客户端应用谁也不能真正防破解(包括这个方案)。 |
13
0o0O0o0O0o Apr 11, 2023 |
14
polarbearn Apr 11, 2023
用 electron 写的防不住的,反编译,全部代码都出来了,也有各自方法调出控制台
|
15
polarbearn Apr 11, 2023
调出控制台,修改授权的判断代码,随意输入都能授权成功
https://cdnjson.com/images/2023/04/11/auto.gif |
16
n0th1n9 Apr 11, 2023
@polarbearn 可以使用 [bytenode]( https://github.com/bytenode/bytenode) 把 js 搞成 v8 字节码,就比较难修改代码了
|