qrcp

qrcp

扫描二维码实现计算机与移动设备间的无线文件传输

qrcp是一款开源的文件传输工具,通过Wi-Fi网络在计算机和移动设备间传输文件。它生成包含传输URL的二维码,实现快速、便捷的文件传输。支持发送和接收文件,可配置网络接口、端口等参数,并提供HTTPS安全传输。适用于Linux、Windows和macOS系统,是一个简单高效的文件共享解决方案。

qrcp文件传输二维码Wi-Fi命令行工具Github开源项目

Logo

$ qrcp

通过扫描二维码,无需离开终端即可通过Wi-Fi从您的计算机向移动设备传输文件。

Go报告卡

您可以通过给我买杯咖啡捐赠来支持开发。

加入Telegram频道qrcp_dev@qrcp_devTwitter账号获取开发相关新闻。

它是如何工作的?

截图

qrcp将Web服务器绑定到您的Wi-Fi网络接口地址上的随机端口,并为其创建一个处理程序。默认处理程序提供内容并在传输完成时退出程序。当用于接收文件时,qrcp提供上传页面并处理传输。

该工具打印一个二维码,编码以下文本:

http://{address}:{port}/{random_path}

大多数二维码应用程序可以检测解码文本中的URL并采取相应行动(即用默认浏览器打开解码的URL),因此当扫描二维码时,移动浏览器将开始下载内容。

向移动设备发送文件:

截图

从移动设备接收文件:

截图

教程

安装

使用Go安装最新开发版本

注意:需要go 1.18

go install github.com/claudiodangelis/qrcp@latest

Linux

Releases页面下载最新的Linux .tar.gz 归档文件,解压它,将二进制文件移动到适当的目录,然后设置执行权限。

# 解压归档文件 tar xf qrcp_0.5.0_linux_x86_64.tar.gz # 复制二进制文件 sudo mv qrcp /usr/local/bin # 设置执行权限 sudo chmod +x /usr/local/bin/qrcp

树莓派

Releases页面提供以下ARM版本:

  • armv7
  • arm64

使用包管理器

ArchLinux

AUR上提供以下软件包:

Deb包(Ubuntu, Debian等)

Releases页面下载最新的.deb包,然后运行dpkg:

sudo dpkg -i qrcp_0.5.0_linux_x86_64.deb # 确认它正常工作: qrcp version

RPM包(CentOS, Fedora等)

Releases页面下载最新的.rpm包,然后运行rpm:

sudo rpm -i qrcp_0.5.0_linux_x86_64.rpm # 确认它正常工作: qrcp --help

Windows

Releases页面下载最新的Windows .tar.gz 归档文件并解压EXE文件。

Scoop

如果您在Windows上使用Scoop进行包管理,可以使用以下一行命令安装qrcp:

scoop install qrcp

Chocolatey

如果您在Windows上使用Chocolatey进行包管理,可以使用以下一行命令安装qrcp:

choco install qrcp

MacOS

Releases页面下载最新的macOS .tar.gz 归档文件,解压它,将二进制文件移动到适当的目录,然后设置执行权限。

# 解压归档文件 tar xf qrcp_0.5.0_macOS_x86_64.tar.gz # 复制二进制文件 sudo mv qrcp /usr/local/bin # 设置执行权限 sudo chmod +x /usr/local/bin/qrcp # 确认它正常工作: qrcp --help

Homebrew

如果您在macOS上使用Homebrew进行包管理,可以使用以下一行命令安装qrcp:

brew install qrcp

使用方法

发送文件

发送一个文件

qrcp MyDocument.pdf

一次发送多个文件

当一次发送多个文件时,qrcp会创建一个包含您要传输的文件或文件夹的zip归档文件,并在传输完成后删除zip归档文件。

# 多个文件 qrcp MyDocument.pdf IMG0001.jpg
# 整个文件夹 qrcp Documents/

在传输前压缩文件

您可以选择在传输前压缩文件。

qrcp --zip LongVideo.avi

接收文件

接收文件时,qrcp提供一个"上传页面",您可以通过该页面从移动设备选择文件。

接收文件到当前目录

qrcp receive

