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
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; }