Dockerfile的ADD指令实现远程文件的安全校验下载

 更新时间:2026年04月27日 08:50:18   作者:舞夢輝影  
本文主要介绍了Dockerfile的ADD指令实现远程文件的安全校验下载,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

不能通过 ADD 指令实现远程文件的安全校验下载。

因为自 Docker 17.05+ 起,ADD 对远程 URL 的支持已被彻底移除。任何形如 ADD https://example.com/file.tar.gz /app/ 的写法都会在构建时直接报错:

ADD does not support remote URLs

这不是配置问题,而是 Docker 官方为保障构建可重现性、缓存一致性与安全性所作的强制限制。

所以,“用 ADD 实现安全校验下载”这一前提本身不成立——ADD 既无法下载,也不提供校验能力(无哈希验证、无签名检查、无证书校验、无权限控制)。

真正可行且推荐的做法是:放弃 ADD 下载,改用 RUN + curl/wget 显式下载 + 校验 + 清理

✅ 安全校验下载的正确写法(推荐)

使用 curl 下载并校验 SHA256

RUN set -eux; \
    curl -fsSL "https://example.com/app-v2.1.0.tar.gz" -o /tmp/app.tar.gz; \
    echo "a1b2c3d4...  /tmp/app.tar.gz" | sha256sum -c -; \
    tar -xzf /tmp/app.tar.gz -C /usr/local/; \
    rm -f /tmp/app.tar.gz
  • set -eux:任一命令失败即中断,避免错误静默继续
  • curl -fsSL:静默失败、跟随重定向、启用 SSL
  • sha256sum -c -:从标准输入读取校验行并验证
  • rm -f:立即清理临时文件,不增大镜像体积

需要 PGP 签名验证时(更高安全等级)

RUN set -eux; \
    curl -fsSL "https://example.com/app.tar.gz" -o /tmp/app.tar.gz; \
    curl -fsSL "https://example.com/app.tar.gz.asc" -o /tmp/app.tar.gz.asc; \
    gpg --no-default-keyring --keyring /tmp/pubring.gpg --import trusted-key.pub; \
    gpg --no-default-keyring --keyring /tmp/pubring.gpg --verify /tmp/app.tar.gz.asc /tmp/app.tar.gz; \
    tar -xzf /tmp/app.tar.gz -C /app/; \
    rm -f /tmp/app.tar.gz /tmp/app.tar.gz.asc /tmp/pubring.gpg

⚠️ 注意:需提前将可信公钥(trusted-key.pub)放入构建上下文,或通过 BuildKit --secret 安全挂载。

✅ 更安全的进阶实践

多阶段构建:隔离下载与运行环境

# 构建阶段:下载、校验、解压、安装
FROM alpine:latest AS builder
RUN apk add --no-cache curl gnupg tar && \
    curl -fsSL https://example.com/binary -o /tmp/tool && \
    echo "d4e5f6... /tmp/tool" | sha256sum -c - && \
    chmod +x /tmp/tool && \
    mv /tmp/tool /usr/local/bin/tool
# 运行阶段:零工具、零临时文件、最小攻击面
FROM alpine:latest
COPY --from=builder /usr/local/bin/tool /usr/local/bin/tool
CMD ["tool"]

敏感资源(含 token、私有地址)必须用 BuildKit secret

# 启用方式:DOCKER_BUILDKIT=1 docker build --secret id=mytoken,src=./token.txt .
RUN --mount=type=secret,id=mytoken \
    curl -H "Authorization: Bearer $(cat /run/secrets/mytoken)" \
         -fsSL https://internal.example.com/secret.bin > /tmp/secret.bin
  • 凭据仅在当前 RUN 中可见,不会写入镜像层
  • 不暴露于 docker history 或镜像文件系统

❌ 常见错误写法(务必避免)

  • ADD https://... /app/ → 构建直接失败(Docker ≥17.05)
  • COPY url /dest → COPY 本就不支持 URL,语法错误
  • RUN curl ... && ADD /tmp/file /dest → 多余,ADD 此时退化为 COPY,无意义
  • RUN curl -O https://... && sha256sum ... 但不加 set -eux 或 rm → 错误被忽略、临时文件残留

不复杂但容易忽略:安全不是靠指令“自动完成”,而是靠你显式控制每一步——下载、校验、权限、清理、隔离。ADD 的远程功能早已退出历史舞台,现在该用更透明、更可控的方式构建可信镜像。

到此这篇关于Dockerfile的ADD指令实现远程文件的安全校验下载的文章就介绍到这了,更多相关Dockerfile 远程文件安全校验下载内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • java多线程编程之使用Synchronized块同步方法

    java多线程编程之使用Synchronized块同步方法

    synchronized块来同步一个对象变量,也可以使用synchronized块来同步类中的静态方法和非静态方法,下面使用Synchronized块同步方法
    2014-01-01
  • Java8新特性 StreamAPI实例详解

    Java8新特性 StreamAPI实例详解

    这篇文章主要为大家介绍了Java8新特性 StreamAPI实例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-11-11
  • 如何在Spring Boot框架中使用拦截器实现URL限制

    如何在Spring Boot框架中使用拦截器实现URL限制

    在Spring Boot框架中,您可以使用拦截器(Interceptor)来控制限制URL列表,本文通过一个简单的示例给大家介绍Spring Boot 拦截器实现URL限制的操作方法,感兴趣的朋友跟随小编一起看看吧
    2023-08-08
  • 基于Springboot疫苗接种行程管理系统的设计与实现

    基于Springboot疫苗接种行程管理系统的设计与实现

    本文主要介绍了基于Springboot实现的疫苗接种行程管理系统的示例代码,系统主要实现个人疫苗接种管理、行程管理、病史管理、风险地区管理、核酸检测报告结果上报、疫情新闻管理等功能,需要的可以参考一下
    2022-03-03
  • Java虚拟机工作原理

    Java虚拟机工作原理

    本文主要介绍了Java虚拟机的工作原理。具有很好的参考价值。下面跟着小编一起来看下吧
    2017-03-03
  • 往DAO类中注入@PersistenceContext和@Resource的区别详解

    往DAO类中注入@PersistenceContext和@Resource的区别详解

    这篇文章主要介绍了往DAO类中注入@PersistenceContext和@Resource的区别详解,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-02-02
  • java开发微信公众号支付

    java开发微信公众号支付

    这篇文章主要给大家结合微信支付接口开发的实践,从获取用户授权到各主要接口的使用方法等方面介绍微信支付的关键点技术,有需要的小伙伴可以参考下
    2015-08-08
  • Java 数据结构算法Collection接口迭代器示例详解

    Java 数据结构算法Collection接口迭代器示例详解

    这篇文章主要为大家介绍了Java 数据结构算法Collection接口迭代器示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-09-09
  • Java版学生管理系统

    Java版学生管理系统

    这篇文章主要为大家详细介绍了Java版学生管理系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-06-06
  • SpringBoot基于Mybatis-Plus自动代码生成

    SpringBoot基于Mybatis-Plus自动代码生成

    这篇文章主要介绍了SpringBoot基于Mybatis-Plus自动代码生成,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-04-04

最新评论