Using JavaScript, how can i open a new window (loading, say, in the process) and inject/insert this code into its body:
<script type="text/javascript">alert(document.title);</script>
I know how to open a new window, but i don't know how to add the script to the new window and run it:
var ww = window.open('');
Using JavaScript, how can i open a new window (loading, say, http://www.google.com in the process) and inject/insert this code into its body:
<script type="text/javascript">alert(document.title);</script>
I know how to open a new window, but i don't know how to add the script to the new window and run it:
var ww = window.open('http://www.google.com');
Share
Improve this question
edited Jul 21, 2009 at 22:33
Shog9
160k36 gold badges235 silver badges240 bronze badges
asked Jul 21, 2009 at 19:49
bobbob
1
- 3 I hope that this just isn't possible. Seems like a huge security risk. – jcollum Commented Jul 21, 2009 at 20:10
4 Answers
Reset to default 12No. This would violate the same origin policy implemented by most (all?) browsers to protect their users.
Imagine if this were possible: You could convince users to come to your site, open a new window with, say, their bank's website loaded into it, and inject code to steal their credentials. Then proceed to steal their money, identity, etc...
Not good, eh? So be very, very glad it isn't possible.
See also: Same-origin policy for DOM access in the Browser Security Handbook
This worked on the firebug console:
>>> var x = window.open("");
Window opened
>>> x
Window about:blank
>>> x.document
Document about:blank
>>> x.document.write("<script type='text/javascript'>alert('h1');</script>");
Alert popped up
The best approach is having your web-site (the one your script comes from) to act as a proxy and download url in question for you. You can therefore modify response on the server, or locally on the client.
Your ww
var is a reference to the new window object. So ww.window.title would be the title of the window you have opened.
If you wish to manipulate your new window you should do it via your ww
var.