接收文件到指定目录

# 注意:文件夹必须存在 qrcp receive --output=/tmp/dir

配置

qrcp无需任何预先配置即可工作,但是您可以选择配置以使用特定值。

要配置qrcp,您可以在$XDG_CONFIG_HOME/qrcp中创建一个配置文件。

注意:在Linux上,$XDG_CONFIG_HOME是用户主目录下的.config。 因此,例如,在Linux上配置文件将是$HOME/.config/qrcp/config.yml。 在MacOS上,它默认为$HOME/Library/Application Support/qrcp/config.yml

注意:从0.10.0版本开始,qrcp使用YAML配置文件而不是旧的JSON格式。您可以通过运行qrcp config migrate自动将旧的JSON格式迁移到新的YAML格式。

类型注释
interface字符串此值在首次启动qrcp时自动发现,您可以设置它来覆盖默认值。您可以使用any接口将Web服务器绑定到0.0.0.0
bind字符串qrcp使用此值来绑定Web服务器。注意:如果设置了此值,则忽略interface参数。
port整数当未设置此值时,qrcp将在每次启动时选择一个随机端口。
path字符串当未设置此值时,qrcp将在URL末尾添加一个随机字符串。
output字符串接收文件的默认目录。如果为空,则使用当前工作目录。
fqdn字符串当设置此值时,qrcp将使用它来替换生成的URL中的IP地址。
keepAlive布尔值控制qrcp是否应在传输文件后退出。默认为false
secure布尔值控制qrcp是否应使用HTTPS而不是HTTP。默认为false
tls-cert字符串TLS证书的路径。仅在secure: true时使用。
tls-key字符串TLS密钥的路径。仅在secure: true时使用。
reversed布尔值反转二维码(白底黑字)?" true`。

所有配置参数都可以通过以QRCP_为前缀的环境变量控制,例如:

  • $QRCP_INTERFACE
  • $QRCP_PORT
  • $QRCP_KEEPALIVE

配置向导

config命令启动一个向导,让您配置接口、端口、完全限定域名和保持活动等参数。

qrcp config

注意:如果某些网络接口未显示,请使用--list-all-interfaces标志来抑制接口过滤器。

qrcp --list-all-interfaces config

配置文件

默认配置文件存储在$XDG_CONFIG_HOME/qrcp/config.yml中,但是,您可以通过传递--config标志来指定配置文件的位置:

qrcp --config /tmp/qrcp.yml MyDocument.pdf

端口

默认情况下,qrcp监听随机端口。设置QRCP_PORT环境变量或传递--port(或-p)标志来选择特定端口:

export QRCP_PORT=8080 qrcp MyDocument

或:

qrcp --port 8080 MyDocument.pdf

网络接口

qrcp 会尝试自动找到适合传输的网络接口。如果找到多个合适的接口,它会要求你选择一个。

如果你想使用特定的接口,可以传递 --interface(或 -i)标志:

# 网络服务器将对tun0接口网络上的 # 所有计算机可见 qrcp -i tun0 MyDocument.dpf

你也可以使用一个特殊的接口名称 any,它会将网络服务器绑定到 0.0.0.0,使网络服务器对任何网络上的所有人可见,甚至是外部网络。

当你想从亚马逊 EC2、Digital Ocean Droplet、谷歌云平台计算实例或任何其他 VPS 传输文件时,这很有用。

qrcp -i any MyDocument.pdf

绑定

除了选择接口外,你还可以直接指定你想让 qrcp 绑定网络服务器的地址。

qrcp --bind 10.20.30.40 MyDocument.pdf

URL

qrcp 使用两种 URL 模式:

  • 发送:http://{ip地址}:{端口}/send/{随机路径}
  • 接收:http://{ip地址}:{端口}/receive/{随机路径}

有一些选项可以覆盖这些模式。

传递 --path 标志来为 URL 使用特定路径,例如:

# 结果 URL 将是 # http://{ip地址}:{端口}/send/x qrcp --path=x MyDocument.pdf

传递 --fqdn(或 -d)来使用完全限定域名而不是 IP。当你从远程位置使用它时,这与 -i any 组合很有用:

