难题彻底解决!VPaste:让 SSH 终端也能"粘贴"截图

一键截图上传,URL 直接输入到光标位置 ------ 解决远程开发场景下的图片粘贴难题

痛点:SSH 终端无法粘贴图片

作为一个开发者,你是否遇到过这样的场景:

  1. 在本地 Mac 截图了一张 UI 问题
  2. SSH 连接到远程服务器,想用 Claude Code 或 Codex 分析这个问题
  3. Cmd+V 想粘贴图片......但终端只能粘贴文本,图片丢失了
  4. 只能手动把图片上传到某处,复制 URL,再粘贴 URL

这个流程太繁琐了!尤其是在和 AI 助手交互时,图片输入的效率直接影响开发体验。

解决方案:VPaste

VPaste 是一个 Mac 本地工具,核心思路很简单:

截图在剪贴板 → 按 Cmd+Alt+V → CDN URL 直接"打"到光标位置

原来的 Cmd+V 粘贴图片功能完全保留,两个快捷键各司其职:

快捷键 功能
Cmd+V 正常粘贴剪贴板内容(图片/文本)
Cmd+Alt+V 上传图片,粘贴 CDN URL

技术实现

1. 快捷键监听

用 Swift 编写一个后台守护进程,通过 CGEventTap 监听全局键盘事件:

swift 复制代码
func eventTapCallback(proxy: CGEventTapProxy, type: CGEventType, 
                      event: CGEvent, refcon: UnsafeMutableRawPointer?) -> Unmanaged<CGEvent>? {
    if type == .keyDown {
        let keyCode = event.getIntegerValueField(.keyboardEventKeycode)
        let flags = event.flags
        
        // V = keyCode 9, Cmd + Alt
        if keyCode == 9 && flags.contains(.maskCommand) && flags.contains(.maskAlternate) {
            runVPaste()  // 异步执行上传
            return nil   // 消费事件,不传递
        }
    }
    return Unmanaged.passRetained(event)
}

2. 剪贴板图片读取

macOS 剪贴板中的图片默认是 TIFF 格式,需要转换成 PNG:

go 复制代码
// AppleScript 读取剪贴板图片
script := `
    set theImage to the clipboard as TIFF picture
    write theImage to file "/tmp/vpaste/image.png"
`

// sips 转换为真正的 PNG
exec.Command("sips", "-s", "format", "png", tempPath, "--out", tempPath).Run()

3. 上传到 COS

使用腾讯云 COS SDK 上传,生成带日期路径的文件名:

go 复制代码
func (c *COSClient) UploadFile(ctx context.Context, filePath string) (string, error) {
    key := fmt.Sprintf("vpaste/temp/%s/%s.png", 
        time.Now().Format("2006/01/02"), filename)
    
    client.Object.Put(ctx, key, reader, opt)
    
    return fmt.Sprintf("https://%s/%s", c.cdnDomain, key), nil
}

4. URL 输入到光标位置

不是用键盘模拟逐字输入(会被输入法干扰),而是:

  1. 把 URL 写入剪贴板
  2. 模拟 Cmd+V 粘贴
swift 复制代码
func pasteURL(_ url: String) {
    let pasteboard = NSPasteboard.general
    pasteboard.clearContents()
    pasteboard.setString(url, forType: .string)
    
    // 模拟 Cmd+V
    let cmdDown = CGEvent(keyboardEventSource: source, virtualKey: 0x37, keyDown: true)
    let vDown = CGEvent(keyboardEventSource: source, virtualKey: 0x09, keyDown: true)
    vDown?.flags = .maskCommand
    // ... post events
}

安装使用

bash 复制代码
# 克隆仓库
git clone https://github.com/talkcozy/vpaste.git
cd vpaste

# 一键安装
./install.sh

配置你的 COS 凭证:

yaml 复制代码
# ~/.config/vpaste/config.yaml
secret_id: "your_cos_secret_id"
secret_key: "your_cos_secret_key"
bucket: "your-bucket-1234567890"
region: "ap-shanghai"
cdn_domain: "cdn.your-domain.com"
upload_path: "vpaste/temp"

首次使用需要授予辅助功能权限(用于监听全局快捷键)。

设计哲学

  1. 最小改动 :不改变原有的 Cmd+V 行为,新增独立快捷键
  2. 零感知:后台守护进程自动启动,无需手动操作
  3. 即刻可用:URL 直接出现在光标位置,不需要额外复制
  4. 云端销毁:可配置 COS 生命周期规则,自动清理临时图片

适配场景

  • ✅ SSH 终端远程开发
  • ✅ Claude Code / Codex AI 助手交互
  • ✅ 浏览器地址栏、搜索框
  • ✅ 任何支持文本输入的地方

开源

项目已在 GitHub 开源:github.com/talkcozy/vp...

MIT License,欢迎 Star、Fork、PR!

相关推荐
IT_陈寒1 小时前
Vite的热更新突然不香了,排查三小时差点砸键盘
前端·人工智能·后端
阿里云大数据AI技术3 小时前
构建高转化海外电商搜索:阿里云OpenSearch行业算法版的全链路智能优化策略实战
人工智能·搜索引擎
Awu12273 小时前
⚡从零开发 Agent CLI(五)实现一个可治理、可扩展的工具系统
前端·人工智能·claude
字节跳动视频云技术团队3 小时前
让 Agent 成为音视频工作台:AI MediaKit CLI + Skill 发布
人工智能·音视频开发
魏祖潇3 小时前
framework 整合实战——DDD/TDD/SDD 三件套在 framework 仓的真实落地
人工智能·后端
Token炼金师4 小时前
去噪扩散:从随机噪声到高保真图像的数学之路
人工智能·aigc
这个DBA有点耶4 小时前
AI写的SQL跑崩了生产库,这锅谁背?
数据库·人工智能·程序员
阿里云大数据AI技术4 小时前
阿里云 EMR AI 助手正式发布:从问答工具到全栈智能运维助手
运维·人工智能
Larcher5 小时前
从零搭建 MCP 服务——让 AI 拥有无限扩展能力
人工智能·程序员