Rounded magnet icon used on The Pirate Bay
The Magnet URI scheme, defines the format of magnet links, a de facto standard for identifying files by their content, via cryptographic hash value) rather than by their location.
Then eDonkey added multiple servers, and ed2k links, plus it was fast back then. Later, Gnutella made it all completely decentralized, including the search. With many client implementations, etc. (EDIT: I forgot WinMX, which had really cool concepts, and was a true expert tool.). ED2k links are a special link format which allow adding a download directly to eMule. These links allow webmasters to offer eMule downloads directly from their web pages and make it very easy to exchange downloads in the network.
Although magnet links can be used in a number of contexts, they are particularly useful in a peer-to-peer file sharing networks because they allow resources to be referred to without the need for a continuously available host, and can be generated by anyone who already has the file, without the need for a central authority to issue them. This makes them popular for use as 'guaranteed' search terms within the file sharing community where anyone can distribute a magnet link to ensure that the resource retrieved by that link is the one intended, regardless of how it is retrieved.
- 3Design
- 3.3Web links to the file
- 4Examples
- 5Features and Clients
History
The standard for Magnet URIs was developed by Bitzi in 2002, partly as a 'vendor- and project-neutral generalization' of the
ed2k:
and freenet:
URI schemes used by eDonkey2000 and Freenet, respectively, and attempts to follow official IETFURI standards as closely as possible.Technical description
Magnet URIs consist of a series of one or more parameters, the order of which is not significant, formatted in the same way as query strings that ordinarily terminate HTTP URLs. The most common parameter is 'xt' ('exact topic'), which is generally a URN formed from the content hash of a particular file, e.g.
This refers to the Hex encoded SHA-1 hash of the file in question. Note that, although a particular file is indicated, an availability search for it must still be carried out by the client application.
Other parameters defined by the draft standard are:
- 'dn' ('display name'): a filename to display to the user, for convenience
- 'kt' ('keyword topic'): a more general search, specifying search terms, rather than a particular file
- 'mt' ('manifest topic'): a URI pointing to a 'manifest', e.g. a list of further items
- application-specific experimental parameters, which must begin 'x.'
The standard also allows for multiple parameters of the same type to be used by appending '.1', '.2', etc. to the parameter name, e.g.:
magnet:?xt.1=urn:sha1:YNCKHTQCWBTRNJIV4WNAE52SJUQCZO5C&xt.2=urn:sha1:TXGCZQTH26NL6OUQAJJPFALHG2LTGBC7
Design
Magnet URIs can contain multiple parameters, in any order, separated from each other by '&'.
- magnet:? xl = [Size in Bytes] & dn = [file name (URL encoded)] & xt = urn: tree: tiger: [ TTHhash (Base32) ]
Parameters
- dn (Display Name) – Filename
- xl (eXact Length) – Size in bytes
- xt (eXact Topic) – URN containing file hash
- as (Acceptable Source) – Web link to the file online
- xs (eXact Source) – P2P link.
- kt (Keyword Topic) – Key words for search
- mt (Manifest Topic) – link to the metafile that contains a list of magneto (MAGMA – MAGnet MAnifest)
- tr (address TRacker) – Tracker URL for BitTorrent downloads
URN, containing hash (xt)
'xt' ('exact topic'): the most important part of a Magnet link, this parameter is used to find and verify the specified files.
- TTH (Tiger Tree Hash)
These hashes are used on Direct Connect and G2 (Gnutella2), among others.
- xt=urn:tree:tiger:[ TTHHash (Base32) ]
- SHA-1 (Secure Hash Algorithm 1)
These hash sums are used on gnutella and G2 (Gnutella2).
- xt=urn:sha1:[ SHA-1Hash (Base32) ]
- BitPrint
Such hash sums consist of an SHA-1 Hash, followed by a TTH Hash, delimited by a point; they are used on gnutella and G2 (Gnutella2). Asphalt 8 airborne hack.
- xt=urn:bitprint:[ SHA-1Hash (Base32) ].[ TTHHash (Base32) ]
- ED2K (eDonkey2000) Hash
These hash sums are used on eDonkey2000.
- xt=urn:ed2k:[ ED2KHash (Hex) ]
- AICH (Advanced Intelligent Corruption Handler)
Not formal URNs for Magnet links, such hash sums are used by eDonkey2000 to restore and control the integrity of downloading and already downloaded files.
- xt=urn:aich:[ aichHash (Base32) ]
- Kazaa Hash
Used on FastTrack, these hash sums are vulnerable to hash collision attacks.
- xt=urn:kzhash:[ KazaaHash (Hex) ]
- BTIH (BitTorrent Info Hash)
These are hex encoded SHA-1 hash sums of the 'info' sections of BitTorrent metafiles as used by BitTorrent to identify downloadable files or sets of files. For backwards compatibility with existing links, clients should also support the Base32 encoded version of the hash.[1]
- xt=urn:btih:[ BitTorrent Info Hash (Hex) ]
Some clients require Base32 of info_hash (Vuze for ex.).
- MD5 (Message Digest 5)
Supported by G2 (Gnutella Peanut Butter), such hashes are vulnerable to hash collision attacks.
- xt=urn:md5:[ MD5Hash (Hex) ]
Web links to the file
There are two types of download links that a Magnet link can include as a direct or backup source.
Normal (as)
'as' ('acceptable source') refers to a direct download from a web server. Regarded as only a fall-back source in case a client is unable to locate and/or download the linked-to file in its supported P2P network(s), most clients treat it equal to the 'xs' token when it comes to priority, and ignore the timeout before contacting 'as' sources denoted by the specs.
- as=[ a web link to the file(URL encoded) ]
P2P (xs)
'xs' ('exact source') is either an HTTP (or HTTPS, FTP, FTPS, etc.) download source for the file pointed to by the Magnet link, the address of a P2P source for the file or the address of a hub (in the case of DC++), by which a client tries to connect directly, asking for the file and/or its sources. This field is commonly used by P2P clients to store the source, and may include the file hash.
- Content-Addressable Web[2] URL
This type of RFC 2168-based link is used by gnutella as well as G2 applications.
Example:
- Link to a DirectConnect hub to find sources for a file
This type of link connects a DirectConnect client immediately to the hub in question.
- xs=dchub://[hub address]:[hub port]
- Reference to a web-based source cache for a file on Gnutella2
In this case, the included link points, not to a client IP or direct source, but to a source cache which stores the IPs of other clients contacting it to download the same file. Once a client connects to the cache, it is served IPs for alternate sources, while its own IP is stored within the cache and forwarded to the next one connecting to the cache. This system operates similar to a BitTorrent tracker.
- xs=http://cache.freebase.be/[ SHA-1hash ]
- Reference to an eD2k source
- xs=ed2kftp://[client address]:[client port]/[ed2k hash]/[file size]/
Manifest (mt)
This is a link to a list of links (see list). Perhaps as a web link..
- mt=http://weblog.foo/all-my-favorites.rss
Ed2k To Magnet Online
..or a URN
- mt=urn:sha1:3I42H3S6NNFQ2MSVX7XZKYAYSCX5QBYJ
Keywords (kt)
This field specifies a string of search keywords to search for in P2P networks.
- kt=joe+blow+mp3
Address tracker (tr)
Tracker URL; used to obtain resources for BitTorrent downloads without a need for DHT support.[1]
- tr=http://example.com/announce
Supplement format (x.)
For experimental and self-complementing informal options, the prefix x followed by a chosen second letter can be used.
- x.[name of the new parameter]=[data of the new parameter (URL encoded)]
Group settings
Multiple files and their URNs, names and hashes in the Magnet link can be included by adding a count number preceded by a dot ('.') to each link parameter.
- magnet:?xt.1=[ URN of the first file]&xt.2=[ URN of the second file]
Examples
Link to a file of zero bytes length
mediawiki-1.15.1.tar.gz
Features and Clients
Parameters:
Clients table
Client | dn | xl | xt | tr | xs | as | kt | mt | Interception[Note 1] | Box[Note 2] |
---|---|---|---|---|---|---|---|---|---|---|
AMule | Yes | Yes | urn:ed2k: | No | Unknown | Unknown | Unknown | Unknown | No | Yes |
ApexDC++ | Yes | Yes | urn:bitprint: | No | Dchub:[Note 3] | Dchub:[Note 3] | No | Unknown | Yes | No |
aria2 | Yes | Unknown | urn:btih: | Yes | Unknown | Unknown | Unknown | Unknown | No | Unknown |
BitComet | Yes | Yes | urn:btih: | Yes | No | No | No | No | Yes | Yes |
Bitflu | Yes | No | urn:btih: | Yes | No | No | No | No | No | No |
Deluge | Yes | No | urn:btih: | Yes | No | No | No | No | Yes | Yes |
FlylinkDC++ | Yes | Yes | urn:bitprint: | No | Dchub:[Note 3] | Dchub:[Note 3] | Yes | Unknown | Yes | No |
gtk-gnutella | Yes | Yes | urn:sha1: | No | http: push: | Yes | Yes | No | No | Yes |
KTorrent | Yes | No | urn:btih: | Yes | No | No | No | No | Yes | Yes |
LimeWire | Yes | Yes | urn:sha1: | No | http: urn:guid: | Unknown | No | No | Yes | Yes |
MiniGet | Yes | No | urn:btih: | Yes | No | No | No | No | Yes | Yes |
µTorrent | Yes | No | urn:btih: | Yes | No | No | No | No | Yes | Yes |
Shareaza | Yes | Yes | urn:bitprint: | Yes [Note 4] | http: ftp: | http: ftp: (Same priority as xs) | Yes | No | Yes | Yes |
Transmission[3][4] | Yes | No | urn:btih: | Yes | No | No | No | No | Yes | Yes |
Vuze | Yes | Yes | urn:btih: | Yes | Yes | No | No | No | Yes | Yes |
Shareaza
This client is able to intercept links from within the web browser and can also handle Magnet links pasted into the search area or the 'Download File or Torrent' dialogue.
aMule 2.2
Unable to intercept Magnet links from within a web browser, this client supports Magnets by offering a text box at the bottom of the client into which they can be copied and pasted. The client is able only to recognize eD2k hash, file size and name in a specific order and therefore, many valid links may not be suitable for downloading.
See also
Notes
- ↑Ability to intercept Magnet links directly from within the web browser. i.e. When a Magnet link is entered into the address bar, the application will intercept the link and try to open the link itself. So if a compatible client is installed on your computer and you enter a Magnet link into your browser address bar, a window pops up asking if you want to allow that client to open the link.
- ↑Possibility to inject the link directly into the application in question.
- ↑ 3.03.13.23.3Dchub://[hubaddress]:[hubport]
- ↑Since v2.5.1.0
References
- ↑ 1.01.1BEP-9: Extension for Peers to Send Metadata Files
- ↑Chapweske, Justin (November 29, 2001). 'HTTP Extensions for a Content-Addressable Web'. www-talk. W3C.<templatestyles src='Module:Citation/CS1/styles.css'></templatestyles>
- ↑'magnet-test.c in trunk/libtransmission; Revision 9531'. Transmission.<templatestyles src='Module:Citation/CS1/styles.css'></templatestyles>
- ↑'magnet.c in trunk/libtransmission; Revision 9979'. Transmission.<templatestyles src='Module:Citation/CS1/styles.css'></templatestyles>
Ed2k To Magnet Link Free
External links
Ed2k Convert To Magnet
- Bitdie a Magnet search engine.
- ENBT Magnet search engine
- CHK Freeware Checksum Utility with SHA1-Base32 and ED2K support
- RHash an open source command-line tool, which can calculate Magnet links.
- Mgnet.me Torrent Magnet URI shortening tool
- Torrent2Magnet Convert Torrent File To Magnet URI
- magnet2torrent.me Magnet Link to Torrent File Converter
- MagnetToTorrent Free Magnet to Torrent Converter
Retrieved from 'https://infogalactic.com/w/index.php?title=Magnet_URI_scheme&oldid=3602270'
Ed2k To Torrent
I just wish, the mldonkey team would focus on full Gnutella and darknet support, and scrap BitTorrent at the first chance.<rant>
It’s really silly, how the dumbest, and most backwards protocol of them all, BitTorrent, now adds all the features that were there long before, and people now say “Oooh, what a new, intriguing technology!”.
Have they be living behind the moon??
Technologically, BitTorrent is even below the original Napster! Even Napster had a search function built-in *from the start*! And the ability to *just put the damn file in the folder to share it, and not having to do anything else, like create a torrent*! Then eDonkey added multiple servers, and ed2k links, plus it was fast back then. Later, Gnutella made it all completely decentralized, including the search. With many client implementations, etc. (EDIT: I forgot WinMX, which had really cool concepts, and was a true expert tool.) And finally, darknets made it all fully anonymous and encrypted.
Only for little retard BitTorrent to come, and go back to what is basically a better FTP! Centralized, insecure, and with that completely idiotic concept of having to create torrent files and having to put them on trackers first. Then they noticed all the cool stuff others had, and re-invented the wheel, while acting like they are the very first to ever do it!
It’s ridiculous!
</rant>