Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >跨浏览器的剪贴板访问解决方案

跨浏览器的剪贴板访问解决方案

作者头像
菩提树下的杨过
发布于 2018-01-24 02:35:12
发布于 2018-01-24 02:35:12
2K00
代码可运行
举报
运行总次数:0
代码可运行

在IE中,JS可以直接访问剪贴板,但是firefox,chrome等其它"高级"浏览器,就没这么幸运了。网上流传的所谓兼容firefox/IE的剪贴板访问javascript代码,都是N年前的往事了。

根据http://mozilla.com.cn/post/49413/ 上的说法:

----------------------------------

火狐不允许网页操作用户的剪切板,因为有安全问题,网页可能盗用你复制的密码等等。

以前可以通过修改设置提权,允许网页获得高权限,操作剪切板,目前火狐已经取消了这个接口。不再允许,所以修改了设置也无效,目前还是自己通过快捷键复制吧。

----------------------------------

看来通过"纯js"来达到“一统天下”,至少在剪贴板这一问题上,已经是不可能了.

幸好,我们还有Flash/Silverlight这一类插件可以解决这一问题。Flash和Silverlight都内置了剪贴板的访问接口,zClip就是利用flash来解决这一问题的免费项目:

http://www.steamdev.com/zclip/

其原理是在目标元素上叠加一个透明的flash,点击目标元素时,其实就是把flash激活了,然后通过flash内部的剪贴板访问接口实现 复制到剪贴板 功能.

整个flash 1K + js 7K,一共约8K大小,已经能圆满解决该问题。

但是事情并没有就此止步,如果你还想进一步减少附加文件的大小,或者检验"自己动手,丰衣足食"的乐趣,下面给出了Silverlight的解决方案:

一、创建一个新Silverliight项目,里面就放一个MainPage,然后在MainPage.xaml.cs里,把对剪贴板的读写方法暴露出来

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
using System;
using System.Windows;
using System.Windows.Browser;
using System.Windows.Controls;

namespace ClipboardTools
{
    public partial class MainPage : UserControl
    {
        public MainPage()
        {
            InitializeComponent();
        }

        /// <summary>
        /// 设置剪贴板文本
        /// </summary>
        /// <param name="text"></param>
        /// <returns></returns>
        [ScriptableMember()]
        public bool SetText(string text)
        {
            try
            {
                Clipboard.SetText(text);
                return true;
            }
            catch (Exception e)
            {
                System.Diagnostics.Debug.WriteLine(e.Message);
                return false;
            }
        }

        /// <summary>
        /// 获取剪贴板文本
        /// </summary>
        /// <returns></returns>
        [ScriptableMember()]
        public string GetText()
        {
            try
            {
                return Clipboard.GetText();
               
            }
            catch (Exception e)
            {
                System.Diagnostics.Debug.WriteLine(e.Message);
                return "";
            }
        }


        /// <summary>
        /// 测试剪贴板里是否有内容
        /// </summary>
        /// <returns></returns>
        [ScriptableMember()]
        public bool ContainsText()
        {
            return Clipboard.ContainsText();
        }
       
    }
}

 然后在App.xaml.cs里注册一下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
        private void Application_Startup(object sender, StartupEventArgs e)
        {
            MainPage mp = new MainPage();
            this.RootVisual = mp;
            HtmlPage.RegisterScriptableObject("JsHandler", mp);
        }

 如果是Silverlight5,注册把下面这个选项勾上,以允许一些需要高权限的操作在浏览器中运行

二、web页面上使用代码示例:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title>Clipboard</title>
    <style type="text/css">
        html, body { height: 100%; overflow: auto;margin: 0;padding:0 }
        #silverlightControlHost { height: 0px;width: 0px; }
        button{ width: 75px;margin-left:5px}
    </style>
</head>
<body>
    <div id="silverlightControlHost">
        <object data="data:application/x-silverlight-2," type="application/x-silverlight-2"
            width="100%" height="100%">
            <param name="source" value="ClientBin/Clipboard.xap" />
            <param name="onError" value="onSilverlightError" />
            <param name="background" value="white" />
            <param name="minRuntimeVersion" value="5.0.61118.0" />
            <param name="onLoad" value="SilverlightLoaded" />
            <param name="autoUpgrade" value="false" />
        </object>
      </div>
    <script type="text/javascript">
      var slCtl = null;
        function SilverlightLoaded(sender) {
            slCtl = sender.getHost();
        }

        function setText(text) {
            if (slCtl != null) {
                var s = slCtl.Content.JsHandler.SetText(text);
                if (s) {
                    alert(text + "\n\n已复制到剪贴板!");
                    return true;
                } else {
                    alert("复制到剪贴板失败!");
                    return true;
                }
            }
            alert("Silverlight加载失败!");
            return false;
        }


        function getText() {
            if (slCtl != null) {
                return slCtl.Content.JsHandler.GetText();
            }
            return "";
        }

        
    </script>
    <div style="margin:10px">
        <input type="text" id="txtSrc" value="Sample Text"/>
        <button id="btnCopy" onclick="setText(document.getElementById('txtSrc').value)">copy</button>
        <button id="btnSet" onclick="alert(getText())">get</button>
    </div>
