0

0

VSCode中怎么使用SFTP同步远程文件?【教程】

夜晨

夜晨

发布时间:2026-01-16 22:49:02

|

869人浏览过

|

来源于php中文网

原创

VSCode需通过SFTP扩展实现远程同步,推荐使用Arjun Komath维护的liximomo.sftp;安装后须打开工作区,配置正确sftp.json(含host、port、username、remotePath),上传前确保远程目录存在。

vscode中怎么使用sftp同步远程文件?【教程】

VSCode 本身不内置 SFTP 功能,必须依赖扩展实现远程文件同步;最常用、维护活跃、支持主流协议的是 ftp-simpleSFTP(由 Arjun Komath 维护,ID:liximomo.sftp)。后者更稳定、配置更清晰,推荐优先使用。

安装并启用 SFTP 扩展

在 VSCode 扩展市场搜索 SFTP,认准发布者为 Arjun Komath、ID 是 liximomo.sftp 的那个——注意别选错成已停更的旧版(如 npmi.sftp 或名字相近但无持续更新的)。安装后无需重启,但需确保当前工作区已打开(即有文件夹被加载),否则右键菜单里的 Upload/Download 选项不会出现。

常见错误现象:

  • 右键没有 Upload to SFTP Server:说明未打开文件夹,或扩展未激活(检查左下角状态栏是否有 SFTP 图标)
  • 安装后命令面板(Ctrl+Shift+P)搜不到 SFTP 相关命令:重启 VSCode 或重载窗口(Cmd/Ctrl+Shift+P → Developer: Reload Window

配置 sftp.json 连接远程服务器

在当前工作区根目录下新建 .vscode/sftp.json(路径必须准确),内容需包含至少 hostportusernameremotePath 四项。密码可留空(后续会弹窗输入),但建议用密钥认证避免反复输密码。

关键参数说明:

Sesame AI
Sesame AI

一款开创性的语音AI伴侣,具备先进的自然对话能力和独特个性。

下载
  • protocol:默认 sftp,不要改成 ftpftps,否则连接失败
  • remotePath:必须以 / 开头,且是远程服务器上的绝对路径(如 /var/www/html),不是相对路径
  • uploadOnSave:设为 true 后,本地保存文件自动上传;但仅对已映射到该配置的文件生效(即文件路径匹配 files 规则,或位于 remotePath 对应的本地子目录)
  • ignore:数组形式,填 glob 模式,如 ["**/.git/**", "**/node_modules/**"],防止上传无关文件
{
  "name": "Production Server",
  "host": "192.168.1.100",
  "port": 22,
  "username": "deploy",
  "remotePath": "/var/www/myapp",
  "uploadOnSave": true,
  "ignore": ["**/.git/**", "**/dist/**"]
}

上传/下载文件与文件夹的正确操作方式

右键菜单是最直接的方式,但行为取决于你右键的对象和当前配置是否匹配:

  • 右键一个本地文件 → 出现 Upload to SFTP Server:上传该文件到 remotePath 下对应路径(如本地 src/index.js 会传到远程 /var/www/myapp/src/index.js
  • 右键一个本地文件夹 → 只有 Upload Folder to SFTP Server:上传整个文件夹(含子目录),目标路径是 remotePath + 文件夹名
  • 右键远程资源管理器中的文件 → Download from SFTP Server:下载单个文件;但该面板默认不显示,需先通过 SFTP: Connect 命令连接成功才会出现

注意:SFTP 扩展不会自动创建远程缺失的父目录。如果上传 src/utils/helper.js,而远程 /var/www/myapp/src/utils/ 不存在,会报错 No such file。此时需手动创建,或改用 SFTP: Upload Folder(它会递归建目录)。

调试连接失败的几个关键点

连接超时、权限拒绝、无法列出目录是最常遇到的问题,排查顺序建议如下:

  • 确认远程服务器 SSH 正在运行:ssh deploy@192.168.1.100 能否正常登录?不能则先解决网络或 SSH 配置
  • 检查用户权限:该用户是否对 remotePath 有读写权限?ls -ld /var/www/myapp 看属主和权限位
  • 验证密钥格式:若用私钥,确保是 OpenSSH 格式(-----BEGIN OPENSSH PRIVATE KEY-----),不是 PuTTY 的 .ppk;可用 ssh-keygen -p -f key.pem 转换
  • 查看输出面板:Ctrl+Shift+U 打开输出面板 → 左上角下拉选 SFTP,所有连接日志、错误详情都在这里,比弹窗提示更具体

特别容易忽略的一点:Windows 用户若用 WSL 作为本地开发环境,sftp.json 中的 remotePath 是远程 Linux 路径,但本地路径映射仍按 Windows 规则解析——除非你在 WSL 内启动 VSCode(用 code .),否则路径逻辑可能错乱。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

411

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

533

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

309

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

74

2025.09.10

html版权符号
html版权符号

html版权符号是“©”,可以在html源文件中直接输入或者从word中复制粘贴过来,php中文网还为大家带来html的相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

611

2023.06.14

html在线编辑器
html在线编辑器

html在线编辑器是用于在线编辑的工具,编辑的内容是基于HTML的文档。它经常被应用于留言板留言、论坛发贴、Blog编写日志或等需要用户输入普通HTML的地方,是Web应用的常用模块之一。php中文网为大家带来了html在线编辑器的相关教程、以及相关文章等内容,供大家免费下载使用。

648

2023.06.21

html网页制作
html网页制作

html网页制作是指使用超文本标记语言来设计和创建网页的过程,html是一种标记语言,它使用标记来描述文档结构和语义,并定义了网页中的各种元素和内容的呈现方式。本专题为大家提供html网页制作的相关的文章、下载、课程内容,供大家免费下载体验。

467

2023.07.31

html空格
html空格

html空格是一种用于在网页中添加间隔和对齐文本的特殊字符,被用于在网页中插入额外的空间,以改变元素之间的排列和对齐方式。本专题为大家提供html空格的相关的文章、下载、课程内容,供大家免费下载体验。

245

2023.08.01

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

9

2026.01.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 7.2万人学习

Git 教程
Git 教程

共21课时 | 2.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号