开源一款剪贴板跨设备共享工具

简介: `shigen`,编程博主,擅长多种语言,近期自制了一个名为`copyhub`的工具,用于局域网内跨设备同步剪贴板。设计灵感源于对现有共享工具的安全顾虑,采用`Flask`和`Redis`实现,前端直接HTML+JS,简化架构。用户通过取件码交换内容,不涉及复杂功能。代码已开源并在个人腾讯云服务器上部署。更多详情见shigen的GitHub和哔哩哔哩频道。一起探索,每天进步!

shigen坚持更新文章的博客写手,擅长Java、python、vue、shell等编程语言和各种应用程序、脚本的开发。记录成长,分享认知,留住感动。
个人IP:shigen

昨天遇到了一个很棘手的问题:我的手机剪贴板需要同步到另外的两台设备上。遗憾的是手机上并没有安装相同的通讯软件。用网上免费的剪贴板共享工具吧,方便是方便,但是觉得还是不安全,关键是不能实现特定的需求。我很享受DIY的过程,于是思索一下,我觉得我可以自己做出来,还能做到局域网下的剪贴板跨设备共享,毕竟我也曾有过成功的案例:开源一个局域网文件共享工具。于是说干就干。

起名字

项目总得有个名字吧。哎,想了好久,还是觉得没有合适的,最后问了GPT,选用了cpoyhub这个名字。

确认需求

我的需求就是很简单,像极了【蜂巢】的设计,我随用随取。输入剪贴板内容,拿到取件码;输入取件码,获得剪贴板内容。再简单不过了!所以,我也不用考虑那么多复杂的东西,什么认证、安全、高并发……小脑袋要爆炸!

确认架构

这是一个小工具,用不着我动不动Spring Boot那一套,而且Spring boot本身就很重!还是拿起了拿手的Flask框架,外加一个Redis,搞定!

前端的话,别搞Vue项目了,直接原生的来一套!关键是时间就那么一丢丢,能用魔法尽量用魔法。需要注意的是:前端的js文件,能用CDN就用CDN,给服务器节省一点流量。

代码设计

算起来逻辑还是很简单的,shigen直接开干了!

项目的整体结构

项目的整体结构如图所示:

项目结构

算得上是一个简简单单的小demo了。

后端代码

这里只展示核心的代码:

from datetime import datetime
from app import app, redis_client
from flask import jsonify, render_template, request

REDIS_KEY_PREFIX = 'clip:'
REDIS_KEY_EXPIRE_SES = 3600 * 10


def format_current_time(format='%m%d%H%M%S'):
    """
    默认格式化当前时间为 'MMDDhhmmss'
    :return: 格式化后的时间字符串
    """
    current_time = datetime.now()
    formatted_time = current_time.strftime(format)
    return formatted_time


@app.route('/')
def index():
    return render_template('index.html')


@app.route('/new', methods=['POST'])
def clipboard():
    data = request.form['data']
    # 将数据存储到 Redis 中
    tms = format_current_time()
    key = REDIS_KEY_PREFIX + tms
    redis_client.set(key, data, REDIS_KEY_EXPIRE_SES)
    return jsonify({
   
   'data': tms, 'success': True})


@app.route('/get', methods=['GET'])
def get():
    tms = request.args.get('code')
    key = REDIS_KEY_PREFIX + tms
    value = redis_client.get(key)
    if not value:
        return jsonify({
   
   'data': None, 'success': False})
    else:
        return jsonify({
   
   'data': value, 'success': True})

前端代码

    <script>
        $(document).ready(function() {
   
   
            // 保存剪贴板内容
            $('#save-btn').click(function() {
   
   
                var data = $('#new-data').val();
                $.post('/new', {
   
   data: data}, function(response) {
   
   
                    console.log(response);
                    showSuccessMessage('Your clipboard saved successfully');
                    $('#new-data').val(response.data);
                    $('#save-btn').attr('disabled', true);
                });
            });

            // 提取剪贴板内容
            $('#extract-code').change(function() {
   
   
                var code = $(this).val();
                $.get('/get', {
   
   code: code}, function(response) {
   
   
                    $('#extracted-data').val(response.data);
                });
            });

            // 复制剪贴板内容
            $('#copy-btn').click(function() {
   
   
                var textarea = document.getElementById('extracted-data');
                textarea.select();
                document.execCommand('copy');
                showSuccessMessage('Copied to clipboard!');
            });

            // 显示复制成功提示消息
            function showSuccessMessage(text) {
   
   
                var message = $('#alert-message');
                message.text(text).fadeIn(300).delay(1500).fadeOut(400);
            }
        });
    </script>