</body>
</html>

silverlight编译后的xap约4K,js代码不足1K,一共5k左右 

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2013-07-17 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
万恶的剪贴板==》为存储而生
近几天逆天经常大量复制粘贴一些图文信息,在某些特定的场合,图片都是无法直接粘贴进去的,就比如博客园的编辑器。 源码:https://github.com/dunitian/DNTLive/tree/master/Software/万恶剪贴板 要弄个什么还要把word里面的图片或者网上的图片先弄出来,这是多么的蛋疼啊~ 于是就有了万恶的剪贴板==》为存储而生 其实是个很简单的功能点==》稍微说下核心代码 获取文本内容:var dataStr = Clipboard.GetText(); 获取单个图片:var
逸鹏
2018/04/10
6670
使用ZeroClipboard解决跨浏览器复制到剪贴板的问题
Zero Clipboard的实现原理 Zero Clipboard 利用透明的Flash让其漂浮在复制按钮之上,这样其实点击的不是按钮而是 Flash ,这样将需要的内容传入Flash,再通过Flash的复制功能把传入的内容复制到剪贴板。 Zero Clipboard的安装方法 首先需要下载 Zero Clipboard的压缩包,解压后把文件夹中两个文件:ZeroClipboard.js 和 ZeroClipboard.swf 放入到你的项目中。 然后把在你要使用复制功能的页面中引入Zero Clipbo
磊哥
2018/05/08
1.6K0
JavaScript操作剪贴板
在网页中一般是不允许访问剪贴板内容的,因为这样存在着很大的安全隐患。在IE和FireFox中剪贴板的访问是可控的,但是在Opera、Chrome、Safari浏览器中是不允许访问的,这样就产生了浏览器兼容的问题。
恋喵大鲤鱼
2018/08/03
3.1K0
Android 系统剪贴板的使用 - 复制、获取和清空
ClipboardManager: 表示一个剪贴板 ClipData: 剪贴板中保存的所有剪贴数据集(剪贴板可同时复制/保存多条多种数据条目) ClipData.Item: 剪贴数据集中的一个数据条目 复制内容 /** * 实现文本复制功能 * * @param content 复制的文本 */ public static void copy(String content) { if (!TextUtils.isEmpty(content)) { // 得到剪贴板管理器
Jingbin
2019/04/25
6.2K0
ZeroClipboard实现多个浏览器兼容的复制文本到剪贴板的功能
ZeroClipboard实现多个浏览器兼容的复制文本到剪贴板的功能 本人在项目中使用的js版本。为了方便大家下载。直接粘贴代码给大家看。版本是1.2.0 /*! * ZeroClipboard * The ZeroClipboard library provides an easy way to copy text to the clipboard using an invisible Adobe Flash movie and a JavaScript interface. * Copyright (c
小帅丶
2018/03/12
1.4K0
通过JS实现剪贴板操作
在网上找到很多种方法,ZeroClipboard.js、clipboard.js 插件等,但是都没有办法解决本人项目中的问题,最后发现可以通过 navigator 对象得到 clipboard,进行剪切板操作
赤蓝紫
2023/01/02
2.7K0
通过JS实现剪贴板操作
剪贴板被占用导致应用使用剪贴板拷贝内容失败抛出 COMException 0x800401D0 错误
本文记录某些软件,例如 向日葵远程控制 软件占用剪贴板,导致 WPF 应用使用剪贴板拷贝内容和设置剪贴板时,抛出 System.Runtime.InteropServices.COMException (0x800401D0): OpenClipboard 失败 (0x800401D0 (CLIPBRD_E_CANT_OPEN)) 异常
林德熙
2023/04/07
1.7K0
逆天通用水印扩展篇~新增剪贴板系列的功能和手动配置,卸除原基础不常用的功能
常用技能:http://www.cnblogs.com/dunitian/p/4822808.html#skill 逆天博客:http://dnt.dkil.net 逆天通用水印支持Winform,WPF,Web,WP,Win10。支持位置选择(9个位置 ==》[X]):http://www.cnblogs.com/dunitian/p/4939369.html 本次添加了一些新东西,比如剪贴板之类的水印操作。完善了部分功能(比如文件过滤,非Bitmap图片的处理,以及一些其他玩意等待你的发现) 先贴下新增
逸鹏
2018/04/10
6610
逆天通用水印扩展篇~新增剪贴板系列的功能和手动配置,卸除原基础不常用的功能
Canvas简历编辑器-我的剪贴板里究竟有什么数据
在这里我们先来聊聊我们究竟应该如何操作剪贴板,也就是我们在浏览器的复制粘贴事件,并且在此基础上聊聊我们在Canvas图形编辑器中应该如何控制焦点以及如何实现复制粘贴行为。
WindRunnerMax
2024/05/08
1330
将内容复制到剪切板兼容主流浏览器的解决方案
对于其他浏览器,google了半天,发现不太好搞,比如 对于firefox,要让网站的js有使用剪切板的权限是要用户授权的 http://kb.mozillazine.org/Granting_JavaScript_access_to_the_clipboard
前端GoGoGo
2018/08/27
1.3K0
使用 JS 剪贴板 API
使用 JS 剪贴板 API 现在的状况 一般情况下我们会在网页上使用大量的3复制粘贴的操作。 但是也可以看到在 360文库中的禁止复制粘贴或者知乎的那样复制粘贴的时候会自动带有一段文字的版权声明。 C
西南_张家辉
2021/02/02
4.3K0
Javascript Tip(1) 操作剪贴板
javascript可以轻松操作客户端剪贴板内容,不过只适用IE5以上浏览器javascript可JavaScript
Java架构师必看
2021/03/22
6510
Silverlight:分包下载及SEO优化方案
一、按模块分包 一般大型的Silverlight应用,都会按模块分解成多个silverlight project,编译后就有多个xap包,然后在需要用到的场景按需加载。我近期开发的这个项目不需要全站Silverlight,而是aspx混合silverlight,说得更白点,就是把相应的子模块xap包嵌入aspx. 这样分包就简单多了:直接用js控制dom元素,修改object元素中的source,动态设置成不同的xap即可实现无刷新的加载不同模块。(这比网上主流的方式:用WebClient动态下载xap包,
菩提树下的杨过
2018/01/23
8300
JavaScript 剪贴板 Clipboard 的那些事儿!
携手创作,共同成长!这是我参与「掘金日新计划 · 8 月更文挑战」的第19天,点击查看活动详情
掘金安东尼
2022/09/22
1.4K0
JavaScript 剪贴板 Clipboard 的那些事儿!
silverlight/xap如何接收参数?
silverlight不能象flash一样,直接以类似xxx.xap?name=123的方式传递参数,而是要用另一种方式实现: html部分(注意高亮部分): <object data="data:
菩提树下的杨过
2018/01/23
1.1K0
开源一款剪贴板跨设备共享工具
昨天遇到了一个很棘手的问题:我的手机剪贴板需要同步到另外的两台设备上。遗憾的是手机上并没有安装相同的通讯软件。用网上免费的剪贴板共享工具吧,方便是方便,但是觉得还是不安全,关键是不能实现特定的需求。我很享受DIY的过程,于是思索一下,我觉得我可以自己做出来,还能做到局域网下的剪贴板跨设备共享,毕竟我也曾有过成功的案例:开源一个局域网文件共享工具。于是说干就干。
shigen
2024/03/31
3090
Salesforce LWC学习(二十八) 复制内容到系统剪贴板(clipboard)
https://developer.mozilla.org/zh-CN/docs/Mozilla/Add-ons/WebExtensions/Interact_with_the_clipboard
Zero-Zhang
2020/12/16
1.1K0
Salesforce LWC学习(二十八) 复制内容到系统剪贴板(clipboard)
【译】JavaScript实现文字剪贴板&amp;React版本
目录 怎么使用JavaScript实现一个剪贴 上面的方法不是很完美我们优化一下 思考一个问题 使用react和typescript重写和优化一下 如何使用copyme 原文参考 写在最前面 有一个简单的需求,用户需要快捷的复制一些相关的信息,然后进行下一步信息的填写。前端这里需要做一个剪贴板方便用户体验。想直接参考 react 使用的可以看 使用react和typescript改写和优化一下 大概设计如下,有多条信息,然后用户可以点击右边的复制 icon 进行快捷的复制。 怎么使用JavaScr
西南_张家辉
2022/09/16
8450
【译】JavaScript实现文字剪贴板&amp;React版本
《大胖 • 小课》- 拖拽和剪贴板文件上传
这是《大胖小课》栏目的专题一《说说文件上传那些事儿》的第5节-《实现文件拖拽和剪贴板上传》
zz_jesse
2020/03/17
9650
win10 UWP 剪贴板 Clipboard 设置文本获取文本获取图片获取文件
win10 UWP 剪贴板 Clipboard使用Windows.ApplicationModel.DataTransfer.Clipboard,提供 UWP 与其他程序的通信,目标程序可以使用 UWP 程序也可以使用以前的程序。
林德熙
2018/09/18
2.1K0
推荐阅读
相关推荐
万恶的剪贴板==》为存储而生
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验