提高警惕,供应链攻击就在你我身边 - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
greensea
V2EX    信息安全

提高警惕,供应链攻击就在你我身边

  •  
  •   greensea 2024-09-11 17:58:43 +08:00 3521 次点击
    这是一个创建于 394 天前的主题,其中的信息可能已经有所发展或是发生改变。

    先说结论

    使用 go 开发并且正在使用 logrus 库的小伙伴,请检查你引入的包是不是官方的包。

    然后开始细说

    import ( log "github.com/siruspen/logrus" ) func foo() { log.Warningf("bar") } 

    我的这两段代码看起来没有什么问题的样子,我就引入了一个日志库 logrus ,然后输出了一点日志,能有啥问题。

    然而实际上,这段代码没有引入 logrus 官方库,官方库的地址应该是 github.com/sirupsen/logrus

    仔细看看,你看出两个地址的区别了吗?

    这就是可怕的地方,这两个地址仅仅是其中两个字母的顺序换了一下,但凡输入的时候来个笔误,就引入了非官方库。

    目前,这个非官方库仅仅从官方库 fork 了出来,只有两次提交,改了一下包名,添加了一个无关紧要的日志输出。在功能上,和官方库几乎完全一致。即使写错了库名,我也能够正常使用,很难发现我实际上写错了库名。

    这就让我想到之前 xz 库被发现的那个供应链攻击,这个仓库现在的行为就很相似,蛰伏,然后等待合适的时机。

    也许我只是杞人忧天,说不定这个库就真的只是正常 fork 了一下,名字又正好非常接近,那这样最好不过。不过不管怎么说,本来想引入官方库,结果引入了一个 fork 出来的仓库,总不是什么好事情。用了 logrus 库的小伙伴还是检查一下自己的代码吧。

    PS: 这个 fork 出来的库会在初始化的时候 fmt.Println("INIT!!!"),一个比较方便的方法是看看自己的程序启动的时候有没有打印 INIT!!!。之前我在本地库里面搜索到了这个输出代码,还暗自吐槽这库这么会有这么不专业的行为,结果原来是我自己的锅。


    最后再补充一下我是怎么发现这个问题的。今天 AI 帮我导入了 logrus 库,结果我发现我对 log 输出格式的设置在一些文件里面生效了,在另一些文件里面没生效。最后排查了好久,终于发现原来我引入了两个不同的库。

    再顺便说一下,如果 CoPilot 之类的工具会用本地代码去学习的话,我本地好多个引入了错误仓库的代码可能已经被学习进去了,AI 也有可能给你引入错误的库……

    9 条回复    2024-09-12 05:36:13 +08:00
    aycclm
        1
    aycclm  
       2024-09-11 18:13:47 +08:00   1
    我靠 它这个名字取得就是准备要搞事情的样子
    itechify
        2
    itechify  
    PRO
       2024-09-11 18:24:50 +08:00
    非 go 选手,小小疑惑,第三方库应该可以加上版本控制吧?
    0o0O0o0O0o
        3
    0o0O0o0O0o  
       2024-09-11 18:34:09 +08:00
    如果是我我就先取名成第一个字母大写再改成小写,重走一遍 Sirupsen 改名 sirupsen 的路
    https://github.com/sirupsen/logrus/issues/570#issuecomment-313933276
    k9982874
        4
    k9982874  
       2024-09-11 18:36:28 +08:00 via Android
    然而已经迁移到 vlog 了
    winterpotato
        5
    winterpotato  
       2024-09-11 18:53:24 +08:00
    恐怖这个名字看起来就是恶意的……已经 report abuse 了
    zhaoahui
        6
    zhaoahui  
       2024-09-11 19:06:52 +08:00
    它这个名字取得就是准备要搞事情的样子
    xdeng
        7
    xdeng  
       2024-09-11 19:11:47 +08:00
    卧槽槽
    RockChinQ
        8
    RockChinQ  
       2024-09-11 23:41:18 +08:00 via Android
    目前有什么自动检查机制么
    irainsoft
        9
    irainsoft  
       2024-09-12 05:36:13 +08:00
    pypi 上也有类似的恶意程序,专坑不小心打错的人,但 lz 提到 AI 自动补全,可能也会是一个新的造成问题的来源...
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     5135 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 26ms UTC 09:36 PVG 17:36 LAX 02:36 JFK 05:36
    Do have faith in what you're doing.
    ubao 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