Software:Clipboard (computing)

From HandWiki
Revision as of 11:32, 9 February 2024 by Steve Marsio (talk | contribs) (over-write)
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)
Short description: Data storage used to support copy and paste operations

The clipboard is a buffer that some operating systems provide for short-term storage and transfer within and between application programs. The clipboard is usually temporary and unnamed, and its contents reside in the computer's RAM.[1]

The clipboard provides an application programming interface by which programs can specify cut, copy and paste operations. It is left to the program to define methods for the user to command these operations, which may include keybindings and menu selections. When an element is copied or cut, the clipboard must store enough information to enable a sensible result no matter where the element is pasted. Application programs may extend the clipboard functions that the operating system provides. A clipboard manager may give the user additional control over the clipboard. Specific clipboard semantics vary among operating systems, can also vary between versions of the same system, and can sometimes be changed by programs and by user preferences.

Windows, Linux and macOS support a single clipboard transaction.[2][3]

History

Clipboards as buffers for small text snippets were first used by Pentti Kanerva when he used it to store deleted texts in order to restore them.[4] Since one could delete a text in one place and restore it in another, the term "delete" wasn't what one would expect in this case. Larry Tesler renamed this in 1973 as cut, copy, and paste and coined the term "clipboard" for this buffer, since these techniques need a clipboard for temporary saving the copied or cut data.[5]

Data formats

Applications communicate through the clipboard by providing either serialized representations of an object, or a promise (for larger objects).[6] In some circumstances, the transfer of certain common data formats may be achieved opaquely through the use of an abstract factory; for example, Mac OS X uses a class called NSImage to provide access to image data stored on the clipboard, though the actual format of the image data backing the object is hidden. The sending and receiving application negotiate the formats which can be transferred in between them, oftentimes with the active GUI widget responsible for providing acceptable type transformations. The pasteboard allows for transfer of common items such as URLs, colors, images, strings, attributed strings (Rich text), and sounds. The operating system and GUI toolkit may provide some common conversions, for example converting from rich text to plain text and vice versa. Various type identifiers for data transfer are supported by modern operating systems, which may automatically provide acceptable mappings between type systems, such as between MIME and Uniform Type Identifier.[7][8]

Computer security

Clipboard hijacking is an exploit in which a person's clipboard's content is replaced by malicious data, such as a link to a malicious web site.[9] While some security-holes were patched, JavaScript can still be used to modify clipboard content via an attack dubbed 'pastejacking'.[10][11] Dylan Ayrey who developed the attack set up a website that demonstrates how this exploit can be used to trick a user into running commands they didn't want to run.[12]

There have been exploits where web pages grab clipboard data. In early 2013 researchers exposed risks stemming from Android-based password managers and documented how passwords in 21 of the most popular of these apps could be accessed by any other app on an Android device including those with extremely low-level privileges.[13] Joe Siegrist notes that this is an "OS-level issue that impacts everything running on Android".[14][1]

Clipboard management and extensions

Glipper, an example of a clipboard management program

Clipboard manager extensions add functionality to the integrated clipboard functions of an operating system. They are applications that enable the user to manipulate the clipboard. On platforms such as Linux that use multiple incompatible GUI toolkits, clipboard managers are often used to transfer data between applications using different such frameworks.

When a clipboard manager provides multiple cut and paste transactions, the clipboard is treated as a stack or scrap book, with new cuts and copies being placed on a list of recent transactions. The standard paste operation copies the most recent transaction, while specialized pastes provide access to the other stored transactions. These managers generally also provide a window that displays the transaction history and allows the user to select earlier copies, edit them, change their format and even search amongst them.

Since most operating systems (e.g. Windows, macOS, Linux, X11, Android, iOS) do not save the clipboard contents to any persistent storage – when a user logs out or reboots the system the clipboard contents are deleted – an added functionality is to save the clipboard persistently. Another example is making the local clipboard work with online applications by saving the clipboard data to the online location upon a copy or cut event, making this data available to online applications for pasting. Clipboard managers can also serve as tools to overcome the limitation of software not supporting copying and pasting (for example, while logging into remote Windows server, one cannot copy and paste their user name and password).

Operating system-specific clipboards

AmigaOS

