使用 RN 开发的 app,客户端证书应该怎么存? - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
luckykelan
V2EX    React

使用 RN 开发的 app,客户端证书应该怎么存?

  •  
  •   luckykelan 2024-06-18 15:17:05 +08:00 2893 次点击

    我使用了 mtls 证书双向认证,想在 RN 中存一份客户端证书, 如果用硬编码,只要反编译了就很容易查出来,存文件,解压 apk 也会获得,有什么安全的方式嘛?

    13 条回复    2024-06-19 11:07:21 +08:00
    AoEiuV020JP
        1
    AoEiuV020JP  
       2024-06-18 15:32:23 +08:00
    考虑反编译就没什么办法了吧,
    首先你想防止客户端证书泄露这点不太对劲,
    iOCZS
        2
    iOCZS  
       2024-06-18 15:42:45 +08:00
    除了加密还能有啥办法呢。。。
    luckykelan
        3
    luckykelan  
    OP
       2024-06-18 15:49:19 +08:00
    @AoEiuV020JP 因为想避免接口数据泄露,客户端证书泄露了就可以随意调用接口了啊
    FengMubai
        4
    FengMubai  
       2024-06-18 16:21:28 +08:00
    @luckykelan 你在客户端运行时生成一个对称密钥, 把密钥用服务端公钥加密发过去, 然后接口数据都用对称加密 (不如直接用 https
    AoEiuV020JP
        5
    AoEiuV020JP  
       2024-06-18 16:30:26 +08:00
    @luckykelan #3 考虑反编译的话就没有任何办法阻止别人调接口了, 客户端什么逻辑别人只要一模一样的抄一遍就一定能调通,
    接口数据安全应该在服务器端做, 不该给的不要给,
    bsg1992
        6
    bsg1992  
       2024-06-18 16:37:41 +08:00   1
    都是客户端了 不就相当于光着身子 站在别人面前嘛。
    你传太多的衣服别人 也能照样给你扒光。
    w88975
        7
    w88975  
       2024-06-18 17:14:11 +08:00
    我当时做的一个 RN 项目,接口加密,是用 rust 写了个 wasm 的加密模块,数据由 wasm 加密后,传给 js ,这样反编译成本就高得多。得先反编译 apk 或者 ipa ,然后反编译 js 文件,最后找到 wasm 模块文件,再去反编译 wasm 。
    crazyu
        8
    crazyu  
       2024-06-18 17:41:18 +08:00
    想知道 v 友有关于 RN iOS 集成微信登陆、支付、分享小程序以及集成录音的经历吗? 如果有的话,是否有对应的文章可以参考,目前这个卡了好久,都没有运行成功,唉,
    dyllen
        9
    dyllen  
       2024-06-18 23:50:53 +08:00
    @w88975 感觉这个可以,这个只能提高破解成本了,完全防住应该不可能。
    xiaoshan5733
        10
    xiaoshan5733  
       2024-06-19 00:50:31 +08:00
    @crazyu 关注+1
    https://native-wechat.hector.im/ 这个是我了解到的最新方案,还没试过
    darkce
        11
    darkce  
       2024-06-19 07:54:55 +08:00
    LuckyLauncher
        12
    LuckyLauncher  
       2024-06-19 10:34:28 +08:00
    @w88975 #7 脚本小子只需要找到 wasm 文件和调用 wasm 函数的入参和出参就行了
    chniccs
        13
    chniccs  
       2024-06-19 11:07:21 +08:00
    当年我是用 c 语言写的加密模块,打包成 so 包让 app 调用 native 方法,这样反编译成本比较高。
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     2635 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 24ms UTC 09:26 PVG 17:26 LAX 02:26 JFK 05:26
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86