news 2026/5/1 7:14:44

npm 离线安装软件包指南(离线安装 claude code)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
npm 离线安装软件包指南(离线安装 claude code)

本文以离线安装@anthropic-ai/claude-code(Claude Code 客户端)和@musistudio/claude-code-router(Claude Code Router)为例,介绍如何通过 npm 原生命令实现离线全局安装。该方法适用于任何 npm 包的离线安装场景。

流程概览

  1. 使用 npm 命令生成完整的依赖清单(包含直接和间接依赖)
  2. 从依赖清单中解析出需要下载的包名和版本
  3. 下载对应的 .tgz 文件并安装到全局

步骤一:生成依赖清单

在有网机器上执行

# 进入项目目录(包含 package.json 和 package-lock.json)cd/path/to/project# 安装依赖(生成 node_modules,npm 会自动选择当前平台的包)npminstall# 生成完整的依赖清单(包含所有直接和间接依赖)# --all: 显示所有传递依赖# --json: 以 JSON 格式输出npmls--all --json>deps-full.json

依赖清单示例

deps-full.json的结构:

{"dependencies":{"@anthropic-ai/claude-code":{"version":"2.1.15","resolved":"http://nexus.test.com/.../claude-code-2.1.15.tgz","dependencies":{"@img/sharp-win32-x64":{"version":"0.33.5","resolved":"http://nexus.test.com/.../sharp-win32-x64-0.33.5.tgz"}}},"@musistudio/claude-code-router":{"version":"2.0.0","resolved":"http://nexus.test.com/.../claude-code-router-2.0.0.tgz"}}}

说明npm install已经自动过滤了平台,只下载了当前系统需要的包


步骤二:从清单解析并下载 .tgz 文件

提示:如果依赖包数量较少(例如少于 5 个),推荐直接从浏览器下载.tgz文件,比使用命令行工具更简单快捷。

在有网机器上执行

# 1. 从 deps-full.json 中提取所有 resolved 链接# Windows PowerShell:Get-Content deps-full.json|Select-String'"resolved"'|ForEach-Object{if($_-match'"resolved":\s*"([^"]+)"'){$matches[1]}}|Out-File -Encoding utf8 download-urls.txt# Linux/macOS/Git Bash:grep-o'"resolved":\s*"[^"]*"'deps-full.json|sed's/"resolved":\s*"\([^"]*\)"/\1/'>download-urls.txt# 2. 批量下载 .tgz 文件# 使用 aria2c (推荐):aria2c -i download-urls.txt -d offline-packages# 或使用 wget:wget-i download-urls.txt -P offline-packages# 或使用 curl:catdownload-urls.txt|xargs-I{}curl-O --create-dirs --output-dir offline-packages{}# 3. 复制依赖清单到离线包目录(供参考)cpdeps-full.json offline-packages/

步骤三:离线安装

在离线机器上执行

重要提示

  • Windows 用户必须使用 PowerShell,CMD 不支持通配符展开
  • 不要使用 CMD,否则会报错
# 1. 进入 offline-packages 目录cdoffline-packages# 2. 查看依赖清单(了解需要安装的包)catdeps-full.json# 3. 安装所有 .tgz 包到全局# Windows PowerShell (必须使用 PowerShell,CMD 不支持 *.tgz 通配符):npminstall-g(Get-ChildItem *.tgz)--offline# Linux/macOS/Git Bash:npminstall-g *.tgz --offline# 4. 验证安装claude --version ccr --versionnpmlist -g --depth=0

命令参考

依赖分析相关

命令说明
npm install安装依赖到 node_modules(自动过滤平台)
npm ls --all显示所有依赖(包括传递依赖)
npm ls --all --json以 JSON 格式输出依赖树
npm ls --all --parseable以机器可读格式输出

下载相关

命令说明
grep -o '"resolved":\s*"[^"]*"' file.json提取 resolved 链接
aria2c -i urls.txt -d dir批量下载(推荐)
wget -i urls.txt -P dir批量下载
curl -O --output-dir dir下载单个文件

安装相关