The Amiga operating system uses 256 units, so one has multiple clipboards at the same time.[15]

Android

Android provides a clipboard that can hold up to one clip object and is accessible system-wide. Simple text is stored directly in the clipboard; complex data are stored by reference. The clip object has one of three formats: text string, URI object, or intent.[16]

To interact with the clipboard, an app uses the class ClipboardManager[17] and system calls to cut, copy, and paste objects.

In Android 8.0, the clipboard first appears in the user interface: In a situation where the user prepares to paste from the clipboard, a "Clipboard" option appears that gives the user access to many objects copied or cut to the clipboard in the past. Apart from that, and in earlier versions, the user has no access to the clipboard except in apps that make it available to the user.

iOS

The clipboard is called "pasteboard" in iOS similar to OS X. Apps on this operating system can create additional pasteboards, called instances of the UIPasteboard class, which can be public or private. One instance can hold a single item or multiple items in different formats.[18]

The formats are identified by Uniform Type Identifiers (UTI).[19]

The data contained in the pasteboard cannot be accessed via the GUI but only from the system and applications

macOS

The clipboard in macOS holds one item in multiple available formats.

The contents of the clipboard can be viewed by selecting the Show Clipboard menu item from the Finder's Edit menu. The raw data and the stored formats can be seen using the ClipboardViewer.[20]

Using the following commands the clipboard can be accessed from the command line:[21][22]

$ # to copy data into the clipboard:
$ echo 'hello world' | pbcopy
$ # to paste from the clipboard:
$ pbpaste
hello world

Microsoft Windows and ReactOS

clip
ReactOS-0.4.13 clip command 667x434.png
The ReactOS clip command
Developer(s)Microsoft, ReactOS Contributors
Operating systemWindows, ReactOS
TypeCommand
LicenseWindows: Proprietary commercial software
ReactOS: GNU General Public License
Websitedocs.microsoft.com/en-us/windows-server/administration/windows-commands/clip

The clipboard in Microsoft Windows and ReactOS holds one item in multiple available formats.

Every item has at least one clipboard format, but can have different types of format of the same data. The three different types of possible formats are:[23]

  • standard formats[24] (e.g. CF_BITMAP, or CF_UNICODETEXT),
  • registered formats[25] (e.g. CF_HTML)
  • private formats for internal use

Up to and including Windows XP the clipboard could be accessed via the ClipBook Viewer application.[26] In newer versions of Windows the content can be accessed via clipboard managers.

Data can be stored to the Windows[27] and ReactOS[28] clipboard via command line using the clip command:[29]

$ # to paste the content of a folder to the clipboard:
$ dir | clip

The clipboard can also be accessed via PowerShell:[30][31]

# to paste the content of a directory to the clipboard
Set-Clipboard -Path "C:\directory\"
# to get the content of the clipboard
Get-Clipboard

Windows 10 and Windows 11 include the Clipboard application, allowing for the storage of multiple text-based clipboard items. It can be accessed by pressing Windows+V.

X Window System

The X Window System commonly used on Unix and Linux systems provides three clipboards, which are named "CLIPBOARD", "PRIMARY" and "SECONDARY".[32] The usage and handling of various selections is not standardized. However, most modern toolkits and desktop environments, such as GNOME or KDE, follow a widely accepted convention, outlined in the freedesktop.org specification.[33] One selection, CLIPBOARD, is used for traditional clipboard semantics, with shortcuts identical to Windows. Another selection, PRIMARY, is an X11-specific mechanism. Data is "copied" immediately upon highlighting and pasted with the third (middle) mouse button.[34] This copied data is usually separated from the CLIPBOARD selection and does not change its contents.[35] SECONDARY was planned as an alternative to PRIMARY but is only used inconsistently.[32]

There are two command line tools (xsel and xclip) which can access the clipboard:[36]

$ # to paste standard output to the clipboard using xclip
$ echo text | xclip -in -selection clipboard
$ # to paste standard output to the clipboard using xsel
$ echo text | xsel --clipboard

The main difference to OS X and Windows is that no data is actually stored in the CLIPBOARD-clipboard but only the reference to the copied or cut data. The application claims the ownership of the CLIPBOARD selection and communicates its ownership to the X Server.[34] When pasting this data, the data and its available formats are requested from the application that owns the CLIPBOARD selection.[37]

