From 5d5452e00231427e06ac3e2ba6dbb2a580f2dd82 Mon Sep 17 00:00:00 2001 From: Daney Date: Tue, 7 Jan 2014 12:49:23 +0000 Subject: [PATCH] Improved usability of label elements to focus on input fields --- bitaddress.org.html | 292 +++++++++++++++++++++++++++++++++++++------- 1 file changed, 248 insertions(+), 44 deletions(-) diff --git a/bitaddress.org.html b/bitaddress.org.html index 47afdc6..5c2b182 100644 --- a/bitaddress.org.html +++ b/bitaddress.org.html @@ -1504,6 +1504,7 @@ if (typeof Crypto == "undefined" || !Crypto.util) { sr.state; sr.pool; sr.pptr; + sr.poolCopyOnInit; // Pool size must be a multiple of 4 and greater than 32. // An array of bytes the size of the pool will be passed to init() @@ -1516,6 +1517,17 @@ if (typeof Crypto == "undefined" || !Crypto.util) { // ba: byte array sr.prototype.nextBytes = function (ba) { var i; + if (window.crypto && window.crypto.getRandomValues && window.Uint8Array) { + try { + var rvBytes = new Uint8Array(ba.length); + window.crypto.getRandomValues(rvBytes); + for (i = 0; i < ba.length; ++i) + ba[i] = sr.getByte() ^ rvBytes[i]; + return; + } catch (e) { + alert(e); + } + } for (i = 0; i < ba.length; ++i) ba[i] = sr.getByte(); }; @@ -1533,8 +1545,9 @@ if (typeof Crypto == "undefined" || !Crypto.util) { sr.seedTime(); sr.state = sr.ArcFour(); // Plug in your RNG constructor here sr.state.init(sr.pool); + sr.poolCopyOnInit = []; for (sr.pptr = 0; sr.pptr < sr.pool.length; ++sr.pptr) - sr.pool[sr.pptr] = 0; + sr.poolCopyOnInit[sr.pptr] = sr.pool[sr.pptr]; sr.pptr = 0; } // TODO: allow reseeding after first request @@ -1543,13 +1556,17 @@ if (typeof Crypto == "undefined" || !Crypto.util) { // Mix in a 32-bit integer into the pool sr.seedInt = function (x) { - sr.pool[sr.pptr++] ^= x & 255; - sr.pool[sr.pptr++] ^= (x >> 8) & 255; - sr.pool[sr.pptr++] ^= (x >> 16) & 255; - sr.pool[sr.pptr++] ^= (x >> 24) & 255; - if (sr.pptr >= sr.poolSize) sr.pptr -= sr.poolSize; + sr.seedInt8(x); + sr.seedInt8((x >> 8)); + sr.seedInt8((x >> 16)); + sr.seedInt8((x >> 24)); } + // Mix in a 8-bit integer into the pool + sr.seedInt8 = function (x) { + sr.pool[sr.pptr++] ^= x & 255; + if (sr.pptr >= sr.poolSize) sr.pptr -= sr.poolSize; + } // Arcfour is a PRNG sr.ArcFour = function () { @@ -1597,11 +1614,14 @@ if (typeof Crypto == "undefined" || !Crypto.util) { sr.pool = new Array(); sr.pptr = 0; var t; - if (navigator.appName == "Netscape" && navigator.appVersion < "5" && window.crypto) { - // Extract entropy (256 bits) from NS4 RNG if available - var z = window.crypto.random(32); - for (t = 0; t < z.length; ++t) - sr.pool[sr.pptr++] = z.charCodeAt(t) & 255; + if (window.crypto && window.crypto.getRandomValues) { + try { + // Use webcrypto if available + var ua = new Uint8Array(32); + window.crypto.getRandomValues(ua); + for (t = 0; t < 32; ++t) + sr.pool[sr.pptr++] = ua[t]; + } catch (e) { alert(e); } } while (sr.pptr < sr.poolSize) { // extract some randomness from Math.random() t = Math.floor(65536 * Math.random()); @@ -1611,8 +1631,36 @@ if (typeof Crypto == "undefined" || !Crypto.util) { sr.pptr = 0; sr.seedTime(); // entropy - sr.seedInt(window.screenX); - sr.seedInt(window.screenY); + var entropyStr = ""; + // screen size and color depth: ~4.8 to ~5.4 bits + entropyStr += (window.screen.height * window.screen.width * window.screen.colorDepth); + entropyStr += (window.screen.availHeight * window.screen.availWidth * window.screen.pixelDepth); + // time zone offset: ~4 bits + var dateObj = new Date(); + var timeZoneOffset = dateObj.getTimezoneOffset(); + entropyStr += timeZoneOffset; + // user agent: ~8.3 to ~11.6 bits + entropyStr += navigator.userAgent; + // browser plugin details: ~16.2 to ~21.8 bits + var pluginsStr = ""; + for (var i = 0; i < navigator.plugins.length; i++) { + pluginsStr += navigator.plugins[i].name + " " + navigator.plugins[i].filename + " " + navigator.plugins[i].description + " " + navigator.plugins[i].version + ", "; + } + var mimeTypesStr = ""; + for (var i = 0; i < navigator.mimeTypes.length; i++) { + mimeTypesStr += navigator.mimeTypes[i].description + " " + navigator.mimeTypes[i].type + " " + navigator.mimeTypes[i].suffixes + ", "; + } + entropyStr += pluginsStr + mimeTypesStr; + // cookies and storage: 1 bit + entropyStr += navigator.cookieEnabled + typeof (sessionStorage) + typeof (localStorage); + + var entropyBytes = Crypto.SHA256(entropyStr, { asBytes: true }); + sr.seedInt8(entropyBytes[0]); + sr.seedInt8(entropyBytes[1]); + sr.seedInt8(entropyBytes[2]); + sr.seedInt8(entropyBytes[3]); + sr.seedInt8(entropyBytes[4]); + sr.seedInt8(entropyBytes[5]); } })(); @@ -5712,12 +5760,13 @@ Bitcoin.Util = { no-repeat left center; width: 17px; height: 17px; display: inline-block; float: right; } .right { text-align: right; } .walletarea { display: none; border: 2px solid green; } -.keyarea { font-family: Courier New; height: 110px; text-align: left; position: relative; padding: 5px; } +hr { margin: 20px 0; border-top: 2px dashed #008000; } +.keyarea { height: 110px; text-align: left; position: relative; padding: 5px; } .keyarea .public { float: left; } .keyarea .pubaddress { display: inline-block; height: 40px; padding: 0 0 0 10px; float: left; } .keyarea .privwif { margin: 0; float: right; text-align: right; padding: 0 20px 0 0; position: relative; } -.keyarea .label { text-decoration: underline; } -.keyarea .output { display: block; } +.keyarea .label { font-weight: bold; } +.keyarea .output { display: block; font-family: monospace; font-size: 1.25em; } .keyarea .qrcode_public { display: inline-block; float: left; } .keyarea .qrcode_private { display: inline-block; position: relative; top: 28px; float: right; } .pubkeyhex { word-wrap: break-word; } @@ -5729,7 +5778,9 @@ body { font-family: Arial; } .answer { padding: 0 15px 10px 25px; text-align: left; display: none; font-size: 80%; } .faq { border: 0; border-top: 2px solid green; } -#keyarea { height: 250px; font-family: Arial; } +#btcaddress, #btcprivwif, #detailaddress, #detailaddresscomp, #detailprivwif, #detailprivwifcomp { font-family: monospace; font-size: 1.25em; } +#seedpoolarea { display: none; } +#keyarea { height: 250px; } #keyarea .pubaddress { float: none; display: block; padding: 0; height: auto; } #keyarea .label { text-decoration: none; } #keyarea .privwif { float: none; text-align: right; position: relative; padding: 0; } @@ -5744,7 +5795,7 @@ body { font-family: Arial; } #main { position: relative; text-align: center; margin: 0px auto; width: 1005px; } #logo { width: 578px; height: 80px; } -#generate { font-family: Courier New; height: 158px; text-align: left; position: relative; padding: 5px; border: 2px solid green; } +#generate { font-family: monospace; font-size: 1.25em; height: 158px; text-align: left; position: relative; padding: 5px; border: 2px solid green; } #generate span { padding: 5px 5px 0 5px; } #paperarea { min-height: 120px; display: none; } @@ -5798,19 +5849,19 @@ body { font-family: Arial; } #detailarea .privqr .item .label { text-decoration: none; } #detailarea .privqr .item { float: left; margin: 0; position: relative; } #detailarea .privqr .item.right { float: right; position: relative; } -#detailarea .item { margin: 10px 0; position: relative; font-size: 90%; } +#detailarea .item { margin: 10px 0; position: relative; font-size: 90%; padding: 1px 0; } #detailarea .item.clear { clear: both; padding-top: 10px; } -#detailarea .label { display: block; text-decoration: underline; } -#detailarea .output { display: block; min-height: 20px; } +#detailarea .label { display: block; font-weight: bold; } +#detailarea .output { display: block; font-family: monospace; font-size: 1.25em; } #detailarea #detailqrcodepublic { position: relative; float: left; margin: 0 10px 0 0; padding: 13px 11px 11px 11px; } #detailarea #detailqrcodepubliccomp { position: relative; float: right; margin: 0 0 0 10px; padding: 13px 11px 11px 11px; } #detailarea #detailqrcodeprivate { position: relative; float: left; margin: 0 10px 0 0; padding: 13px 11px 11px 11px; } #detailarea #detailqrcodeprivatecomp { position: relative; float: right; margin: 0 0 0 10px; padding: 13px 11px 11px 11px; } -#detailpubkey { width: 566px; } +#detailpubkey { width: 590px; } #detailbip38commands { display: none; padding-top: 5px; } #vanityarea { text-align: left; } #vanityarea .label { text-decoration: underline; } -#vanityarea .output { display: block; } +#vanityarea .output { font-family: monospace; font-size: 1.25em; display: block; } #vanityarea .notes { text-align: left; font-size: 80%; padding: 0 0 20px 0; } #vanitystep1area { display: none; text-align: left; position: relative; padding: 15px; border-bottom: 2px solid green; } #vanitystep1label { padding-left: 5px; } @@ -5821,7 +5872,7 @@ body { font-family: Arial; } .englishjson { text-align: center; padding: 40px 0 20px 0; } .unittests { text-align: center; } .unittests div { width: 894px; font-family: monospace; text-align: left; margin: auto; padding: 5px; border: 1px solid black; } -#testnet { font-family: Tahoma; display: none; background-color: Orange; color: #000000; border-radius: 5px; font-weight: bold; padding: 10px 0; margin: 0 auto 20px auto; } +#testnet { display: none; background-color: Orange; color: #000000; border-radius: 5px; font-weight: bold; padding: 10px 0; margin: 0 auto 20px auto; } #busyblock { position: fixed; display: none; background: url("") #ccc no-repeat center; opacity: 0.4; width: 100%; height: 100%; top: 0; left: 0; z-index: 5000; } #busyblock.busy { display: block; } .hide { display: none; } @@ -5868,7 +5919,7 @@ body { font-family: Arial; } #bulkstartindex, #paperlimit, #paperlimitperpage { width: 35px; } #bulklimit { width: 45px; } - .footer { font-family: Arial; font-size: 90%; clear: both; width: 750px; padding: 10px 0 10px 0; margin: 50px auto auto auto; } + .footer { font-size: 90%; clear: both; width: 750px; padding: 10px 0 10px 0; margin: 50px auto auto auto; } .footer div span.item { padding: 10px; } .footer .authorbtc { float: left; width: 470px; } .footer .authorbtc span.item { text-align: left; display: block; padding: 0 20px; } @@ -5889,8 +5940,12 @@ body { font-family: Arial; } .paper #logo { display: none; } .menu, .footer, .commands, #tagline, #faqs, #culturemenu { display: none; } #detailprivwif { width: 285px; word-wrap: break-word; } - #detailprivwifcomp { width: 285px; word-wrap: break-word; text-align: right; } + #detailprivwifcomp { width: 310px; word-wrap: break-word; text-align: right; } + #detailarea .privqr .item.right { width: 310px; } #detailarea .privqr .item { width: 285px; } + #detailarea .notes { display: none; } + #seedpoolarea { display: none; } + .faq { display: none; } } @@ -5902,10 +5957,12 @@ body { font-family: Arial; } Español | Français | ελληνικά | - italiano + italiano | + Deutsch
Open Source JavaScript Client-Side Bitcoin Wallet Generator
+
-

A Bitcoin wallet is as simple as a single pairing of a Bitcoin address with it's corresponding Bitcoin private key. Such a wallet has been generated for you in your web browser and is displayed above.

+

A Bitcoin wallet is as simple as a single pairing of a Bitcoin address with its corresponding Bitcoin private key. Such a wallet has been generated for you in your web browser and is displayed above.

To safeguard this wallet you must print or otherwise record the Bitcoin address and private key. It is important to make a backup copy of the private key and store it in a safe location. This site does not have knowledge of your private key. If you are familiar with PGP you can download this all-in-one HTML page and check that you have an authentic version from the author of this site by matching the SHA1 hash of this HTML with the SHA1 hash available in the signed version history document linked on the footer of this site. If you leave/refresh the site or press the "Generate New Address" button then a new private key will be generated and the previously displayed private key will not be retrievable. Your Bitcoin private key should be kept a secret. Whomever you share the private key with has access to spend all the bitcoins associated with that address. If you print your wallet then store it in a zip lock bag to keep it safe from water. Treat a paper wallet like cash.

Add funds to this wallet by instructing others to send bitcoins to your Bitcoin address.

Check your balance by going to blockchain.info or blockexplorer.com and entering your Bitcoin address.

@@ -5964,15 +6021,15 @@ body { font-family: Arial; }
- - + +
- - - + + +
@@ -5981,9 +6038,9 @@ body { font-family: Arial; }
- - - + + +
@@ -6021,13 +6078,13 @@ body { font-family: Arial; }
- Enter Passphrase: + - +
- Confirm Passphrase: + Algorithm: SHA256(passphrase) @@ -6114,7 +6171,7 @@ body { font-family: Arial; }
- + @@ -6210,7 +6267,7 @@ body { font-family: Arial; }
- Version History (v2.6.4) + Version History (v2.7.2) (PGP) 527B 5C82 B1F6 B2DB 72A0
ECBF 8749 7B91 6397 4F5A
@@ -6581,7 +6638,7 @@ ninja.seeder = { // number of mouse movements to wait for seedLimit: (function () { var num = Crypto.util.randomBytes(12)[11]; - return 50 + Math.floor(num); + return 100 + Math.floor(num); })(), seedCount: 0, // counter @@ -6603,6 +6660,12 @@ ninja.seeder = { document.getElementById("generate").style.display = "none"; document.getElementById("menu").style.visibility = "visible"; } + if (SecureRandom.poolCopyOnInit != null) { + document.getElementById("seedpool").innerHTML = Crypto.util.bytesToHex(SecureRandom.poolCopyOnInit); + } + else { + document.getElementById("seedpool").innerHTML = Crypto.util.bytesToHex(SecureRandom.pool); + } }, // If user has not moved the mouse or if they are on a mobile device @@ -7348,7 +7411,140 @@ ninja.translator = { "detaildecrypt": "Decripta BIP38", "detaillabelq1": "How do I make a wallet using dice? What is B6?", //TODO: please translate "detaila1": "An important part of creating a Bitcoin wallet is ensuring the random numbers used to create the wallet are truly random. Physical randomness is better than computer generated pseudo-randomness. The easiest way to generate physical randomness is with dice. To create a Bitcoin private key you only need one six sided die which you roll 99 times. Stopping each time to record the value of the die. When recording the values follow these rules: 1=1, 2=2, 3=3, 4=4, 5=5, 6=0. By doing this you are recording the big random number, your private key, in B6 or base 6 format. You can then enter the 99 character base 6 private key into the text field above and click View Details. You will then see the Bitcoin address associated with your private key. You should also make note of your private key in WIF format since it is more widely used." //TODO: please translate - } + }, + + "de": { + // javascript alerts or messages + "testneteditionactivated": "TESTNET AKTIVIERT", + "paperlabelbitcoinaddress": "Bitcoin-Adresse:", + "paperlabelprivatekey": "Privater Schlüssel (Wallet Import Format):", + "paperlabelencryptedkey": "Verschlüsselter privater Schlüssel (Passwort benötigt)", + "bulkgeneratingaddresses": "Adressen erstellen... ", + "brainalertpassphrasetooshort": "Die eingegebene Passphrase ist zu kurz.\n\n", + "brainalertpassphrasewarning": "Hinweis: Eine längere Passphrase schützt besser vor Brute-Force-Attacken, bei denen auf gut Glück Passphrasen probiert werden.", + "brainalertpassphrasedoesnotmatch": "Die beiden Passphrasen stimmen nicht überein.", + "detailalertnotvalidprivatekey": "Der eingegebene Text ist kein gültiger privater Schlüssel.", + "detailconfirmsha256": "Der eingegebene Text ist kein gültiger privater Schlüssel!\n\nMöchtest du den eingegebenen Text als Passphrase verwenden, um mithilfe dessen SHA256-Hash einen privaten Schlüssel zu erstellen?\n\nHinweis: Eine längere Passphrase schützt besser vor Brute-Force-Attacken, bei denen auf gut Glück Passphrasen probiert werden.", + "bip38alertincorrectpassphrase": "Falsches Passwort", + "bip38alertpassphraserequired": "Bitte Passwort eingeben.", + "vanityinvalidinputcouldnotcombinekeys": "Unzulässige Eingaben. Die Schlüssel konnten nicht kombiniert werden.", + "vanityalertinvalidinputpublickeysmatch": "Unzulässige Eingaben. Die eingegebenen öffentlichen Schlüssel stimmen überein. Bitte gib zwei unterschiedliche Schlüssel ein.", + "vanityalertinvalidinputcannotmultiple": "Unzulässige Eingaben. Zwei öffentliche Schlüssel können nicht miteinander multipliziert werden. Wähle \"Addieren\" aus, um aus zwei öffentlichen Schlüsseln eine Bitcoin-Adresse zu erstellen.", + "vanityprivatekeyonlyavailable": "Nur verfügbar, wenn zwei private Schlüssel kombiniert werden.", + "vanityalertinvalidinputprivatekeysmatch": "Unzulässige Eingaben. Die eingegebenen privaten Schlüssel stimmen überein. Bitte gib zwei unterschiedliche Schlüssel ein.", + + // header and menu html + "tagline": "Offener, client-seitiger Bitcoin-Wallet-Generator in JavaScript", + "generatelabelbitcoinaddress": "Erstelle Bitcoin-Wallet...", + "generatelabelmovemouse": "Bewege deine Maus umher, um die Zufälligkeit zu erhöhen...", + "singlewallet": "Einzelnes Wallet", + "paperwallet": "Papier-Wallet", + "bulkwallet": "Massen-Wallet", + "brainwallet": "Kopf-Wallet", + "vanitywallet": "Personalisiertes Wallet", + "detailwallet": "Walletdetails", + + // footer html + "footerlabeldonations": "Spenden:", + "footerlabeltranslatedby": "Übersetzung: 1EWPcmYmU8MamRUYMFWQa1r7A2Tskz78t5", + "footerlabelpgp": "PGP", + "footerlabelversion": "Versionsgeschichte", + "footerlabelgithub": "GitHub-Repository", + "footerlabelcopyright1": "Copyright bitaddress.org.", + "footerlabelcopyright2": "JavaScript-Copyrights sind im Quelltext enthalten.", + "footerlabelnowarranty": "Ohne Gewähr.", + + // single wallet html + "newaddress": "Neues Wallet erstellen", + "singleprint": "Drucken", + "singlelabelbitcoinaddress": "Bitcoin-Adresse", + "singlelabelprivatekey": "Privater Schlüssel (WIF – zum Importieren geeignet):", + "singletip1": "Ein Bitcoin-Wallet (Geldbörse) ist nichts anderes als eine Bitcoin-Adresse (öffentlicher Schlüssel) und der zu ihr gehörende private Schlüssel. Oben findest du ein solches, gerade für dich erstelltes Wallet, bestehend aus den beiden Zeichenketten. Die QR-Codes dienen lediglich der Vereinfachung und enthalten kodiert die Adresse bzw. den privaten Schlüssel.", + "singletip2": "Um dieses Wallet zu schützen, musst du es entweder ausdrucken oder anderweitig die Bitcoin-Adresse und den privaten Schlüssel sichern. Fertige auf jeden Fall eine Kopie des privaten Schlüssels an und bewahre sie an einem sicheren Ort auf. Der private Schlüssel liegt nur lokal auf deinem Rechner vor und wurde nicht ins Internet übertragen. Falls du dich mit PGP auskennst, kannst du dir diese all-in-one HTML-Seite herunterladen. Um zu überprüfen, ob die heruntergeladene Version authentisch ist, kannst du den SHA1-Hash dieser Seite mit dem SHA1-Hash in der signierten Versionsgeschichte am unteren Ende dieser Seite abgleichen. Wenn du diese Seite verlässt, sie neulädst bzw. den \"Neues Wallet erstellen\"-Button drückst, wird ein neues Wallet erstellt und das vorherige wird nicht mehr abrufbar sein. Du solltest deinen privaten Schlüssel geheim halten. Wer den privaten Schlüssel hat, kann damit auf alle im Wallet befindlichen Bitcoin zugreifen und sie nach Belieben ausgeben. Behandle dein gedrucktes Wallet wie echtes Geld!", + "singletip3": "Du kannst Guthaben zu deinem Wallet hinzufügen, indem du genau wie bei anderen Überweisungen Bitcoins an die Bitcoin-Adresse deines Wallets schickst.", + "singletip4": "Überprüfe dein Guthaben, indem du deine Bitcoin-Adresse auf blockchain.info bzw. blockexplorer.com eingibst.", + "singletip5": "Du kannst deine Bitcoins ausgeben, indem du das gesamte mit deinem privaten Schlüssel verbundene Guthaben auf deinen Account bei blockchain.info bzw. mtgox.com überträgst. Alternativ kannst du dir ein Bitcoinprogramm herunterladen und deinen privaten Schlüssel in dieses importieren. Beachte dabei aber, dass, sobald du Bitcoins mit dem Programm sendest, dein privater Schlüssel mit den anderen privaten Schlüsseln, die vom Programm bereitgestellt werden, verbunden wird. Bei einer Überweisung wird etwas Rückgeld an eine der Bitcoin-Adressen des Programms geschickt. Deswegen musst du, um tatsächlich dein gesamtes Guthaben zu sichern, ein Backup vom gesamten Wallet des Programms, das nun auch deinen importierten privaten Schlüssel enthält, anfertigen. Satoshi rät, dass man unter keinen Umständen ein Wallet löschen sollte.", + + // paper wallet html + "paperlabelhideart": "Grafische Gestaltung ausblenden?", + "paperlabeladdressesperpage": "Adressen je Seite:", + "paperlabeladdressestogenerate": "Anzahl zu erstellender Adressen:", + "papergenerate": "Erstellen", + "paperprint": "Drucken", + "paperlabelBIPpassphrase": "Passwort:", + "paperlabelencrypt": "Mit BIP38 verschlüsseln?", + + // bulk wallet html + "bulklabelstartindex": "Startindex:", + "bulklabelrowstogenerate": "Zu erstellende Adressen:", + "bulklabelcompressed": "Adressen komprimieren?", + "bulkgenerate": "Erstellen", + "bulkprint": "Drucken", + "bulklabelcsv": "Comma Separated Values (CSV):", + "bulklabelformat": "Index, Adresse, privater Schlüssel (WIF)", + "bulklabelq1": "Warum sollte ich ein Massen-Wallet auf meiner Webseite einsetzen?", + "bulka1": "Bisher musste immer der offizielle Bitcoin-Daemon, bitcoind, auf dem Server installiert sein, damit man Bitcoins auf seiner Webseite annehmen konnte. Viele Webhoster blockieren die Installation von bitcoind. Außerdem müssen die privaten Schlüssel auf dem Server liegen, damit bitcoind funktioniert, obwohl sie dort einfacher gestohlen werden können. Mit einem Massen-Wallet brauchst du nur noch die Bitcoin-Adressen und nicht mehr zusätzlich die privaten Schlüssel hochladen. Dadurch musst du dir keine Sorgen mehr machen, dass dein Bitcoin-Wallet gestohlen werden könnte, wenn unberechtigt in deinen Server eingedrungen wird.", + "bulklabelq2": "Wie kann ich ein Massen-Wallet in meine Webseite integrieren?", + "bulklabela2li1": "Erstelle mithilfe dieser Seite ganz viele Bitcoin-Adressen (10.000+). Kopiere die CSV-Liste in eine sichere Textdatei auf deinem Computer. Fertige ein Backup dieser Datei an und speichere sie an einem sicheren Ort.", + "bulklabela2li2": "Importiere die Bitcoin-Adressen in eine Datenbank auf deinem Server. (Lege nur die Bitcoin-Adressen, nicht aber die privaten Schlüssel auf deinem Server ab!)", + "bulklabela2li3": "Biete deinen Kunden auf deiner Webseite Bitcoin als Zahlungsmöglichkeit an. Wenn ein Kunde mit Bitcoin zahlen möchte, zeige ihm eine der Adressen aus deiner Datenbank als Zahlungsadresse an und speichere sie mit seiner Bestellung.", + "bulklabela2li4": "Jetzt musst du dir den Zahlungseingang bestätigen lassen. Google \"bitcoin payment notification\" und melde dich bei mindestens einem solchen Anbieter an. Es gibt verschiedene Anbieter, die dich via Web, API, SMS, E-Mail etc. über erfolgte Transaktionen informieren können. Sobald du die Eingangsbestätigung erhälst, kannst du automatisch die Bestellung abwickeln lassen. Um selber zu schauen, ob eine Zahlung erfolgt ist, kannst du Block Explorer nutzen. Ersetze BITCOINADRESSE durch die Bitcoin-Adresse, die du prüfen möchtest. Es dauert von zehn Minuten bis zu einer Stunde, um Transaktionen zu bestätigen.
http://www.blockexplorer.com/address/BITCOINADRESSE

Unbestätigte Transaktionen findest du hier: http://blockchain.info/
Sämtliche Transaktionen sollten dort innerhalb von 30 Sekunden auftauchen.", + "bulklabela2li5": "Deine Bitcoins werden sicher in die Block-Chain aufgenommen. Mithilfe des ursprünglichen Wallets vom ersten Schritt kannst du sie ausgeben.", + + // brain wallet html + "brainlabelenterpassphrase": "Passphrase eingeben:", + "brainlabelshow": "Aufdecken?", + "brainprint": "Drucken", + "brainlabelconfirm": "Passphrase wiederholen:", + "brainview": "Zugehöriges Wallet anzeigen", + "brainalgorithm": "Algorithmus: SHA256 (Passphrase)", + "brainlabelbitcoinaddress": "Bitcoin-Adresse:", + "brainlabelprivatekey": "Privater Schlüssel (WIF):", + + // vanity wallet html + "vanitylabelstep1": "Schritt 1 - Erstelle dein Schlüsselpaar", + "vanitynewkeypair": "Erstellen", + "vanitylabelstep1publickey": "Öffentlicher Schlüssel:", + "vanitylabelstep1pubnotes": "Kopiere den obigen öffentlichen Schlüssel in das \"Your public key\"-Feld auf der Webseite von Vanity Pool.", + "vanitylabelstep1privatekey": "Privater Schlüssel (Your Part Private Key):", + "vanitylabelstep1privnotes": "Speichere den obigen privaten Schlüssel in einer Textdatei, die du am besten auf einem verschlüsselten Laufwerk sicherst. Sobald der Vanity-Pool deine personalisierte Bitcoin-Adresse gefunden hat, kannst du den zu ihr gehörenden privaten Schlüssel nur mithilfe des vom Pools berechneten privaten Schlüssels (Pool Part Private Key) und des obigen privaten Schlüssels (Your Part Private Key) erhalten. Beide privaten Schlüssel (Pool und Your) werden zum Berechnen des privaten Schlüssels deiner personalisierten Bitcoin-Adresse benötigt, damit wirklich nur jemand, der beide besitzt, das personalisierte Wallet nutzen kann.", + "vanitylabelstep2calculateyourvanitywallet": "Schritt 2 - Berechne dein personalisiertes Wallet", + "vanitylabelenteryourpart": "Gib hier deinen privaten Schlüssel von oben ein (Your Part Private Key):", + "vanitylabelenteryourpoolpart": "Gib hier den von Vanity-Pool erhaltenen privaten Schlüssel ein (Pool Part Private Key):", + "vanitylabelnote1": "[HINWEIS: Dieses Eingabefeld nimmt sowohl öffentlich als auch private Schlüssel an.]", + "vanitylabelnote2": "[HINWEIS: Dieses Eingabefeld nimmt sowohl öffentlich als auch private Schlüssel an.]", + "vanitylabelradioadd": "Addieren", + "vanitylabelradiomultiply": "Multiplizieren", + "vanitycalc": "Personalisiertes Wallet berechnen", + "vanitylabelbitcoinaddress": "Personalisierte Bitcoin-Adresse:", + "vanitylabelnotesbitcoinaddress": "Die obige Bitcoin-Adresse sollte den gewünschten Präfix enthalten.", + "vanitylabelpublickeyhex": "Personalisierter öffentlicher Schlüssel (HEX):", + "vanitylabelnotespublickeyhex": "Die obige Zeichenfolge ist der öffentliche Schlüssel (Bitcoin-Adresse) im Hexadezimalformat.", + "vanitylabelprivatekey": "Personalisierter privater Schlüssel (WIF):", + "vanitylabelnotesprivatekey": "Der obige private Schlüssel ermöglicht das Importieren in andere Wallets.", + + // detail wallet html + "detaillabelenterprivatekey": "Privaten Schlüssel eingeben:", + "detailkeyformats": "Unterstützte Formate: WIF, WIFC, HEX, B64, B6, MINI, BIP38", + "detailview": "Details anzeigen", + "detailprint": "Drucken", + "detaillabelnote1": "Der private Schlüssel deines Wallets ist eine geheime, einzigartige Zeichenfolge, die nur du kennst. Er kann auf mehrer Arten dargestellt werden. Unten findest du die zugehörige Bitcoin-Adresse bzw. öffentlichen Schlüssel sowie den privaten Schlüssel in den verbreitetsten Formaten.", + "detaillabelnote2": "Ab Version 0.6 speichert Bitcoin-qt öffentliche Schlüssel komprimiert. Das Programm unterstützt nun auch den Import und Export von privaten Schlüsseln mit importprivkey/dumpprivkey. Das Format des exportierten privaten Schlüssels hängt davon ab, ob die Adresse in einem alten oder neuen Wallet erstellt wurde.", + "detaillabelbitcoinaddress": "Bitcoin-Adresse:", + "detaillabelbitcoinaddresscomp": "Komprimierte Bitcoin-Adresse:", + "detaillabelpublickey": "Öffentlicher Schlüssel (130 Zeichen [0-9A-F]):", + "detaillabelpublickeycomp": "Komprimierter öffentlicher Schlüssel (66 Zeichen [0-9A-F]):", + "detaillabelprivwif": "Privater Schlüssel WIF
51 Zeichen in base58, beginnt mit", + "detaillabelprivwifcomp": "Komprimierter privater Schlüssel WIF
52 Zeichen in base58, beginnt mit", + "detailcompwifprefix": "'K' oder 'L'", + "detaillabelprivhex": "Privater Schlüssel in Hexadezimal (64 Zeichen [0-9A-F]):", + "detaillabelprivb64": "Privater Schlüssel in base64 (44 Zeichen):", + "detaillabelprivmini": "Privater Schlüssel in mini (22, 26 oder 30 Zeichen, beginnt mit 'S'):", + "detaillabelpassphrase": "Passwort für BIP38 eingeben", + "detaildecrypt": "Entschlüsseln", + "detaillabelq1": "Wie erstelle ich ein Wallet mithilfe eines Würfels? Was versteht man unter B6?", + "detaila1": "Beim Erstellen eines Bitcoin-Wallets sollten die dafür genutzten Zufallszahlen auch tatsächlich zufällig sein. Ein echter Würfel liefert wesentlich zufälligere Zahlen als ein Computer. Um einen privaten Schlüssel zu erstellen, sind lediglich 99 Würfe mit einem normalen Würfel nötig. Nach jedem Wurf solltest du die Augenzahl nach folgendem Muster aufschreiben: 1-\>1, 2-\>2, 3-\>3, 4-\>4, 5-\>5, 6-\>0. Die so entstandene Zufallszahl stellt deinen privaten Schlüssel in B6 bzw. zur Basis 6 dar. Diesen 99 Zeichen langen Basis-6-Schlüssel kannst du im obigen Eingabefeld eingeben und dir dann die zugehörigen Details anzeigen lassen. U.a. wird dir die zu deinem privaten Schlüssel gehörende Bitcoin-Adresse angezeigt. Es wäre ratsam, sich die ebenfalls berechnete WIF-Version des privaten Schlüssels zu notieren, weil sie häufiger genutzt wird." + } } }; @@ -7476,6 +7672,10 @@ ninja.wallets.paperwallet = { ninja.wallets.paperwallet.pageBreakAt = pageBreakAt; document.getElementById("paperkeyarea").innerHTML = ""; if (ninja.wallets.paperwallet.encrypt) { + if (passphrase == "") { + alert(ninja.translator.get("bip38alertpassphraserequired")); + return; + } document.getElementById("busyblock").className = "busy"; ninja.privateKey.BIP38GenerateIntermediatePointAsync(passphrase, null, null, function (intermediate) { ninja.wallets.paperwallet.intermediatePoint = intermediate; @@ -8691,8 +8891,12 @@ if (ninja.getQueryString()["testnet"] == "true" || ninja.getQueryString()["testn Bitcoin.ECKey.privateKeyPrefix = 0xEF; // testnet ninja.testnetMode = true; } +if (ninja.getQueryString()["showseedpool"] == "true" || ninja.getQueryString()["showseedpool"] == "1") { + document.getElementById("seedpoolarea").style.display = "block"; + +} // if users does not move mouse after random amount of time then generate the key anyway. -setTimeout(ninja.seeder.forceGenerate, ninja.seeder.seedLimit * 20); +setTimeout(ninja.seeder.forceGenerate, ninja.seeder.seedLimit * 100);