项目js java 实现自动复制粘贴 亲测有效

项目js java 实现自动复制粘贴 亲测有效

项目中有需求 — 点击按钮时触发事件 —把内容自动复制到剪切板 — 粘贴给好友

查了很多资料 下面两种方法 亲测有效 :

第一种前台 纯js代码实现
(可以实现前后端分离 服务器端剪切板)

var aux = document.createElement("input"); 
aux.setAttribute("value", 这里写想要复制的值); 
document.body.appendChild(aux); 
aux.select();
document.execCommand("copy"); 
document.body.removeChild(aux);						
alert("复制成功!");

第二种后台 用Java Clipboard 实现
(注意:只能针对本地剪切板)

package common.util;

import java.awt.Toolkit;
import java.awt.datatransfer.Clipboard;
import java.awt.datatransfer.DataFlavor;
import java.awt.datatransfer.StringSelection;
import java.awt.datatransfer.Transferable;

public class ClipboardUtil {
	public static void main(String[] args) throws InterruptedException {
	     //测试
    }

    /**
     * 把文本设置到剪贴板(复制)
     */
    public static void SaveClipboardString(String text) {
    	 StringSelection stsel = new StringSelection(text);
	      Toolkit.getDefaultToolkit().getSystemClipboard().setContents(stsel, stsel);
    }
    
    /**
     * 把文本设置到剪贴板(复制)
     */
    public static void setClipboardString(String text) {
        // 获取系统剪贴板
        Clipboard clipboard = Toolkit.getDefaultToolkit().getSystemClipboard();
        // 封装文本内容
        Transferable trans = new StringSelection(text);
        // 把文本内容设置到系统剪贴板
        clipboard.setContents(trans, null);
    }

    /**
     * 从剪贴板中获取文本(粘贴)
     */
    public static String getClipboardString() {
        // 获取系统剪贴板
        Clipboard clipboard = Toolkit.getDefaultToolkit().getSystemClipboard();

        // 获取剪贴板中的内容
        Transferable trans = clipboard.getContents(null);

        if (trans != null) {
            // 判断剪贴板中的内容是否支持文本
            if (trans.isDataFlavorSupported(DataFlavor.stringFlavor)) {
                try {
                    // 获取剪贴板中的文本内容
                    String text = (String) trans.getTransferData(DataFlavor.stringFlavor);
                    return text;
                } catch (Exception e) {
                    e.printStackTrace();
                }
            }
        }

        return null;
    }

}

之后去前台调用 SaveClipboardString 方法即可!

Playwright 是一个自动化测试库,它支持多种浏览器,包括 Chromium、Firefox 和 WebKit。使用 Playwright,你可以编写脚本来自动化 Web 浏览器中的各种任务,例如导航、点击按钮、填写表单、截图和更多。Playwright 支持 Python、JavaScript、Java 和 C# 等编程语言。 在 Python 中使用 Playwright 编写复制粘贴的脚本,你需要首先安装 Playwright 和对应浏览器的驱动程序。可以通过 pip 来安装 Python 的 Playwright 库。以下是一个简单的 Python 脚本示例,演示了如何使用 Playwright 进行复制粘贴操作: ```python from playwright.sync_api import sync_playwright with sync_playwright() as p: browser = p.chromium.launch(headless=False) # 启动浏览器实例 page = browser.new_page() # 打开新页面 page.goto("https://www.example.com") # 访问网页 # 复制页面中某个元素的文本内容 element = page.query_selector('.copy-text') # 假设要复制文本在带有 class 'copy-text' 的元素中 text_to_copy = element.inner_text() # 获取元素的文本内容 # 执行复制操作,需要先聚焦到输入框 input_field = page.query_selector('#input-field') # 假设粘贴的目标输入框的 id 是 'input-field' page.focus(input_field) # 聚焦到输入框 page.keyboard.press("Meta+C") # 使用快捷键复制(Windows 使用 Ctrl+C) # 执行粘贴操作 page.keyboard.press("Meta+V") # 使用快捷键粘贴(Windows 使用 Ctrl+V) # 关闭浏览器 browser.close() ``` 在实际使用中,你需要根据具体的网页元素和需求调整选择器(query_selector)、文本和快捷键操作。另外,Playwright 提供了丰富的 API 来模拟用户交互,这可以使得自动化测试更加灵活和强大。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值