# 结果 URL 将是 # http://example.com:8080/send/xYz9 qrcp --fqdn example.com -i any -p 8080 MyRemoteDocument.pdf

HTTPS

qrcp 支持使用 HTTPS 进行安全文件传输。要启用安全传输,你需要一个 TLS 证书和相关的密钥。

你可以从 qrcp config 向导中选择 TLS 证书和密钥的路径,或者如果你愿意,你可以传递 --tls-cert--tls-key

qrcp --tls-cert /path/to/cert.pem --tls-key /path/to/cert.key MyDocument

还有一个 --secure 标志可用,你可以用它来覆盖默认值。

默认输出目录

在浏览器中打开

如果你需要在终端外打印二维码,你可以传递 --browser 标志。使用这个标志,qrcp 仍然会在终端打印二维码,但它还会打开一个新的默认浏览器窗口来显示二维码。

qrcp --browser MyDocument.pdf

保持服务器运行

在传输文件后保持服务器运行可能很有用,例如,当你想将同一个文件传输到多个设备时。你可以使用 --keep-alive 标志来实现这一点:

# 服务器在第一次传输后 # 不会自动关闭 qrcp --keep-alive MyDocument.pdf

Shell 补全脚本

qrcp 带有一个内置的 completion 命令,可以生成 shell 补全脚本。

Bash:

$ source <(qrcp completion bash)

要为每个会话加载补全,执行一次:

Linux:

$ qrcp completion bash > /etc/bash_completion.d/qrcp

注意:如果你不想系统范围安装补全脚本,请参考 Bash Completion FAQ

MacOS:

$ qrcp completion bash > /usr/local/etc/bash_completion.d/qrcp

Zsh:

如果你的环境中还没有启用 shell 补全,你需要启用它。你可以执行一次以下命令:

$ echo "autoload -U compinit; compinit" >> ~/.zshrc

要为每个会话加载补全,执行一次:

$ qrcp completion zsh > "${fpath[1]}/_qrcp"

你需要启动一个新的 shell 才能使这个设置生效。

Fish:

$ qrcp completion fish | source

要为每个会话加载补全,执行一次:

$ qrcp completion fish > ~/.config/fish/completions/qrcp.fish

作者

qrcp,最初叫做 qr-filetransfer,源于 Claudio d'Angelis(Telegram 上的 @claudiodangelis)的一个想法,他是当前的维护者,并且由社区开发

加入我们!

致谢

logo 由 @arasatasaygin 提供,作为 openlogos 计划的一部分,这是一个开源项目的免费 logo 集合。

查看申请一个的规则:openlogos 规则

发布由 goreleaser 处理。

克隆和类似项目

  • qr-fileshare - 一个用 NodeJS 和 React 界面实现的类似想法。
  • instant-file-transfer (未注明) - 类似的 Node.js 项目
  • qr-filetransfer - 这个项目的 Python 克隆版
  • qr-filetransfer - 这个项目的另一个 Node.js 克隆版
  • qr-transfer-node - 这个项目的另一个 Node.js 克隆版
  • QRDELIVER - 类似的 Node.js 项目
  • qrfile - 通过扫描二维码传输文件
  • quick-transfer - 这个项目的 Node.js 克隆版
  • share-file-qr - 这个项目的 Python 重新实现
  • share-files (未注明) - 又一个这个项目的 Node.js 克隆版
  • ezshare - 另一个 Node.js 双向文件共享工具,支持文件夹和多个文件
  • local_file_share - "与其他人共享本地文件,或智能手机下载电脑中的文件"
  • qrcp - 一个 qrcp 的桌面应用克隆版,用 C# 和 .NET Core 编写,适用于 Windows。
  • swift_file - 受 qrcp 启发的 Rust 项目。

许可

MIT。参见 LICENSE

编辑推荐精选

讯飞星火

讯飞星火

深度推理能力全新升级,全面对标OpenAI o1

科大讯飞的星火大模型,支持语言理解、知识问答和文本创作等多功能,适用于多种文件和业务场景,提升办公和日常生活的效率。讯飞星火是一个提供丰富智能服务的平台,涵盖科技资讯、图像创作、写作辅助、编程解答、科研文献解读等功能,能为不同需求的用户提供便捷高效的帮助,助力用户轻松获取信息、解决问题,满足多样化使用场景。