命令说明
npm install -g package.tgz安装单个包到全局
npm install -g (Get-ChildItem *.tgz)批量安装(仅 Windows PowerShell,CMD 不支持 *.tgz 通配符)
npm install -g *.tgz批量安装(仅 Linux/macOS/Git Bash)
npm list -g --depth=0查看已安装的全局包

Windows 用户注意:CMD 不支持*.tgz通配符,必须使用 PowerShell


优势说明

为什么先执行 npm install?

  1. 自动平台过滤:npm 会根据当前系统自动选择需要的包

    • Windows 只下载 win32 相关的包
    • Linux 只下载 linux 相关的包
    • macOS 只下载 darwin 相关的包
  2. 获取完整依赖树npm ls --all --json会显示所有直接和间接依赖

  3. 避免下载无用包:不需要下载其他平台的包,节省时间和空间


注意事项

1. 平台一致性

确保有网机器和离线机器是相同平台

  • 如果有网机器是 Windows,离线机器也应该是 Windows
  • 如果有网机器是 Linux,离线机器也应该是 Linux

如果需要跨平台,需要在每个平台上分别执行步骤一和步骤二。

2. Shell 环境要求

平台推荐Shell不支持说明
WindowsPowerShellCMDCMD 不支持通配符*.tgz
WindowsGit Bash-可用,与 Linux 相同
LinuxBash/sh-原生支持
macOSBash/zsh-原生支持

批量安装命令

  • Windows PowerShell:npm install -g (Get-ChildItem *.tgz)
  • Windows Git Bash/Linux/macOS:npm install -g *.tgz

3. 依赖顺序

使用批量安装命令时,npm 会自动处理依赖顺序,无需手动排序。


(END)

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/10 17:08:15

大数据领域数据预处理:优化数据存储与管理的关键

大数据领域数据预处理:优化数据存储与管理的关键 关键词:大数据预处理、数据清洗、数据集成、数据转换、数据归约、存储优化、管理效率 摘要:在大数据时代,数据预处理作为数据生命周期管理的核心环节,直接影响数据存储效率、分析质量和应用价值。本文系统解析数据预处理的…

作者头像 李华
网站建设 2026/4/18 16:08:09

亲测好用10个AI论文平台,助你轻松搞定本科生毕业论文!

亲测好用10个AI论文平台,助你轻松搞定本科生毕业论文! AI 工具助力论文写作,轻松应对学术挑战 在当前的学术环境中,越来越多的学生开始借助 AI 工具来提升论文写作效率。无论是降低 AIGC 率,还是保持语义通顺&#xff…

作者头像 李华
网站建设 2026/4/22 6:12:58

OpenCode Rules 完整指南

概述 OpenCode的Rules功能通过创建AGENTS.md文件来提供自定义指令,类似于Cursor的规则。这些指令会包含在LLM的上下文中,用于定制特定项目的行为,让AI助手更好地理解项目需求和工作流程。 初始化 自动创建 运行/init命令自动扫描项目并生成AG…

作者头像 李华
网站建设 2026/5/1 5:10:12

只需一张图,无需训练、无需先验、无需提示、类别无关!这个通用物体计数模型即将开源!

原文链接:真正类别无关的、理想的、可用于全自动物体计数系统的解决方案。 在智能交通系统中,算法需实时监测不同区域的人流、车流密度。在工业流水线上,模型要快速清点成千上万个形态各异的零件。 看似简单的计数任务,实则涉及…

作者头像 李华
网站建设 2026/4/20 9:20:36

Java基于SSM+JSP的词语查询系统

项目说明 成语,作为汉语语言文化中的瑰宝,承载着深厚的历史底蕴与文化内涵。随着互联网技术的发展,传统的成语学习方式已经无法满足现代人的需求,而成语查询系统的开发则具有深远的意义。它不仅为人们提供了一个便捷、高效的成语…

作者头像 李华
网站建设 2026/4/27 1:40:49

Java基于Spring Boot+Vue的智能社区服务与管理平台的设计与实现

所需该项目可以在最下面查看联系方式,为防止迷路可以收藏文章,以防后期找不到 项目介绍 随着城市化进程的加快,社区作为城市生活的基本单元,其管理和服务水平直接影响到居民的生活质量和城市的整体形象。然而,传统的…

作者头像 李华