完整的代码,可参考shigen的GitHub

服务部署

最后就是服务的部署了,shigen部署在了自己的腾讯云服务器上。一切很是顺利,基本山没有遇到大的问题:

nohup python3 run.py > app.log 2>&1 &

服务部署

整个过程也放在了shigen的哔哩哔哩上,感兴趣的伙伴,欢迎体验。

与shigen一起,每天不一样!

目录
相关文章
|
Ubuntu Linux C语言
还在用Alpine作为你Docker的Python开发基础镜像?其实Ubuntu更好一点
一般情况下,当你想为你的Python开发环境选择一个基础镜像时,大多数人都会选择Alpine,为什么?因为它太小了,仅仅只有 5 MB 左右(对比 Ubuntu 系列镜像接近 100 MB),但事实的真相是,我们选择基础镜像并不是为了体验一下Python语法而已,在此基础上,我们需要调试和安装各种扩展,可能会安装很多三方依赖,甚至预设更多服务,在这种环境下,Alpine就并非是一个很好的选择了,本次我们就来分别在Alpine和Ubuntu上来体验一下安装和编译Python的区别。
还在用Alpine作为你Docker的Python开发基础镜像?其实Ubuntu更好一点
|
Windows
关于:未能加载文件或程序集“ICSharpCode.SharpZipLib”或它的某一个依赖项异常的解决方案
关于:未能加载文件或程序集“ICSharpCode.SharpZipLib”或它的某一个依赖项异常的解决方案
1245 0
|
3月前
|
人工智能 数据安全/隐私保护
还在搜 CTF 题库?AiPy本地 AI 助手,一句话处理100 + 题表格题目,秒答理论题超高效
CTF赛前搜题太痛苦?题库杂乱难找,考点难梳理?试试Aipy本地AI助手,秒速检索、分类、答题,准确率100%。一句话指令“回答桌面questions.csv”,高效备战不慌张,赛前冲刺更轻松!
|
8月前
|
前端开发 JavaScript 安全
|
SQL Java Scala
flink-cdc SQL Server op 字段如何获取?
Flink CDC 是 Apache Flink 的组件,用于捕获数据库变更事件。对 SQL Server,通过 Debezium 连接器支持变更数据捕获。`op` 字段标识操作类型(INSERT、UPDATE、DELETE)。配置包括添加依赖及设定 Source 连接器,可通过 Flink SQL 或 Java/Scala 完成。示例查询利用 `op` 字段筛选处理变更事件。
600 1
|
存储 弹性计算 Apache
阿里云经济型e实例测评报告
阿里云经济型e实例是一款面向个人开发者、学生和小微企业的入门级云服务器。
148741 14
|
小程序 API
小程序背景音乐及音频播放demo(copy直接使用~)
小程序背景音乐及音频播放demo(copy直接使用~)
663 0
小程序背景音乐及音频播放demo(copy直接使用~)
|
JavaScript 网络安全 虚拟化
Grafana 中,可以使用以下参数来限制用户对面板参数的修改
在 Grafana 中,可以使用以下参数来限制用户对面板参数的修改: 1. `kiosk`:如上所述,该参数可用于启用全屏模式,以隐藏浏览器的地址栏和工具栏,防止用户访问和修改面板参数。 2. `edit`:该参数用于禁止用户编辑面板。当使用 `edit` 参数时,用户将无法修改面板的布局、查询和其他配置选项。 3. `viewPanel`:该参数用于将面板设置为只读模式,以防止用户编辑面板。当使用 `viewPanel` 参数时,用户无法修改面板的任何设置,只能查看面板的内容。 这些参数可以单独使用,也可以同时使用,以提供更严格的限制。要使用这些参数,只需将它们添加到 Grafana
1359 0