通过HTTP/S进行远程、内存中的Python包/模块导入
Python缺少但在其他语言中已经流行的一个特性是远程加载包/模块。
httpimport
允许Python包和模块直接在Python解释器的进程内存中通过远程URI进行安装和导入,以及更多功能...
1.1.0
。with httpimport.remote_repo('http://my-codes.example.com/python_packages'): import package1
with httpimport.pypi_repo(): import distlib # https://pypi.org/project/distlib/ print(distlib.__version__) # '0.3.6' <-- 当前最新版本 (https://github.com/pypa/distlib/blob/0.3.6/distlib/__init__.py#L9)
with httpimport.github_repo('operatorequals', 'httpimport', ref='master'): import httpimport as httpimport_upstream # 同样适用于'bitbucket_repo'和'gitlab_repo'
url = "https://gist.githubusercontent.com/operatorequals/ee5049677e7bbc97af2941d1d3f04ace/raw/e55fa867d3fb350f70b2897bb415f410027dd7e4" with httpimport.remote_repo(url): import hello hello.hello() # Hello world
# 从HTTP/S URL http_module = httpimport.load('package1', 'https://my-codes.example.com/python_packages') print(http_module) <module 'package1' from 'https://my-codes.example.com/python_packages/package1/__init__.py'> # 从PyPI pypi_module = httpimport.load('distlib', importer_class=httpimport.PyPIImporter) print(pypi_module) <module 'distlib' from 'https://files.pythonhosted.org/packages/76/cb/6bbd2b10170ed991cf64e8c8b85e01f2fb38f95d1bc77617569e0b0b26ac/distlib-0.3.6-py2.py3-none-any.whl#distlib/__init__.py'>
整个过程中没有文件接触磁盘
# with httpimport.remote_repo('https://example.com/packages.tar'): # with httpimport.remote_repo('https://example.com/packages.tar.bz2'): # with httpimport.remote_repo('https://example.com/packages.tar.gz'): # with httpimport.remote_repo('https://example.com/packages.tar.xz'): with httpimport.remote_repo('https://example.com/packages.zip'): import test_package
任何包都可以使用简单的HTTP/S服务器为httpimport
提供服务:
echo 'print("Hello httpimport!")' > module.py python -m http.server Serving HTTP on 0.0.0.0 port 8000 ...
>>> import httpimport >>> with httpimport.remote_repo("http://127.0.0.1:8000"): ... import module ... Hello httpimport!
在v1.0.0
之后,可以使用URL和命名配置文件设置HTTP认证、自定义头部、代理等多种选项!
URL配置文件是INI格式的配置,用于设置特定URL的选项,如下所示:
[http://127.0.0.1:8000] allow-plaintext: yes ; 'true'和'1'也会被评估为True [https://example.com] proxy-url: https://127.0.0.1:8080 ; 值不需要加引号(')
现在,对http://127.0.0.1:8000
的请求将被允许(默认情况下HTTP URL不起作用),而对https://example.com
的请求将通过HTTP代理发送。
with httpimport.remote_repo("https://example.com"): # URL匹配URL配置文件 import module_accessed_through_proxy
命名配置文件类似于URL配置文件,但不指定URL,需要显式使用:
[github] headers: Authorization: token <Github-Token>
上述配置可以如下使用:
with httpimport.github_repo('operatorequals','httpimport-private-test', profile='github'): import secret_module
github_pat_<乱码>
,可以在这里生成:https://github.com/settings/tokens/new从PyPI导入时可以使用额外的选项,如下面的配置文件所示:
[pypi] # 用于PyPI项目版本的'requirements.txt'文件位置 requirements-file: requirements-dev.txt # 内联'requirements.txt'语法附加 requirements: distlib==0.3.5 sampleproject==3.0.0 # 只支持版本固定符号('==') # 适用于'requirements'和'requirements-file'选项 # 包含'模块': 'PyPI项目'元组的映射 # 例如:'import sample' --> 在'sampleproject' PyPI项目中搜索'sample'模块: # https://pypi.org/project/sampleproject/ project-names: sample: sampleproject
PyPI配置文件可以像所有命名配置文件一样使用:
with httpimport.pypi_repo(profile='pypi'): import distlib import sample distlib.__version__ # '0.3.5' <-- 在配置文件'requirements'选项中固定 sample.__url__ # 'https://files.pythonhosted.org/packages/ec/a8/5ec62d18adde798d33a170e7f72930357aa69a60839194c93eb0fb05e59c/sampleproject-3.0.0-py3-none-any.whl#sample/__init__.py' <-- 从'sampleproject'加载
此外,所有其他选项都可以级联到PyPI配置文件中,如HTTPS代理(HTTP代理不起作用,因为PyPI使用HTTPS托管)、headers
等。
'
,"
)可以将配置文件作为INI字符串提供给set_profile
函数,并在所有httpimport
函数中使用:
httpimport.set_profile(""" [profile1] proxy-url: https://my-proxy.example.com headers: Authorization: Basic ... X-Hello-From: httpimport X-Some-Other: HTTP 头部 """) with httpimport.remote_repo("https://code.example.com", profile='profile1'): import module_accessed_through_proxy
配置文件是使用Python的configparser
模块解析的INI配置字符串。
httpimport
的ConfigParser
对象是全局变量httpimport.CONFIG
,可以自由使用:
import httpimport httpimport.CONFIG.read('github.ini') # 从文件中读取配置 with httpimport.github_repo('operatorequals','httpimport-private-test', profile='github'): import secret_module
httpimport
模块会自动加载位于$HOME/.httpimport.ini
和$HOME/.httpimport/
目录下的配置。$HOME/.httpimport/
目录下的配置会覆盖$HOME/.httpimport.ini
中的配置。
HTTP选项
zip-password
- v1.0.0
proxy-url
- v1.0.0
headers
- v1.0.0
allow-plaintext
- v1.0.0
ca-verify
- v1.3.0
ca-file
- v1.3.0
仅PyPI选项
project-names
- v1.2.0
requirements
- v1.2.0
requirements-file
- v1.2.0
allow-compiled
auth
auth-type
tls-cert
tls-key
tls-passphrase
import httpimport import logging logging.getLogger('httpimport').setLevel(logging.DEBUG)
强烈建议不要使用纯HTTP URL的httpimport
由于HTTP流量可以被所有中间主机读取和修改(与HTTPS不同),远程攻击者可能会修改httpimport
消耗的HTTP响应,并在下载的_包/模块_中添加任意_Python_代码。这直接导致在当前用户上下文中执行任意_远程代码_!
换句话说,通过互联网使用纯HTTP可能会危及您的主机而您无法察觉。
httpimport
时只使用HTTPS URL!RELOAD
标志和错误修复load()
函数imp
模块,改用importlib
如果我的工作对您有帮助,您可以随时通过互联网给我买杯啤酒或一升汽油,或者如果您亲自遇到我。
在第二种情况下,我们可以讨论Internet Historian或Ordinary Things的任何视频,同时听Lofi Girl播放列表,就像我们这些互联网公民一样。
最强AI数据分析助手
小浣熊家族Raccoon,您的AI智能助手,致力于通过先进的人工智能技术,为用户提供高效、便捷的智能服务。无论是日常咨询还是专业问题解答,小浣熊都能以快速、准确的响应满足您的需求,让您的生活更加智能便捷。
像人一样思考的AI智能体
imini 是一款超级AI智能体,能根据人类指令,自主思考、自主完成、并且交付结果的AI智能体。
AI数字人视频创作平台
Keevx 一款开箱即用的AI数字人视频创作平台,广泛适用于电商广告、企业培训与社媒宣传,让全球企业与个人创作者无需拍摄剪辑,就能快速生成多语言、高质量的专业视频。
一站式AI创作平台
提供 AI 驱动的图片、视频生成及数字人等功能,助力创意创作
AI办公助手,复杂任务高效处理
AI办公助手,复杂任务高效处理。办公效率低?扣子空间AI助手支持播客生成、PPT制作、网页开发及报告写作,覆盖科研、商业、舆情等领域的专家Agent 7x24小时响应,生活工作无缝切换,提升50%效率!
AI辅助编程,代码自动修复
Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。
AI小说写作助手,一站式润色、改写、扩写
蛙蛙写作—国内先进的AI写作平台,涵盖小说、学术、社交媒体等多场景。提供续写、改写、润色等功能,助力创作者高效优化写作流程。界面简洁,功能全面,适合各类写作者提升内容品质和工作效率。
全能AI智能助手,随时解答生活与工作的多样问题
问小白,由元石科技研发的AI智能助手,快速准确地解答各种生活和工作问题,包括但不限于搜索、规划和社交互动,帮助用户在日常生活中提高效率,轻松管理个人事务。
实时语音翻译/同声传译工具
Transly是一个多场景的AI大语言模型驱动的同声传译、专业翻译助手,它拥有超精准的音频识别翻译能力,几乎零延迟的使用体验和支持多国语言可以让你带它走遍全球,无论你是留学生、商务人士、韩剧美剧爱好者,还是出国游玩、多国会议、跨国追星等等,都可以满足 你所有需要同传的场景需求,线上线下通用,扫除语言障碍,让全世界的语言交流不再有国界。
一键生成PPT和Word,让学习生活更轻松
讯飞智文是一个利用 AI 技术的项目,能够帮助用户生成 PPT 以及各类文档。无论是商业领域的市场分析报告、年度目标制定,还是学生群体的职业生涯规划、实习避坑指南,亦或是活动策划、旅游攻略等内容,它都能提供支持,帮助用户精准表达,轻松呈现各种信息。
最新AI工具、AI资讯
独家AI资源、AI项目落地
微信扫一扫关注公众号