# AirDropPlus **Repository Path**: yeytytytytyytyt/air-drop-plus ## Basic Information - **Project Name**: AirDropPlus - **Description**: About A file transfer and clipboard synchronization tool between Windows and iOS devices implemented using Python and Shortcuts. - **Primary Language**: Python - **License**: MIT - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 119 - **Forks**: 17 - **Created**: 2023-12-08 - **Last Updated**: 2025-07-08 ## Categories & Tags **Categories**: networklib **Tags**: None ## README # AirDrop Plus 用于 iOS 设备和 Windows 电脑之间进行文件传输,基于 HTTP,需要配合快捷指令使用 # 依赖 ``` python==3.10.6 flask==3.0.0 win10toast==0.9 psutil==5.9.6 pyinstaller==6.2.0 windows_toasts==1.1.0 pillow==10.1.0 pyperclip~=1.8.2 pystray==0.19.5 ``` # 打包 ```bash pyinstaller --add-data 'config;config' --add-data 'static;static' -w AirDropPlus.py ``` # 使用 1. Windows安装bonjour,这样就可以通过 '设备名.local' 访问到Windows,而不需要通过IP地址。
Image
2. 修改配置文件 'config.ini',设置文件保存路径和密钥(打包后的配置文件在'_internal/config.ini') 3. 手机端下载快捷指令:https://www.icloud.com/shortcuts/a10fa721e97b4f67b1703c0730b12c06 4. 设置快捷指令: - 主机:Windows设备名.local - 密钥:'config.ini' 中设置的密钥相同 - 简化:启用时会关闭发送iOS剪贴板的功能
Image
5. 使用条件:iOS设备和Windows设备在同一个局域网下,也可以是Windows连接iOS的热点,或者iOS连接Windows的热点,使用热点发送文件不消耗流量 6. 功能测试 - 发送文件:在文件分享菜单执行'AirDrop Plus'快捷指令 - 接收文件:直接执行'AirDrop Plus'快捷指令,也可以在辅助功能中设置成双击手机背面触发,15 Pro系列可以设置成侧边按钮触发。 - 当'简化'被开启时,运行后iOS接收Windows上复制的内容(文件、图像、文本)。 - 当'简化'被关闭时,运行后会弹出一个菜单,选择发送iOS剪贴板,还是接收Windows剪贴板
Image Image
7. 退出程序:在Windows任务管理器中右键'AirDropPlus.exe',点击结束任务
Image
# 问题 1. 快捷指令运行超时:可能的原因 # API ## 请求头参数 | 参数名 | 类型 | 描述 | |-----------------|--------|---------------------------------------------------------------| | ShortcutVersion | String | 快捷指令的版本,需要和 config.ini 中的 version 一致 | | Authorization | String | 密钥,需要和 config.ini 中的 key 前两位一致,例如 config.ini 为 1.5.1,此处需要是1.5 | ## 文件发送 > 移动端发送一个文件到PC ### 请求 #### 请求方式 - HTTP 方法: POST - URL: /file/send #### 请求参数 - 发送格式: 表单 | 参数名 | 类型 | 描述 | |----------------|--------|-----------------------------------------------------------------------------------------------------------------------------------| | file | File | 要发送的文件 | | filename | String | 发送的文件名 | | notify_content | String | 让PC端通知显示的内容
如果是发送单个文件:这里填写的就是 filename 的内容
如果是发送n个文件:前n-1个的 notify_content 为空,第n个的 notify_content 包含n个文件的 filename,使用\n分隔 | ### 返回 - 返回类型: JSON - 返回内容: ```json { "success": true, "msg": "发送成功", "data": null } ``` ## 文件发送列表 > 移动端发送文件列表到PC(通知PC接下来要发送哪些文件) ### 请求 #### 请求方式 - HTTP 方法: POST - URL: /file/send/list #### 请求参数 - 发送格式: 表单 | 参数名 | 类型 | 描述 | |-----------|--------|---------------------------------------| | file_list | String | 要发送的文件列表,文件之间用\n分隔,如:aaa.jpg\nbbb.png | ### 返回 - 返回类型: JSON - 返回内容: ```json { "success": true, "msg": "发送成功", "data": null } ``` ## 文件接收 > 移动端接收PC上的文件 ### 请求 #### 请求方式 - HTTP 方法: POST - URL: /file/receive #### 请求参数 - 发送格式: 表单 | 参数名 | 类型 | 描述 | |----------|--------|-----------| | path | String | 要接收的文件的路径 | ### 返回 - 返回类型: 文件 - 返回内容: 文件 ## 剪贴板发送 > 把移动端的剪贴板发送到PC的剪贴板 ### 请求 #### 请求方式 - HTTP 方法: POST - URL: /clipboard/send #### 请求参数 - 发送格式: 表单 | 参数名 | 类型 | 描述 | |-----------|--------|----------| | clipboard | String | 移动端剪贴板内容 | ### 返回 - 返回类型: JSON - 返回内容: ```json { "success": true, "msg": "发送成功", "data": null } ``` ## 剪贴板接收 > 发送PC的剪贴板内容 ### 请求 #### 请求方式 - HTTP 方法: GET - URL: /clipboard/receive #### 请求参数 - 无 ### 返回 - 返回类型: JSON - 返回内容: - 剪贴板内容为文本时: ```json { "success": true, "msg": "", "data": { "type": "text", "data": "clipboard_text" } } ``` - 剪贴板为文件时: ```json { "success": true, "msg": "", "data": { "type": "file", "data": ["c:/xx/xx/aa.png", "c:/xx/xx/bb.pdf"] } } ``` - 剪贴板为图像时: ```json { "success": true, "msg": "", "data": { "type": "img", "data": "img_base64_code" } } ```