APIs

Applications can access the clipboard or its data via APIs.

JavaScript

In JavaScript a class which detects changes in the users clipboard data (ClipboardEvent)[38] and functions to alter the content of a clipboard or read from it (clipboardData.getData(), clipboardData.setData())[39] exist, but aren't supported by every browser since altering the clipboard of a user can represent a security issue.

Qt

In Qt a wrapper for every supported platform[40] exists. It provides access to window system clipboards with the use of the class QClipboard. This class facilitates access to common data types by functions.[41] The data type of the element stored in the clipboard is indicated via MIME and MIME data can also be put in the clipboard with help of functions from this class.

See also

References

  1. 1.0 1.1 "What is a Clipboard in Computing? - Definition from Techopedia" (in en). Techopedia.com. https://www.techopedia.com/definition/4646/clipboard. 
  2. Kimmatkar, Sarang B. (2014). "Extending functionalities of default clipboard.". (IJCSIT) International Journal of Computer Science and Information Technologies 5 6. 
  3. Stephens, Rod (2010). Visual Basic 2010 : programmer's reference. Library Genesis. Indianapolis, IN : Wiley Pub., Inc.. ISBN 978-0-470-49983-2. https://archive.org/details/visualbasicprogr00step_709. 
  4. Moggridge, Bill (2007). Designing interactions. Cambridge, Massachusetts: MIT Press. p. 65ff. ISBN 9780262134743. https://archive.org/details/designinginterac00mogg/page/65. 
  5. Larry Tesler. "A User Experience Retrospective". http://www.nomodes.com/Larry_Tesler_Consulting/Retrospective/Pages/CHI_Retrospective.html. 
  6. "Dragging Files". https://developer.apple.com/library/archive/documentation/Cocoa/Conceptual/DragandDrop/Tasks/DraggingFiles.html. 
  7. "NSPasteboard - AppKit | Apple Developer Documentation". https://developer.apple.com/documentation/appkit/nspasteboard. 
  8. "Adopting Uniform Type Identifiers". https://developer.apple.com/library/archive/documentation/FileManagement/Conceptual/understanding_utis/understand_utis.tasks/understand_utis_tasks.html#//apple_ref/doc/uid/TP40001319-CH203-BABHCIAC. 
  9. "What is clipboard hijack attack? - Definition from WhatIs.com". http://whatis.techtarget.com/definition/clipboard-hijack-attack. 
  10. Chirgwin, Richard. "Pastejack attack turns your clipboard into a threat". The Register. https://www.theregister.co.uk/2016/05/25/pastejack_attack_turns_your_clipboard_into_a_vector/. 
  11. "Researcher warns of 'pastejacking' hack attacks targeting users' clipboards". Graham Cluley. 26 May 2016. https://www.grahamcluley.com/researcher-warns-pastejacking-hack-attacks-targeting-users-clipboards/. 
  12. "dxa4481/Pastejacking". https://github.com/dxa4481/Pastejacking. 
  13. Fahl, Sascha; Harbach, Marian; Oltrogge, Marten; Muders, Thomas; Smith, Matthew (2013). "Hey, You, Get Off of My Clipboard". Financial Cryptography and Data Security. Lecture Notes in Computer Science. 7859. pp. 144–161. doi:10.1007/978-3-642-39884-1_12. ISBN 978-3-642-39883-4. http://fc13.ifca.ai/proc/4-2.pdf. Retrieved 4 January 2017. 
  14. "Using a password manager on Android? It may be wide open to sniffing attacks". Ars Technica. 21 November 2014. https://arstechnica.com/security/2014/11/using-a-password-manager-on-android-it-may-be-wide-open-to-sniffing-attacks/. 
  15. "Clipboard Device - AmigaOS Documentation Wiki" (in en). http://wiki.amigaos.net/wiki/Clipboard_Device#Multiple_Clips. 
  16. "Copy and Paste | Android Developers" (in en). https://developer.android.com/guide/topics/text/copy-paste.html. 
  17. "ClipboardManager | Android Developers" (in en). https://developer.android.com/reference/android/text/ClipboardManager.html. 
  18. "Pasteboard" (in en). https://developer.apple.com/library/content/documentation/General/Conceptual/Devpedia-CocoaApp/Pasteboard.html. 
  19. "Uniform Type Identifier" (in en). https://developer.apple.com/library/content/documentation/General/Conceptual/DevPedia-CocoaCore/UniformTypeIdentifier.html#//apple_ref/doc/uid/TP40008195-CH60. 
  20. "ClipboardViewer" (in en). https://developer.apple.com/library/content/samplecode/ClipboardViewer/Introduction/Intro.html. 
  21. "Copy to clipboard from terminal in OS X". rogeriopvl.com. http://blog.rogeriopvl.com/archives/copy-to-clipboard-from-terminal-in-os-x/. 
  22. "pbcopy(1) Mac OS X Manual Page". apple.com. https://developer.apple.com/library/mac/documentation/Darwin/Reference/ManPages/man1/pbcopy.1.html. 
  23. "Clipboard Formats (Windows)" (in en). https://msdn.microsoft.com/en-us/library/windows/desktop/ms649013(v=vs.85).aspx. 
  24. "Standard Clipboard Formats (Windows)" (in en). https://msdn.microsoft.com/en-us/library/windows/desktop/ff729168(v=vs.85).aspx. 
  25. "HTML Clipboard Format (Internet Explorer)" (in en). https://msdn.microsoft.com/en-us/library/aa767917(VS.85).aspx. 
  26. "View & Manage Clipboard In Windows 10/8/7" (in en-US). The Windows Club. 2013-04-12. http://www.thewindowsclub.com/windows-clipboard-manager-viewer. 
  27. "clip | Microsoft Docs". Docs.microsoft.com. 2017-10-16. https://docs.microsoft.com/en-us/windows-server/administration/windows-commands/clip. 
  28. "reactos/base/applications/cmdutils/clip at master · reactos/reactos · GitHub". Github.com. https://github.com/reactos/reactos/tree/master/base/applications/cmdutils/clip. 
  29. "How to Copy Command Line Output to the Windows Clipboard" (in en-US). https://www.labnol.org/software/copy-command-output-to-clipboard/2506/. 
  30. sdwheeler. "Get-Clipboard (Microsoft.PowerShell.Management)" (in en-us). https://docs.microsoft.com/en-us/powershell/module/microsoft.powershell.management/get-clipboard?view=powershell-5.1. 
  31. sdwheeler. "Set-Clipboard (Microsoft.PowerShell.Management)" (in en-us). https://docs.microsoft.com/en-us/powershell/module/microsoft.powershell.management/set-clipboard?view=powershell-5.1. 
  32. 32.0 32.1 "Clipboard - ArchWiki" (in en). https://wiki.archlinux.org/index.php/Clipboard. 
  33. "clipboards-spec". freedesktop.org. http://www.freedesktop.org/wiki/Specifications/clipboards-spec/. 
  34. 34.0 34.1 "Copy & Paste, Drag & Drop [MI Wiki"] (in de). https://wiki.mi.ur.de/lehre/ss17/itt/copyandpaste. 
  35. "gnu.org" (in en). https://www.gnu.org/software/emacs/manual/html_node/emacs/Primary-Selection.html. 
  36. "Copying and Pasting To and From the System Clipboard On The Command Line — Fernando Basso" (in en). https://fernandobasso.github.io/en/shell/copy-paste-from-command-line-xclip-xsel-clipboard.html#about-xclip-and-xsel. 
  37. "X Selections, X Cut Buffers, and Emacs Kill Rings". https://www.jwz.org/doc/x-cut-and-paste.html. 
  38. "Clipboard API and events – ClipboardEvent". https://www.w3.org/TR/clipboard-apis/#clipboard-events-and-interfaces. 
  39. "Clipboard API and events – Synchronous Clipboard API" (in en). https://www.w3.org/TR/clipboard-apis/#sync-clipboard-api. 
  40. "platforms\plugins\src - qt/qtbase.git - Qt Base (Core, Gui, Widgets, Network, ...)" (in en). http://code.qt.io/cgit/qt/qtbase.git/tree/src/plugins/platforms. 
  41. "QClipboard Class | Qt GUI 5.10" (in en). http://doc.qt.io/qt-5/qclipboard.html. 

Further reading

External links