本帖最后由 yuupuu 于 2024-10-24 17:13 编辑
剪贴板同步能够提高很多的效率,免去复制、发送、复制、粘贴的步骤,只需要在手机上复制,就可以直接在电脑上 ctrl+v 粘贴,这方面在 Apple 设备中是做的非常好的,Apple 设备之间的剪贴板同步功能(Universal Clipboard)确实非常方便,它可以在 iPhone、iPad 和 Mac 之间无缝传输剪内容,从而大大提高工作效率。但是,iPhone 如何和 Windows 剪贴板同步呢?
其实方案有很多,有些是通过安装软件来实现,还有一些是通过输入法自带的剪贴板同步功能来实现,例如微信输入法就有剪贴板同步的功能。
技术原理
在 iPhone 中有一个叫做 快捷指令 的APP,这个APP提供了一些方法去操作你的 iPhone ,通过里面提供的API可以创建一个自动化脚本,这个脚本就可以获取剪贴板内容,既然能够获取到 iPhone 的剪贴板内容,那么就可以将剪贴板内容通过 快捷指令 的另一个API发送给 Windows 系统,然后在 Windows 系统通过一个 Python 脚本来实时监控 iPhone 的剪贴板更新,获取到新的剪贴板内容则自动设置 Windows 剪贴板。
iPhone 同步
Python 实时获取 Windows 剪贴板是否有新内容 -> POST 给服务器 -> 打开某个 APP 和关闭即可触发快捷指令获取服务器的剪贴板内容 -> 获取成功 -> 设置手机的剪贴板。
例如:你在微信聊天窗口复制了一个内容,然后退出微信界面返回 ios 桌面,这个过程实际上已经触发了自动化获取你的剪贴板内容并 POST 给服务器了,然后 Windows 那边挂了一个后台 Python 脚本去读取服务器是否有新的内容,如果有则 Python 将会自动设置 Windows 的剪贴板,此时你只需要 Ctrl+V 就可以了。
创建个人自动化,设定一个触发条件,触发条件是当打开或者关闭某个APP的时候,执行这个自动化脚本。
自动化脚本的顺序是:
1. 获取剪贴板;
2. 对剪贴板的内容进行 URL 编码;
3. 使用文本将局域网的 HTTP接口 和经过 URL编码的剪贴板内容 进行拼接;
4. 使用 获取URL内容 这个API将剪贴板内容发送给局域网API;
5. 结束。
Windows 同步
打开某个 APP 和关闭即可触发快捷指令个人自动化,获取手机的剪贴板内容 -> POST 给服务器 -> Python 监听服务器内容变动 -> 设置 Windows 剪贴板
例如:当你在 Windows 的浏览器复制了一段文字的时候,这个时候 Python 已经将这段文字 POST 给服务器了,此时你可以去打开微信,那么自动化就自动触发了,自动化将会请求服务器获取剪贴板的内容,并设置到你的手机剪贴板,此时你只需要粘贴即可。
Windows Python脚本
在本地开启一个 php 服务器,通过一个简单的 php 脚本来保存剪贴板的内容。
[Asm] 纯文本查看 复制代码 <?php
$content = $_GET['content'];
file_put_contents('./content.txt', $content);
echo '<h1>OK</h1>';
例如在本地服务器 clipboard 目录下创建 index.php 将上面代码复制进去。快捷指令发送数据过来的时候,就会将剪贴板内容保存在 content.txt 里面。然后本地开启 Python 脚本去循环读取这个 content.txt 是否有新内容,如果有则设置到剪贴板。
clipboard.py
[Asm] 纯文本查看 复制代码 import requests
import time
import pyperclip
import tkinter as tk
from tkinter import messagebox
def fetch_content(url):
try:
response = requests.get(url)
response.raise_for_status()
response.encoding = 'utf-8'
return response.text
except requests.RequestException as e:
print(f"Error fetching content: {e}")
return None
def show_floating_notification(message):
# 创建一个透明窗口靠近鼠标指针
root = tk.Tk()
root.overrideredirect(True) # 去掉窗口边框
root.attributes("-topmost", True) # 窗口置顶
root.attributes("-alpha", 0.8) # 设置透明度
root.geometry(f"220x30+{root.winfo_pointerx()}+{root.winfo_pointery()}") # 设置窗口大小和位置
label = tk.Label(root, text=message, bg="#eee", fg="#666", font=("Arial", 11))
label.pack(expand=True, fill='both')
# 自动关闭窗口
root.after(2000, root.destroy) # 3秒后自动关闭窗口
root.mainloop()
def monitor_content(url, interval=1):
last_content = None
while True:
current_content = fetch_content(url)
if current_content is not None and current_content != last_content:
print("New content detected:")
print(current_content)
pyperclip.copy(current_content) # 将内容复制到剪贴板
print("Content has been copied to the clipboard.")
show_floating_notification("来自iPhone13的剪贴板内容")
last_content = current_content
time.sleep(interval) # 间隔指定的秒数再检查
if __name__ == "__main__":
url = "http://192.168.2.112/clipboard/content.txt"
monitor_content(url)
|