热门AI开发模型训练AI工具讯飞星火大模型智能问答内容创作多语种支持智慧生活
Spark-TTS

Spark-TTS

一种基于大语言模型的高效单流解耦语音令牌文本到语音合成模型

Spark-TTS 是一个基于 PyTorch 的开源文本到语音合成项目,由多个知名机构联合参与。该项目提供了高效的 LLM(大语言模型)驱动的语音合成方案,支持语音克隆和语音创建功能,可通过命令行界面(CLI)和 Web UI 两种方式使用。用户可以根据需求调整语音的性别、音高、速度等参数,生成高质量的语音。该项目适用于多种场景,如有声读物制作、智能语音助手开发等。

Trae

Trae

字节跳动发布的AI编程神器IDE

Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。

AI工具TraeAI IDE协作生产力转型热门
咔片PPT

咔片PPT

AI助力,做PPT更简单!

咔片是一款轻量化在线演示设计工具,借助 AI 技术,实现从内容生成到智能设计的一站式 PPT 制作服务。支持多种文档格式导入生成 PPT,提供海量模板、智能美化、素材替换等功能,适用于销售、教师、学生等各类人群,能高效制作出高品质 PPT,满足不同场景演示需求。

讯飞绘文

讯飞绘文

选题、配图、成文,一站式创作,让内容运营更高效

讯飞绘文,一个AI集成平台,支持写作、选题、配图、排版和发布。高效生成适用于各类媒体的定制内容,加速品牌传播,提升内容营销效果。

热门AI辅助写作AI工具讯飞绘文内容运营AI创作个性化文章多平台分发AI助手
材料星

材料星

专业的AI公文写作平台,公文写作神器

AI 材料星,专业的 AI 公文写作辅助平台,为体制内工作人员提供高效的公文写作解决方案。拥有海量公文文库、9 大核心 AI 功能,支持 30 + 文稿类型生成,助力快速完成领导讲话、工作总结、述职报告等材料,提升办公效率,是体制打工人的得力写作神器。

openai-agents-python

openai-agents-python

OpenAI Agents SDK,助力开发者便捷使用 OpenAI 相关功能。

openai-agents-python 是 OpenAI 推出的一款强大 Python SDK,它为开发者提供了与 OpenAI 模型交互的高效工具,支持工具调用、结果处理、追踪等功能,涵盖多种应用场景,如研究助手、财务研究等,能显著提升开发效率,让开发者更轻松地利用 OpenAI 的技术优势。

Hunyuan3D-2

Hunyuan3D-2

高分辨率纹理 3D 资产生成

Hunyuan3D-2 是腾讯开发的用于 3D 资产生成的强大工具,支持从文本描述、单张图片或多视角图片生成 3D 模型,具备快速形状生成能力,可生成带纹理的高质量 3D 模型,适用于多个领域,为 3D 创作提供了高效解决方案。

3FS

3FS

一个具备存储、管理和客户端操作等多种功能的分布式文件系统相关项目。

3FS 是一个功能强大的分布式文件系统项目,涵盖了存储引擎、元数据管理、客户端工具等多个模块。它支持多种文件操作,如创建文件和目录、设置布局等,同时具备高效的事件循环、节点选择和协程池管理等特性。适用于需要大规模数据存储和管理的场景,能够提高系统的性能和可靠性,是分布式存储领域的优质解决方案。

TRELLIS

TRELLIS

用于可扩展和多功能 3D 生成的结构化 3D 潜在表示

TRELLIS 是一个专注于 3D 生成的项目,它利用结构化 3D 潜在表示技术,实现了可扩展且多功能的 3D 生成。项目提供了多种 3D 生成的方法和工具,包括文本到 3D、图像到 3D 等,并且支持多种输出格式,如 3D 高斯、辐射场和网格等。通过 TRELLIS,用户可以根据文本描述或图像输入快速生成高质量的 3D 资产,适用于游戏开发、动画制作、虚拟现实等多个领域。

下拉加载更多