diff --git a/scanners/kube-hunter/examples/in-cluster/findings.json b/scanners/kube-hunter/examples/in-cluster/findings.yaml similarity index 100% rename from scanners/kube-hunter/examples/in-cluster/findings.json rename to scanners/kube-hunter/examples/in-cluster/findings.yaml diff --git a/scanners/zap/examples/demo-juice-shop-full-scan/findings.yaml b/scanners/zap/examples/demo-juice-shop-full-scan/findings.yaml index 8d176246..7270df9d 100644 --- a/scanners/zap/examples/demo-juice-shop-full-scan/findings.yaml +++ b/scanners/zap/examples/demo-juice-shop-full-scan/findings.yaml @@ -1 +1,2733 @@ -[{"name":"HTTP Only Site","description":"The site is only served under HTTP and not HTTPS.","category":"HTTP Only Site","location":"https://juice-shop.demo-apps.svc","osi_layer":"APPLICATION","severity":"MEDIUM","attributes":{"host":"juice-shop.demo-apps.svc","zap_confidence":"2","zap_count":"1","zap_solution":"Configure your web or application server to use SSL (https).","zap_otherinfo":"Failed to connect.ZAP attempted to connect via: https://juice-shop.demo-apps.svc:443/","zap_reference":"https://cheatsheetseries.owasp.org/cheatsheets/Transport_Layer_Protection_Cheat_Sheet.htmlhttps://letsencrypt.org/","zap_cweid":"311","zap_wascid":"4","zap_riskcode":"2","zap_pluginid":"10106","zap_finding_urls":[{"uri":"http://juice-shop.demo-apps.svc:3000/","method":"GET"}]},"id":"838915aa-3946-4a24-bb0d-18a6c1f830f2"},{"name":"Storable but Non-Cacheable Content","description":"The response contents are storable by caching components such as proxy servers, but will not be retrieved directly from the cache, without validating the request upstream, in response to similar requests from other users. ","category":"Storable but Non-Cacheable Content","location":"http://juice-shop.demo-apps.svc:3000","osi_layer":"APPLICATION","severity":"INFORMATIONAL","attributes":{"host":"juice-shop.demo-apps.svc","zap_confidence":"2","zap_count":"35","zap_solution":null,"zap_otherinfo":null,"zap_reference":"https://tools.ietf.org/html/rfc7234https://tools.ietf.org/html/rfc7231http://www.w3.org/Protocols/rfc2616/rfc2616-sec13.html (obsoleted by rfc7234)","zap_cweid":"524","zap_wascid":"13","zap_riskcode":"0","zap_pluginid":"10049","zap_finding_urls":[{"uri":"http://juice-shop.demo-apps.svc:3000/ftp/acquisitions.md","method":"GET","evidence":"max-age=0"},{"uri":"http://juice-shop.demo-apps.svc:3000/ftp/legal.md","method":"GET","evidence":"max-age=0"},{"uri":"http://juice-shop.demo-apps.svc:3000/sitemap.xml","method":"GET","evidence":"max-age=0"},{"uri":"http://juice-shop.demo-apps.svc:3000/assets/public/favicon_js.ico","method":"GET","evidence":"max-age=0"},{"uri":"http://juice-shop.demo-apps.svc:3000/main-es2015.js","method":"GET","evidence":"max-age=0"},{"uri":"http://juice-shop.demo-apps.svc:3000/MaterialIcons-Regular.woff2","method":"GET","evidence":"max-age=0"},{"uri":"http://juice-shop.demo-apps.svc:3000/polyfills-es5.js","method":"GET","evidence":"max-age=0"},{"uri":"http://juice-shop.demo-apps.svc:3000/assets/public/images/JuiceShop_Logo.png","method":"GET","evidence":"max-age=0"},{"uri":"http://juice-shop.demo-apps.svc:3000/vendor-es2015.js","method":"GET","evidence":"max-age=0"},{"uri":"http://juice-shop.demo-apps.svc:3000/assets/public/images/products/fan_girlie.jpg","method":"GET","evidence":"max-age=0"},{"uri":"http://juice-shop.demo-apps.svc:3000/assets/public/images/products/apple_juice.jpg","method":"GET","evidence":"max-age=0"},{"uri":"http://juice-shop.demo-apps.svc:3000/assets/public/images/products/green_smoothie.jpg","method":"GET","evidence":"max-age=0"},{"uri":"http://juice-shop.demo-apps.svc:3000/assets/public/images/products/apple_pressings.jpg","method":"GET","evidence":"max-age=0"},{"uri":"http://juice-shop.demo-apps.svc:3000","method":"GET","evidence":"max-age=0"},{"uri":"http://juice-shop.demo-apps.svc:3000/assets/public/images/products/melon_bike.jpeg","method":"GET","evidence":"max-age=0"},{"uri":"http://juice-shop.demo-apps.svc:3000/ftp/incident-support.kdbx","method":"GET","evidence":"max-age=0"},{"uri":"http://juice-shop.demo-apps.svc:3000/runtime-es5.js","method":"GET","evidence":"max-age=0"},{"uri":"http://juice-shop.demo-apps.svc:3000/vendor-es5.js","method":"GET","evidence":"max-age=0"},{"uri":"http://juice-shop.demo-apps.svc:3000/","method":"GET","evidence":"max-age=0"},{"uri":"http://juice-shop.demo-apps.svc:3000/assets/public/images/products/eggfruit_juice.jpg","method":"GET","evidence":"max-age=0"}]},"id":"f54e1a43-403b-4ca0-920b-239db3cae852"},{"name":"User Agent Fuzzer","description":"Check for differences in response based on fuzzed User Agent (eg. mobile sites, access as a Search Engine Crawler). Compares the response statuscode and the hashcode of the response body with the original response.","category":"User Agent Fuzzer","location":"http://juice-shop.demo-apps.svc:3000","osi_layer":"APPLICATION","severity":"INFORMATIONAL","attributes":{"host":"juice-shop.demo-apps.svc","zap_confidence":"2","zap_count":"70","zap_solution":null,"zap_otherinfo":null,"zap_reference":"https://owasp.org/wstg","zap_cweid":null,"zap_wascid":null,"zap_riskcode":"0","zap_pluginid":"10104","zap_finding_urls":[{"uri":"http://juice-shop.demo-apps.svc:3000/","method":"GET","param":"Header User-Agent","attack":"Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 6.0)"},{"uri":"http://juice-shop.demo-apps.svc:3000/assets/public/images/products","method":"GET","param":"Header User-Agent","attack":"msnbot/1.1 (+http://search.msn.com/msnbot.htm)"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=polling&t=NB_4MHS","method":"GET","param":"Header User-Agent","attack":"Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 6.0)"},{"uri":"http://juice-shop.demo-apps.svc:3000/assets/i18n","method":"GET","param":"Header User-Agent","attack":"Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 6.0)"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=websocket&sid=SUkCn1d1AMCb92teAAJD","method":"GET","param":"Header User-Agent","attack":"Mozilla/5.0 (compatible; Googlebot/2.1; +http://www.google.com/bot.html)"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=websocket&sid=SUkCn1d1AMCb92teAAJD","method":"GET","param":"Header User-Agent","attack":"Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1)"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=polling&t=NB_4MNm&sid=Jqb5tSRY7TVpvWxfAAJP","method":"GET","param":"Header User-Agent","attack":"Mozilla/5.0 (compatible; Googlebot/2.1; +http://www.google.com/bot.html)"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=websocket&sid=SUkCn1d1AMCb92teAAJD","method":"GET","param":"Header User-Agent","attack":"Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 6.0)"},{"uri":"http://juice-shop.demo-apps.svc:3000/assets/public/images","method":"GET","param":"Header User-Agent","attack":"Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 6.0)"},{"uri":"http://juice-shop.demo-apps.svc:3000/assets/public","method":"GET","param":"Header User-Agent","attack":"msnbot/1.1 (+http://search.msn.com/msnbot.htm)"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=polling&t=NB_4MNm&sid=Jqb5tSRY7TVpvWxfAAJP","method":"GET","param":"Header User-Agent","attack":"Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1)"},{"uri":"http://juice-shop.demo-apps.svc:3000/","method":"GET","param":"Header User-Agent","attack":"Mozilla/5.0 (iPhone; U; CPU iPhone OS 3_0 like Mac OS X; en-us) AppleWebKit/528.18 (KHTML, like Gecko) Version/4.0 Mobile/7A341 Safari/528.16"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=polling&t=NB_4MHS","method":"GET","param":"Header User-Agent","attack":"Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1)"},{"uri":"http://juice-shop.demo-apps.svc:3000/assets/public/images","method":"GET","param":"Header User-Agent","attack":"Mozilla/5.0 (compatible; Googlebot/2.1; +http://www.google.com/bot.html)"},{"uri":"http://juice-shop.demo-apps.svc:3000/assets","method":"GET","param":"Header User-Agent","attack":"Mozilla/5.0 (compatible; Googlebot/2.1; +http://www.google.com/bot.html)"},{"uri":"http://juice-shop.demo-apps.svc:3000/assets/i18n","method":"GET","param":"Header User-Agent","attack":"Mozilla/5.0 (compatible; Googlebot/2.1; +http://www.google.com/bot.html)"},{"uri":"http://juice-shop.demo-apps.svc:3000/assets/public/images","method":"GET","param":"Header User-Agent","attack":"Mozilla/5.0 (compatible; Yahoo! Slurp; http://help.yahoo.com/help/us/ysearch/slurp)"},{"uri":"http://juice-shop.demo-apps.svc:3000/assets/i18n","method":"GET","param":"Header User-Agent","attack":"Mozilla/5.0 (iPhone; U; CPU iPhone OS 3_0 like Mac OS X; en-us) AppleWebKit/528.18 (KHTML, like Gecko) Version/4.0 Mobile/7A341 Safari/528.16"},{"uri":"http://juice-shop.demo-apps.svc:3000/assets/public/images","method":"GET","param":"Header User-Agent","attack":"Mozilla/5.0 (iPhone; U; CPU iPhone OS 3_0 like Mac OS X; en-us) AppleWebKit/528.18 (KHTML, like Gecko) Version/4.0 Mobile/7A341 Safari/528.16"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=polling&t=NB_4MHS","method":"GET","param":"Header User-Agent","attack":"Mozilla/5.0 (compatible; Googlebot/2.1; +http://www.google.com/bot.html)"}]},"id":"123a006b-c743-40f5-9451-5c20ce9725f2"},{"name":"Cross-Domain Misconfiguration","description":"Web browser data loading may be possible, due to a Cross Origin Resource Sharing (CORS) misconfiguration on the web server","category":"Cross-Domain Misconfiguration","location":"http://juice-shop.demo-apps.svc:3000","osi_layer":"APPLICATION","severity":"MEDIUM","attributes":{"host":"juice-shop.demo-apps.svc","zap_confidence":"2","zap_count":"80","zap_solution":"Ensure that sensitive data is not available in an unauthenticated manner (using IP address white-listing, for instance).Configure the \"Access-Control-Allow-Origin\" HTTP header to a more restrictive set of domains, or remove all CORS headers entirely, to allow the web browser to enforce the Same Origin Policy (SOP) in a more restrictive manner.","zap_otherinfo":"The CORS misconfiguration on the web server permits cross-domain read requests from arbitrary third party domains, using unauthenticated APIs on this domain. Web browser implementations do not permit arbitrary third parties to read the response from authenticated APIs, however. This reduces the risk somewhat. This misconfiguration could be used by an attacker to access data that is available in an unauthenticated manner, but which uses some other form of security, such as IP address white-listing.","zap_reference":"http://www.hpenterprisesecurity.com/vulncat/en/vulncat/vb/html5_overly_permissive_cors_policy.html","zap_cweid":"264","zap_wascid":"14","zap_riskcode":"2","zap_pluginid":"10098","zap_finding_urls":[{"uri":"http://juice-shop.demo-apps.svc:3000/assets/public/images/products/fruit_press.jpg","method":"GET","evidence":"Access-Control-Allow-Origin: *"},{"uri":"http://juice-shop.demo-apps.svc:3000/api/Quantitys/","method":"GET","evidence":"Access-Control-Allow-Origin: *"},{"uri":"http://juice-shop.demo-apps.svc:3000/ftp/quarantine/juicy_malware_windows_64.exe.url","method":"GET","evidence":"Access-Control-Allow-Origin: *"},{"uri":"http://juice-shop.demo-apps.svc:3000/assets/public/images/products/coaster.jpg","method":"GET","evidence":"Access-Control-Allow-Origin: *"},{"uri":"http://juice-shop.demo-apps.svc:3000/api/Challenges/?name=Score%20Board","method":"GET","evidence":"Access-Control-Allow-Origin: *"},{"uri":"http://juice-shop.demo-apps.svc:3000/ftp/encrypt.pyc","method":"GET","evidence":"Access-Control-Allow-Origin: *"},{"uri":"http://juice-shop.demo-apps.svc:3000/ftp/quarantine","method":"GET","evidence":"Access-Control-Allow-Origin: *"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=polling&t=NB_4JpY&sid=EQLt4SVpH3WQQOI3AAJK","method":"GET","evidence":"Access-Control-Allow-Origin: *"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=polling&t=NB_4LmB","method":"GET","evidence":"Access-Control-Allow-Origin: *"},{"uri":"http://juice-shop.demo-apps.svc:3000/rest/admin/application-configuration","method":"GET","evidence":"Access-Control-Allow-Origin: *"},{"uri":"http://juice-shop.demo-apps.svc:3000/assets/public/images/products/banana_juice.jpg","method":"GET","evidence":"Access-Control-Allow-Origin: *"},{"uri":"http://juice-shop.demo-apps.svc:3000/rest/user/whoami","method":"GET","evidence":"Access-Control-Allow-Origin: *"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=polling&t=NB_45O-","method":"GET","evidence":"Access-Control-Allow-Origin: *"},{"uri":"http://juice-shop.demo-apps.svc:3000/assets/public/images/products/melon_bike.jpeg","method":"GET","evidence":"Access-Control-Allow-Origin: *"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=polling&t=NB_4MHS","method":"GET","evidence":"Access-Control-Allow-Origin: *"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=polling&t=NB_4Kme","method":"GET","evidence":"Access-Control-Allow-Origin: *"},{"uri":"http://juice-shop.demo-apps.svc:3000/assets/public/images/products/eggfruit_juice.jpg","method":"GET","evidence":"Access-Control-Allow-Origin: *"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=polling&t=NB_4KEV","method":"GET","evidence":"Access-Control-Allow-Origin: *"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=polling&t=NB_4EA-&sid=QRaHSlvGqPn23CrxAAJI","method":"GET","evidence":"Access-Control-Allow-Origin: *"},{"uri":"http://juice-shop.demo-apps.svc:3000/tutorial-es2015.js","method":"GET","evidence":"Access-Control-Allow-Origin: *"}]},"id":"a00c3441-618e-4f2e-a2c4-c0cc652881d8"},{"name":"Base64 Disclosure","description":"Base64 encoded data was disclosed by the application/web server. Note: in the interests of performance not all base64 strings in the response were analyzed individually, the entire response should be looked at by the analyst/security team/developer(s).","category":"Base64 Disclosure","location":"http://juice-shop.demo-apps.svc:3000","osi_layer":"APPLICATION","severity":"INFORMATIONAL","attributes":{"host":"juice-shop.demo-apps.svc","zap_confidence":"2","zap_count":"14","zap_solution":"Manually confirm that the Base64 data does not leak sensitive information, and that the data cannot be aggregated/used to exploit other vulnerabilities.","zap_otherinfo":"ٷ\\x001a�����\\x001f�\\x0016!�����g��ʟ�","zap_reference":"http://projects.webappsec.org/w/page/13246936/Information%20Leakage","zap_cweid":"200","zap_wascid":"13","zap_riskcode":"0","zap_pluginid":"10094","zap_finding_urls":[{"uri":"http://juice-shop.demo-apps.svc:3000/rest/products/search?q=","method":"GET","evidence":"2bca-IKmxdQfxxYh2+WZyvz2Z/b7yp/w"},{"uri":"http://juice-shop.demo-apps.svc:3000/main-es2015.js","method":"GET","evidence":"1AbKfgvw9psQ41NbLi8kufDQTezwG8DRZm"},{"uri":"http://juice-shop.demo-apps.svc:3000/rest/languages","method":"GET","evidence":"10d6-z3izUgDuZcb1ivzuRqqv9VdKZrI"},{"uri":"http://juice-shop.demo-apps.svc:3000/ftp/quarantine","method":"GET","evidence":"iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAMAAAAoLQ9TAAAABGdBTUEAALGPC/xhBQAAAWtQTFRFAAAA/PPQ9Nhc2q402qQ12qs2/PTX2pg12p81+/LM89NE9dto2q82+/fp2rM22qY39d6U+/bo2qo2/frx/vz32q812qs12qE279SU8c4w9NZP+/LK//367s9y7s925cp0/vzw9t92//342po2/vz25s1579B6+OSO2bQ0/v799NyT8tE79dld8Msm+OrC/vzx79KA2IYs7s6I9d6R4cJe9+OF/PLI/fry79OF/v30//328tWB89RJ8c9p8c0u9eCf//7+9txs6sts5Mdr+++5+u2z/vrv+/fq6cFz8dBs8tA57cpq+OaU9uGs27Y8//799NdX/PbY9uB89unJ//z14sNf+emh+emk+vDc+uys9+OL8dJy89NH+eic8tN5+OaV+OWR9N2n9dtl9t529+KF9+GB9Nue9NdU8tR/9t5y89qW9dpj89iO89eG/vvu2pQ12Y4z/vzy2Ict/vvv48dr/vzz4sNg///+2Igty3PqwQAAAAF0Uk5TAEDm2GYAAACtSURBVBjTY2AgA2iYlJWVhfohBPg0yx38y92dS0pKVOVBAqIi6sb2vsWWpfrFeTI8QAEhYQEta28nCwM1OVleZqCAmKCEkUdwYWmhQnFeOStQgL9cySqkNNDHVJGbiY0FKCCuYuYSGRsV5KgjxcXIARRQNncNj09JTgqw0ZbkZAcK5LuFJaRmZqfHeNnpSucDBQoiEtOycnIz4qI9bfUKQA6pKKqAgqIKQyK8BgAZ5yfODmnHrQAAAABJRU5ErkJggg=="},{"uri":"http://juice-shop.demo-apps.svc:3000/main-es5.js","method":"GET","evidence":"1AbKfgvw9psQ41NbLi8kufDQTezwG8DRZm"},{"uri":"http://juice-shop.demo-apps.svc:3000/api/Challenges/?name=Score%20Board","method":"GET","evidence":"20f-meUKV+WEJgl9v+gheG3ot2T8lWw"},{"uri":"http://juice-shop.demo-apps.svc:3000/rest/admin/application-configuration","method":"GET","evidence":"353c-5zeEPiUKTQwVmEEy6QdEpKtCBZM"},{"uri":"http://juice-shop.demo-apps.svc:3000/vendor-es2015.js","method":"GET","evidence":"0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"},{"uri":"http://juice-shop.demo-apps.svc:3000/ftp","method":"GET","evidence":"iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAMAAAAoLQ9TAAAABGdBTUEAALGPC/xhBQAAAWtQTFRFAAAA/PPQ9Nhc2q402qQ12qs2/PTX2pg12p81+/LM89NE9dto2q82+/fp2rM22qY39d6U+/bo2qo2/frx/vz32q812qs12qE279SU8c4w9NZP+/LK//367s9y7s925cp0/vzw9t92//342po2/vz25s1579B6+OSO2bQ0/v799NyT8tE79dld8Msm+OrC/vzx79KA2IYs7s6I9d6R4cJe9+OF/PLI/fry79OF/v30//328tWB89RJ8c9p8c0u9eCf//7+9txs6sts5Mdr+++5+u2z/vrv+/fq6cFz8dBs8tA57cpq+OaU9uGs27Y8//799NdX/PbY9uB89unJ//z14sNf+emh+emk+vDc+uys9+OL8dJy89NH+eic8tN5+OaV+OWR9N2n9dtl9t529+KF9+GB9Nue9NdU8tR/9t5y89qW9dpj89iO89eG/vvu2pQ12Y4z/vzy2Ict/vvv48dr/vzz4sNg///+2Igty3PqwQAAAAF0Uk5TAEDm2GYAAACtSURBVBjTY2AgA2iYlJWVhfohBPg0yx38y92dS0pKVOVBAqIi6sb2vsWWpfrFeTI8QAEhYQEta28nCwM1OVleZqCAmKCEkUdwYWmhQnFeOStQgL9cySqkNNDHVJGbiY0FKCCuYuYSGRsV5KgjxcXIARRQNncNj09JTgqw0ZbkZAcK5LuFJaRmZqfHeNnpSucDBQoiEtOycnIz4qI9bfUKQA6pKKqAgqIKQyK8BgAZ5yfODmnHrQAAAABJRU5ErkJggg=="},{"uri":"http://juice-shop.demo-apps.svc:3000/api/Quantitys/","method":"GET","evidence":"13c2-YZnu7Poyut6tOnXqggfs4IrmzZo"},{"uri":"http://juice-shop.demo-apps.svc:3000/rest/captcha/","method":"GET","evidence":"30-ynPBjsSc6cJ6iwKnFhStR2ZeQOI"},{"uri":"http://juice-shop.demo-apps.svc:3000/vendor-es5.js","method":"GET","evidence":"0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"},{"uri":"http://juice-shop.demo-apps.svc:3000/robots.txt","method":"GET","evidence":"1c-8HgF6mNyhsSFK0pascC9uB0wjX0"},{"uri":"http://juice-shop.demo-apps.svc:3000/rest/admin/application-version","method":"GET","evidence":"14-q5yR/Ty1zvj1FGW0EQicfxYEQoM"}]},"id":"93f659f0-0d9d-4c44-b6c0-e68946bd22b3"},{"name":"Hidden File Found","description":"A sensitive file was identified as accessible or available. This may leak administrative, configuration, or credential information which can be leveraged by a malicious individual to further attack the system or conduct social engineering efforts.","category":"Hidden File Found","location":"http://juice-shop.demo-apps.svc:3000","osi_layer":"APPLICATION","severity":"MEDIUM","attributes":{"host":"juice-shop.demo-apps.svc","zap_confidence":"1","zap_count":"33","zap_solution":"Consider whether or not the component is actually required in production, if it isn't then disable it. If it is then ensure access to it requires appropriate authentication and authorization, or limit exposure to internal systems or specific source IPs, etc.","zap_otherinfo":"adminer","zap_reference":"https://blog.hboeck.de/archives/892-Introducing-Snallygaster-a-Tool-to-Scan-for-Secrets-on-Web-Servers.html","zap_cweid":"538","zap_wascid":"13","zap_riskcode":"2","zap_pluginid":"40035","zap_finding_urls":[{"uri":"http://juice-shop.demo-apps.svc:3000/adminer.php","method":"GET","evidence":"HTTP/1.1 200 OK"},{"uri":"http://juice-shop.demo-apps.svc:3000/.git/config","method":"GET","evidence":"HTTP/1.1 200 OK"},{"uri":"http://juice-shop.demo-apps.svc:3000/FileZilla.xml","method":"GET","evidence":"HTTP/1.1 200 OK"},{"uri":"http://juice-shop.demo-apps.svc:3000/app/etc/local.xml","method":"GET","evidence":"HTTP/1.1 200 OK"},{"uri":"http://juice-shop.demo-apps.svc:3000/config/databases.yml","method":"GET","evidence":"HTTP/1.1 200 OK"},{"uri":"http://juice-shop.demo-apps.svc:3000/id_dsa","method":"GET","evidence":"HTTP/1.1 200 OK"},{"uri":"http://juice-shop.demo-apps.svc:3000/.ssh/id_rsa","method":"GET","evidence":"HTTP/1.1 200 OK"},{"uri":"http://juice-shop.demo-apps.svc:3000/.DS_Store","method":"GET","evidence":"HTTP/1.1 200 OK"},{"uri":"http://juice-shop.demo-apps.svc:3000/sitemanager.xml","method":"GET","evidence":"HTTP/1.1 200 OK"},{"uri":"http://juice-shop.demo-apps.svc:3000/sites/default/private/files/backup_migrate/scheduled/test.txt","method":"GET","evidence":"HTTP/1.1 200 OK"},{"uri":"http://juice-shop.demo-apps.svc:3000/core","method":"GET","evidence":"HTTP/1.1 200 OK"},{"uri":"http://juice-shop.demo-apps.svc:3000/CHANGELOG.txt","method":"GET","evidence":"HTTP/1.1 200 OK"},{"uri":"http://juice-shop.demo-apps.svc:3000/WinSCP.ini","method":"GET","evidence":"HTTP/1.1 200 OK"},{"uri":"http://juice-shop.demo-apps.svc:3000/config/database.yml","method":"GET","evidence":"HTTP/1.1 200 OK"},{"uri":"http://juice-shop.demo-apps.svc:3000/winscp.ini","method":"GET","evidence":"HTTP/1.1 200 OK"},{"uri":"http://juice-shop.demo-apps.svc:3000/DEADJOE","method":"GET","evidence":"HTTP/1.1 200 OK"},{"uri":"http://juice-shop.demo-apps.svc:3000/id_rsa","method":"GET","evidence":"HTTP/1.1 200 OK"},{"uri":"http://juice-shop.demo-apps.svc:3000/server.key","method":"GET","evidence":"HTTP/1.1 200 OK"},{"uri":"http://juice-shop.demo-apps.svc:3000/.idea/WebServers.xml","method":"GET","evidence":"HTTP/1.1 200 OK"},{"uri":"http://juice-shop.demo-apps.svc:3000/.ssh/id_dsa","method":"GET","evidence":"HTTP/1.1 200 OK"}]},"id":"b6601654-e2cb-42f2-ae14-95cc66d080ac"},{"name":"Feature Policy Header Not Set","description":"Feature Policy Header is an added layer of security that helps to restrict from unauthorized access or usage of browser/client features by web resources. This policy ensures the user privacy by limiting or specifying the features of the browsers can be used by the web resources. Feature Policy provides a set of standard HTTP headers that allow website owners to limit which features of browsers can be used by the page such as camera, microphone, location, full screen etc.","category":"Feature Policy Header Not Set","location":"http://juice-shop.demo-apps.svc:3000","osi_layer":"APPLICATION","severity":"LOW","attributes":{"host":"juice-shop.demo-apps.svc","zap_confidence":"2","zap_count":"22","zap_solution":"Ensure that your web server, application server, load balancer, etc. is configured to set the Feature-Policy header.","zap_otherinfo":null,"zap_reference":"https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Feature-Policyhttps://developers.google.com/web/updates/2018/06/feature-policyhttps://scotthelme.co.uk/a-new-security-header-feature-policy/https://w3c.github.io/webappsec-feature-policy/https://www.smashingmagazine.com/2018/12/feature-policy/","zap_cweid":"16","zap_wascid":"15","zap_riskcode":"1","zap_pluginid":"10063","zap_finding_urls":[{"uri":"http://juice-shop.demo-apps.svc:3000/ftp/quarantine/juicy_malware_linux_64.url","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/ftp","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/ftp/quarantine/juicy_malware_macos_64.url","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/polyfills-es2015.js","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/ftp/eastere.gg","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/vendor-es5.js","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/ftp/encrypt.pyc","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/main-es2015.js","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/polyfills-es5.js","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/runtime-es5.js","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/vendor-es2015.js","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/ftp/quarantine/juicy_malware_windows_64.exe.url","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/runtime-es2015.js","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/sitemap.xml","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/ftp/suspicious_errors.yml","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/ftp/package.json.bak","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/main-es5.js","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/tutorial-es2015.js","method":"GET"}]},"id":"ffb9e114-d582-41d0-b362-5512b8ecad6d"},{"name":"Cookie Slack Detector","description":"Repeated GET requests: drop a different cookie each time, followed by normal request with all cookies to stabilize session, compare responses against original baseline GET. This can reveal areas where cookie based authentication/attributes are not actually enforced.","category":"Cookie Slack Detector","location":"http://juice-shop.demo-apps.svc:3000","osi_layer":"APPLICATION","severity":"INFORMATIONAL","attributes":{"host":"juice-shop.demo-apps.svc","zap_confidence":"1","zap_count":"35","zap_solution":null,"zap_otherinfo":"Cookies that don't have expected effects can reveal flaws in application logic. In the worst case, this can reveal where authentication via cookie token(s) is not actually enforced.These cookies affected the response: These cookies did NOT affect the response: io,language","zap_reference":"http://projects.webappsec.org/Fingerprinting","zap_cweid":"200","zap_wascid":"45","zap_riskcode":"0","zap_pluginid":"90027","zap_finding_urls":[{"uri":"http://juice-shop.demo-apps.svc:3000/assets/public/images/products/melon_bike.jpeg","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/assets/public/images/products/banana_juice.jpg","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/rest/user","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=websocket&sid=SUkCn1d1AMCb92teAAJD","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/assets/public/images/products/carrot_juice.jpeg","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=polling&t=NB_4MNm&sid=Jqb5tSRY7TVpvWxfAAJP","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/rest/admin/application-version","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/assets/public/favicon_js.ico","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/assets/public/images/products","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/rest/languages","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/rest/admin/application-configuration","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/rest/captcha/","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/api","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/assets/public/images/products/coaster.jpg","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/assets/public/images/products/eggfruit_juice.jpg","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/rest/products","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/rest/products/search?q=","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/assets/public/images/products/apple_juice.jpg","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/assets/public/images/products/artwork.jpg","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/assets/public/images/products/apple_pressings.jpg","method":"GET"}]},"id":"0f363fea-8f7f-4dbf-a894-65eb6596dfad"},{"name":"Cookie Without SameSite Attribute","description":"A cookie has been set without the SameSite attribute, which means that the cookie can be sent as a result of a 'cross-site' request. The SameSite attribute is an effective counter measure to cross-site request forgery, cross-site script inclusion, and timing attacks.","category":"Cookie Without SameSite Attribute","location":"http://juice-shop.demo-apps.svc:3000","osi_layer":"APPLICATION","severity":"LOW","attributes":{"host":"juice-shop.demo-apps.svc","zap_confidence":"2","zap_count":"26","zap_solution":"Ensure that the SameSite attribute is set to either 'lax' or ideally 'strict' for all cookies.","zap_otherinfo":null,"zap_reference":"https://tools.ietf.org/html/draft-ietf-httpbis-cookie-same-site","zap_cweid":"16","zap_wascid":"13","zap_riskcode":"1","zap_pluginid":"10054","zap_finding_urls":[{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=polling&t=NB_4LwY&sid=7d6AHoAKV74kodunAAJO","method":"GET","param":"io","evidence":"Set-Cookie: io"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=polling&t=NB_4Jif","method":"GET","param":"io","evidence":"Set-Cookie: io"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=polling&t=NB_4Dyx","method":"GET","param":"io","evidence":"Set-Cookie: io"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=polling&t=NB_48f7","method":"GET","param":"io","evidence":"Set-Cookie: io"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=polling&t=NB_45aF&sid=SUkCn1d1AMCb92teAAJD","method":"GET","param":"io","evidence":"Set-Cookie: io"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=polling&t=NB_48lc&sid=GwYaNaiL4IO2N-BFAAJF","method":"GET","param":"io","evidence":"Set-Cookie: io"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=polling&t=NB_45O-","method":"GET","param":"io","evidence":"Set-Cookie: io"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=polling&t=NB_4JpY&sid=EQLt4SVpH3WQQOI3AAJK","method":"GET","param":"io","evidence":"Set-Cookie: io"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=polling&t=NB_468h&sid=gcMvRjo3zdXdJmvCAAJE","method":"GET","param":"io","evidence":"Set-Cookie: io"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=polling&t=NB_4LmB","method":"GET","param":"io","evidence":"Set-Cookie: io"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=polling&t=NB_4KEV","method":"GET","param":"io","evidence":"Set-Cookie: io"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=polling&t=NB_4Kme","method":"GET","param":"io","evidence":"Set-Cookie: io"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=polling&t=NB_4AGr","method":"GET","param":"io","evidence":"Set-Cookie: io"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=polling&t=NB_4Ktj&sid=zQ0Mw6vwMbX9lKFCAAJM","method":"GET","param":"io","evidence":"Set-Cookie: io"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=polling&t=NB_4MHS","method":"GET","param":"io","evidence":"Set-Cookie: io"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=polling&t=NB_4AN6&sid=vAZyt0pkAtDNJ6WaAAJG","method":"GET","param":"io","evidence":"Set-Cookie: io"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=polling&t=NB_4MNm&sid=Jqb5tSRY7TVpvWxfAAJP","method":"GET","param":"io","evidence":"Set-Cookie: io"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=polling&t=NB_4LNQ&sid=k8MuVo8TgUS6THldAAJN","method":"GET","param":"io","evidence":"Set-Cookie: io"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=polling&t=NB_4GWW","method":"GET","param":"io","evidence":"Set-Cookie: io"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=polling&t=NB_4KLh&sid=p8N4l1VcorqI-28DAAJL","method":"GET","param":"io","evidence":"Set-Cookie: io"}]},"id":"67c8d6ba-1aff-43aa-bf93-d05892d7eaa8"},{"name":"Backup File Disclosure","description":"A backup of the file was disclosed by the web server","category":"Backup File Disclosure","location":"http://juice-shop.demo-apps.svc:3000","osi_layer":"APPLICATION","severity":"MEDIUM","attributes":{"host":"juice-shop.demo-apps.svc","zap_confidence":"2","zap_count":"67","zap_solution":"Do not edit files in-situ on the web server, and ensure that un-necessary files (including hidden files) are removed from the web server.","zap_otherinfo":"http://juice-shop.demo-apps.svc:3000/rest/user","zap_reference":"https://cwe.mitre.org/data/definitions/530.htmlhttps://owasp.org/www-project-web-security-testing-guide/v41/4-Web_Application_Security_Testing/02-Configuration_and_Deployment_Management_Testing/04-Review_Old_Backup_and_Unreferenced_Files_for_Sensitive_Information.html","zap_cweid":"530","zap_wascid":"34","zap_riskcode":"2","zap_pluginid":"10095","zap_finding_urls":[{"uri":"http://juice-shop.demo-apps.svc:3000/restbackup/user","method":"GET","attack":"http://juice-shop.demo-apps.svc:3000/restbackup/user","evidence":"A backup of [http://juice-shop.demo-apps.svc:3000/rest/user] is available at [http://juice-shop.demo-apps.svc:3000/restbackup/user]"},{"uri":"http://juice-shop.demo-apps.svc:3000/ftp/Copy%20(3)%20of%20legal.md","method":"GET","attack":"http://juice-shop.demo-apps.svc:3000/ftp/Copy (3) of legal.md","evidence":"A backup of [http://juice-shop.demo-apps.svc:3000/ftp/legal.md] is available at [http://juice-shop.demo-apps.svc:3000/ftp/Copy (3) of legal.md]"},{"uri":"http://juice-shop.demo-apps.svc:3000/rest.log","method":"GET","attack":"http://juice-shop.demo-apps.svc:3000/rest.log","evidence":"A backup of [http://juice-shop.demo-apps.svc:3000/rest] is available at [http://juice-shop.demo-apps.svc:3000/rest.log]"},{"uri":"http://juice-shop.demo-apps.svc:3000/ftp/Copy%20(2)%20of%20legal.md","method":"GET","attack":"http://juice-shop.demo-apps.svc:3000/ftp/Copy (2) of legal.md","evidence":"A backup of [http://juice-shop.demo-apps.svc:3000/ftp/legal.md] is available at [http://juice-shop.demo-apps.svc:3000/ftp/Copy (2) of legal.md]"},{"uri":"http://juice-shop.demo-apps.svc:3000/ftp/Copy%20(3)%20of%20acquisitions.md","method":"GET","attack":"http://juice-shop.demo-apps.svc:3000/ftp/Copy (3) of acquisitions.md","evidence":"A backup of [http://juice-shop.demo-apps.svc:3000/ftp/acquisitions.md] is available at [http://juice-shop.demo-apps.svc:3000/ftp/Copy (3) of acquisitions.md]"},{"uri":"http://juice-shop.demo-apps.svc:3000/ftp/legal%20-%20Copy%20(3).md","method":"GET","attack":"http://juice-shop.demo-apps.svc:3000/ftp/legal - Copy (3).md","evidence":"A backup of [http://juice-shop.demo-apps.svc:3000/ftp/legal.md] is available at [http://juice-shop.demo-apps.svc:3000/ftp/legal - Copy (3).md]"},{"uri":"http://juice-shop.demo-apps.svc:3000/restbackup/languages","method":"GET","attack":"http://juice-shop.demo-apps.svc:3000/restbackup/languages","evidence":"A backup of [http://juice-shop.demo-apps.svc:3000/rest/languages] is available at [http://juice-shop.demo-apps.svc:3000/restbackup/languages]"},{"uri":"http://juice-shop.demo-apps.svc:3000/rest%20-%20Copy","method":"GET","attack":"http://juice-shop.demo-apps.svc:3000/rest - Copy","evidence":"A backup of [http://juice-shop.demo-apps.svc:3000/rest] is available at [http://juice-shop.demo-apps.svc:3000/rest - Copy]"},{"uri":"http://juice-shop.demo-apps.svc:3000/rest.backup","method":"GET","attack":"http://juice-shop.demo-apps.svc:3000/rest.backup","evidence":"A backup of [http://juice-shop.demo-apps.svc:3000/rest] is available at [http://juice-shop.demo-apps.svc:3000/rest.backup]"},{"uri":"http://juice-shop.demo-apps.svc:3000/api%20-%20Copy%20(2)","method":"GET","attack":"http://juice-shop.demo-apps.svc:3000/api - Copy (2)","evidence":"A backup of [http://juice-shop.demo-apps.svc:3000/api] is available at [http://juice-shop.demo-apps.svc:3000/api - Copy (2)]"},{"uri":"http://juice-shop.demo-apps.svc:3000/rest%20-%20Copy%20(3)/products","method":"GET","attack":"http://juice-shop.demo-apps.svc:3000/rest - Copy (3)/products","evidence":"A backup of [http://juice-shop.demo-apps.svc:3000/rest/products] is available at [http://juice-shop.demo-apps.svc:3000/rest - Copy (3)/products]"},{"uri":"http://juice-shop.demo-apps.svc:3000/ftp/legal%20-%20Copy.md","method":"GET","attack":"http://juice-shop.demo-apps.svc:3000/ftp/legal - Copy.md","evidence":"A backup of [http://juice-shop.demo-apps.svc:3000/ftp/legal.md] is available at [http://juice-shop.demo-apps.svc:3000/ftp/legal - Copy.md]"},{"uri":"http://juice-shop.demo-apps.svc:3000/rest%20-%20Copy/languages","method":"GET","attack":"http://juice-shop.demo-apps.svc:3000/rest - Copy/languages","evidence":"A backup of [http://juice-shop.demo-apps.svc:3000/rest/languages] is available at [http://juice-shop.demo-apps.svc:3000/rest - Copy/languages]"},{"uri":"http://juice-shop.demo-apps.svc:3000/ftp/acquisitions%20-%20Copy%20(3).md","method":"GET","attack":"http://juice-shop.demo-apps.svc:3000/ftp/acquisitions - Copy (3).md","evidence":"A backup of [http://juice-shop.demo-apps.svc:3000/ftp/acquisitions.md] is available at [http://juice-shop.demo-apps.svc:3000/ftp/acquisitions - Copy (3).md]"},{"uri":"http://juice-shop.demo-apps.svc:3000/ftp/announcement_encrypted%20-%20Copy%20(3).md","method":"GET","attack":"http://juice-shop.demo-apps.svc:3000/ftp/announcement_encrypted - Copy (3).md","evidence":"A backup of [http://juice-shop.demo-apps.svc:3000/ftp/announcement_encrypted.md] is available at [http://juice-shop.demo-apps.svc:3000/ftp/announcement_encrypted - Copy (3).md]"},{"uri":"http://juice-shop.demo-apps.svc:3000/api.bac","method":"GET","attack":"http://juice-shop.demo-apps.svc:3000/api.bac","evidence":"A backup of [http://juice-shop.demo-apps.svc:3000/api] is available at [http://juice-shop.demo-apps.svc:3000/api.bac]"},{"uri":"http://juice-shop.demo-apps.svc:3000/ftp/Copy%20of%20acquisitions.md","method":"GET","attack":"http://juice-shop.demo-apps.svc:3000/ftp/Copy of acquisitions.md","evidence":"A backup of [http://juice-shop.demo-apps.svc:3000/ftp/acquisitions.md] is available at [http://juice-shop.demo-apps.svc:3000/ftp/Copy of acquisitions.md]"},{"uri":"http://juice-shop.demo-apps.svc:3000/ftp/legalbackup.md","method":"GET","attack":"http://juice-shop.demo-apps.svc:3000/ftp/legalbackup.md","evidence":"A backup of [http://juice-shop.demo-apps.svc:3000/ftp/legal.md] is available at [http://juice-shop.demo-apps.svc:3000/ftp/legalbackup.md]"},{"uri":"http://juice-shop.demo-apps.svc:3000/api.backup","method":"GET","attack":"http://juice-shop.demo-apps.svc:3000/api.backup","evidence":"A backup of [http://juice-shop.demo-apps.svc:3000/api] is available at [http://juice-shop.demo-apps.svc:3000/api.backup]"},{"uri":"http://juice-shop.demo-apps.svc:3000/api.old","method":"GET","attack":"http://juice-shop.demo-apps.svc:3000/api.old","evidence":"A backup of [http://juice-shop.demo-apps.svc:3000/api] is available at [http://juice-shop.demo-apps.svc:3000/api.old]"}]},"id":"0e3dc163-4bfe-4640-bd08-597320329c87"},{"name":"Timestamp Disclosure - Unix","description":"A timestamp was disclosed by the application/web server - Unix","category":"Timestamp Disclosure - Unix","location":"http://juice-shop.demo-apps.svc:3000","osi_layer":"APPLICATION","severity":"INFORMATIONAL","attributes":{"host":"juice-shop.demo-apps.svc","zap_confidence":"1","zap_count":"25","zap_solution":"Manually confirm that the timestamp data is not sensitive, and that the data cannot be aggregated to disclose exploitable patterns.","zap_otherinfo":"1803700518, which evaluates to: 2027-02-27 03:55:18","zap_reference":"http://projects.webappsec.org/w/page/13246936/Information%20Leakage","zap_cweid":"200","zap_wascid":"13","zap_riskcode":"0","zap_pluginid":"10096","zap_finding_urls":[{"uri":"http://juice-shop.demo-apps.svc:3000/vendor-es5.js","method":"GET","evidence":"1803700518"},{"uri":"http://juice-shop.demo-apps.svc:3000/vendor-es2015.js","method":"GET","evidence":"1801949248"},{"uri":"http://juice-shop.demo-apps.svc:3000/vendor-es2015.js","method":"GET","evidence":"0000051215"},{"uri":"http://juice-shop.demo-apps.svc:3000/rest/products/search?q=","method":"GET","evidence":"1969196030"},{"uri":"http://juice-shop.demo-apps.svc:3000/vendor-es5.js","method":"GET","evidence":"0000039834"},{"uri":"http://juice-shop.demo-apps.svc:3000/rest/admin/application-configuration","method":"GET","evidence":"1970691216"},{"uri":"http://juice-shop.demo-apps.svc:3000/vendor-es2015.js","method":"GET","evidence":"1801948466"},{"uri":"http://juice-shop.demo-apps.svc:3000/styles.css","method":"GET","evidence":"33333333"},{"uri":"http://juice-shop.demo-apps.svc:3000/vendor-es2015.js","method":"GET","evidence":"0000039834"},{"uri":"http://juice-shop.demo-apps.svc:3000/vendor-es5.js","method":"GET","evidence":"0000051215"},{"uri":"http://juice-shop.demo-apps.svc:3000/vendor-es5.js","method":"GET","evidence":"0000000004"},{"uri":"http://juice-shop.demo-apps.svc:3000/styles.css","method":"GET","evidence":"33335333"},{"uri":"http://juice-shop.demo-apps.svc:3000/vendor-es2015.js","method":"GET","evidence":"0000000005"},{"uri":"http://juice-shop.demo-apps.svc:3000/vendor-es2015.js","method":"GET","evidence":"0000000004"},{"uri":"http://juice-shop.demo-apps.svc:3000/polyfills-es5.js","method":"GET","evidence":"62425156"},{"uri":"http://juice-shop.demo-apps.svc:3000/styles.css","method":"GET","evidence":"33334333"},{"uri":"http://juice-shop.demo-apps.svc:3000/vendor-es5.js","method":"GET","evidence":"1801949248"},{"uri":"http://juice-shop.demo-apps.svc:3000/rest/admin/application-configuration","method":"GET","evidence":"1969196030"},{"uri":"http://juice-shop.demo-apps.svc:3000/vendor-es5.js","method":"GET","evidence":"0000000005"},{"uri":"http://juice-shop.demo-apps.svc:3000/vendor-es2015.js","method":"GET","evidence":"179464974"}]},"id":"cf709dc0-111d-46d2-b435-81a75dc53baf"},{"name":"Session ID in URL Rewrite","description":"URL rewrite is used to track user session ID. The session ID may be disclosed via cross-site referer header. In addition, the session ID might be stored in browser history or server logs.","category":"Session ID in URL Rewrite","location":"http://juice-shop.demo-apps.svc:3000","osi_layer":"APPLICATION","severity":"MEDIUM","attributes":{"host":"juice-shop.demo-apps.svc","zap_confidence":"3","zap_count":"26","zap_solution":"For secure content, put session ID in a cookie. To be even more secure consider using a combination of cookie and URL rewrite.","zap_otherinfo":null,"zap_reference":"http://seclists.org/lists/webappsec/2002/Oct-Dec/0111.html","zap_cweid":"200","zap_wascid":"13","zap_riskcode":"2","zap_pluginid":"3","zap_finding_urls":[{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=polling&t=NB_4AN6&sid=vAZyt0pkAtDNJ6WaAAJG","method":"GET","param":"sid","evidence":"vAZyt0pkAtDNJ6WaAAJG"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=websocket&sid=vAZyt0pkAtDNJ6WaAAJG","method":"GET","param":"sid","evidence":"vAZyt0pkAtDNJ6WaAAJG"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=websocket&sid=Zf_m8hPQmZ3Qj-zKAAJJ","method":"GET","param":"sid","evidence":"Zf_m8hPQmZ3Qj-zKAAJJ"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=websocket&sid=k8MuVo8TgUS6THldAAJN","method":"GET","param":"sid","evidence":"k8MuVo8TgUS6THldAAJN"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=websocket&sid=Jqb5tSRY7TVpvWxfAAJP","method":"GET","param":"sid","evidence":"Jqb5tSRY7TVpvWxfAAJP"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=polling&t=NB_4MNm&sid=Jqb5tSRY7TVpvWxfAAJP","method":"GET","param":"sid","evidence":"Jqb5tSRY7TVpvWxfAAJP"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=websocket&sid=p8N4l1VcorqI-28DAAJL","method":"GET","param":"sid","evidence":"p8N4l1VcorqI-28DAAJL"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=polling&t=NB_45aF&sid=SUkCn1d1AMCb92teAAJD","method":"GET","param":"sid","evidence":"SUkCn1d1AMCb92teAAJD"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=polling&t=NB_4JpY&sid=EQLt4SVpH3WQQOI3AAJK","method":"GET","param":"sid","evidence":"EQLt4SVpH3WQQOI3AAJK"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=polling&t=NB_4EA-&sid=QRaHSlvGqPn23CrxAAJI","method":"GET","param":"sid","evidence":"QRaHSlvGqPn23CrxAAJI"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=polling&t=NB_4KLh&sid=p8N4l1VcorqI-28DAAJL","method":"GET","param":"sid","evidence":"p8N4l1VcorqI-28DAAJL"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=polling&t=NB_4GeT&sid=Zf_m8hPQmZ3Qj-zKAAJJ","method":"GET","param":"sid","evidence":"Zf_m8hPQmZ3Qj-zKAAJJ"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=websocket&sid=gcMvRjo3zdXdJmvCAAJE","method":"GET","param":"sid","evidence":"gcMvRjo3zdXdJmvCAAJE"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=websocket&sid=GwYaNaiL4IO2N-BFAAJF","method":"GET","param":"sid","evidence":"GwYaNaiL4IO2N-BFAAJF"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=websocket&sid=ylY-c4ef8ITTNed2AAJH","method":"GET","param":"sid","evidence":"ylY-c4ef8ITTNed2AAJH"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=polling&t=NB_48lc&sid=GwYaNaiL4IO2N-BFAAJF","method":"GET","param":"sid","evidence":"GwYaNaiL4IO2N-BFAAJF"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=websocket&sid=7d6AHoAKV74kodunAAJO","method":"GET","param":"sid","evidence":"7d6AHoAKV74kodunAAJO"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=websocket&sid=SUkCn1d1AMCb92teAAJD","method":"GET","param":"sid","evidence":"SUkCn1d1AMCb92teAAJD"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=websocket&sid=QRaHSlvGqPn23CrxAAJI","method":"GET","param":"sid","evidence":"QRaHSlvGqPn23CrxAAJI"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=websocket&sid=EQLt4SVpH3WQQOI3AAJK","method":"GET","param":"sid","evidence":"EQLt4SVpH3WQQOI3AAJK"}]},"id":"70e9c616-6682-4ace-8cc9-4442a9979195"},{"name":"Cross-Domain JavaScript Source File Inclusion","description":"The page includes one or more script files from a third-party domain.","category":"Cross-Domain JavaScript Source File Inclusion","location":"http://juice-shop.demo-apps.svc:3000","osi_layer":"APPLICATION","severity":"LOW","attributes":{"host":"juice-shop.demo-apps.svc","zap_confidence":"2","zap_count":"6","zap_solution":"Ensure JavaScript source files are loaded from only trusted sources, and the sources can't be controlled by end users of the application.","zap_otherinfo":null,"zap_reference":null,"zap_cweid":"829","zap_wascid":"15","zap_riskcode":"1","zap_pluginid":"10017","zap_finding_urls":[{"uri":"http://juice-shop.demo-apps.svc:3000/","method":"GET","param":"//cdnjs.cloudflare.com/ajax/libs/cookieconsent2/3.1.0/cookieconsent.min.js","evidence":""},{"uri":"http://juice-shop.demo-apps.svc:3000/","method":"GET","param":"//cdnjs.cloudflare.com/ajax/libs/jquery/2.2.4/jquery.min.js","evidence":""},{"uri":"http://juice-shop.demo-apps.svc:3000","method":"GET","param":"//cdnjs.cloudflare.com/ajax/libs/cookieconsent2/3.1.0/cookieconsent.min.js","evidence":""},{"uri":"http://juice-shop.demo-apps.svc:3000/sitemap.xml","method":"GET","param":"//cdnjs.cloudflare.com/ajax/libs/cookieconsent2/3.1.0/cookieconsent.min.js","evidence":""},{"uri":"http://juice-shop.demo-apps.svc:3000","method":"GET","param":"//cdnjs.cloudflare.com/ajax/libs/jquery/2.2.4/jquery.min.js","evidence":""},{"uri":"http://juice-shop.demo-apps.svc:3000/sitemap.xml","method":"GET","param":"//cdnjs.cloudflare.com/ajax/libs/jquery/2.2.4/jquery.min.js","evidence":""}]},"id":"d38228fd-d990-4dd2-bf8d-f1b72dd17830"},{"name":"Server Leaks Information via \"X-Powered-By\" HTTP Response Header Field(s)","description":"The web/application server is leaking information via one or more \"X-Powered-By\" HTTP response headers. Access to such information may facilitate attackers identifying other frameworks/components your web application is reliant upon and the vulnerabilities such components may be subject to.","category":"Server Leaks Information via \"X-Powered-By\" HTTP Response Header Field(s)","location":"http://juice-shop.demo-apps.svc:3000","osi_layer":"APPLICATION","severity":"LOW","attributes":{"host":"juice-shop.demo-apps.svc","zap_confidence":"2","zap_count":"54","zap_solution":"Ensure that your web server, application server, load balancer, etc. is configured to suppress \"X-Powered-By\" headers.","zap_otherinfo":null,"zap_reference":"http://blogs.msdn.com/b/varunm/archive/2013/04/23/remove-unwanted-http-response-headers.aspxhttp://www.troyhunt.com/2012/02/shhh-dont-let-your-response-headers.html","zap_cweid":"200","zap_wascid":"13","zap_riskcode":"1","zap_pluginid":"10037","zap_finding_urls":[{"uri":"http://juice-shop.demo-apps.svc:3000/robots.txt","method":"GET","evidence":"X-Powered-By: Express"},{"uri":"http://juice-shop.demo-apps.svc:3000/rest/captcha/","method":"GET","evidence":"X-Powered-By: Express"},{"uri":"http://juice-shop.demo-apps.svc:3000/rest/products/search?q=","method":"GET","evidence":"X-Powered-By: Express"},{"uri":"http://juice-shop.demo-apps.svc:3000/font-mfizz.woff","method":"GET","evidence":"X-Powered-By: Express"},{"uri":"http://juice-shop.demo-apps.svc:3000/assets/public/images/products/carrot_juice.jpeg","method":"GET","evidence":"X-Powered-By: Express"},{"uri":"http://juice-shop.demo-apps.svc:3000/assets/public/favicon_js.ico","method":"GET","evidence":"X-Powered-By: Express"},{"uri":"http://juice-shop.demo-apps.svc:3000/runtime-es5.js","method":"GET","evidence":"X-Powered-By: Express"},{"uri":"http://juice-shop.demo-apps.svc:3000/assets/public/images/products/lemon_juice.jpg","method":"GET","evidence":"X-Powered-By: Express"},{"uri":"http://juice-shop.demo-apps.svc:3000/ftp/legal.md","method":"GET","evidence":"X-Powered-By: Express"},{"uri":"http://juice-shop.demo-apps.svc:3000/sitemap.xml","method":"GET","evidence":"X-Powered-By: Express"},{"uri":"http://juice-shop.demo-apps.svc:3000/assets/public/images/products/fan_girlie.jpg","method":"GET","evidence":"X-Powered-By: Express"},{"uri":"http://juice-shop.demo-apps.svc:3000/main-es2015.js","method":"GET","evidence":"X-Powered-By: Express"},{"uri":"http://juice-shop.demo-apps.svc:3000/assets/public/images/JuiceShop_Logo.png","method":"GET","evidence":"X-Powered-By: Express"},{"uri":"http://juice-shop.demo-apps.svc:3000/assets/public/images/products/melon_bike.jpeg","method":"GET","evidence":"X-Powered-By: Express"},{"uri":"http://juice-shop.demo-apps.svc:3000/assets/public/images/products/green_smoothie.jpg","method":"GET","evidence":"X-Powered-By: Express"},{"uri":"http://juice-shop.demo-apps.svc:3000/vendor-es2015.js","method":"GET","evidence":"X-Powered-By: Express"},{"uri":"http://juice-shop.demo-apps.svc:3000/assets/public/images/products/banana_juice.jpg","method":"GET","evidence":"X-Powered-By: Express"},{"uri":"http://juice-shop.demo-apps.svc:3000/ftp/suspicious_errors.yml","method":"GET","evidence":"X-Powered-By: Express"},{"uri":"http://juice-shop.demo-apps.svc:3000/rest/user/whoami","method":"GET","evidence":"X-Powered-By: Express"},{"uri":"http://juice-shop.demo-apps.svc:3000","method":"GET","evidence":"X-Powered-By: Express"}]},"id":"726653f1-416c-489e-917a-6566aa46da80"},{"name":"Storable and Cacheable Content","description":"The response contents are storable by caching components such as proxy servers, and may be retrieved directly from the cache, rather than from the origin server by the caching servers, in response to similar requests from other users. If the response data is sensitive, personal or user-specific, this may result in sensitive information being leaked. In some cases, this may even result in a user gaining complete control of the session of another user, depending on the configuration of the caching components in use in their environment. This is primarily an issue where \"shared\" caching servers such as \"proxy\" caches are configured on the local network. This configuration is typically found in corporate or educational environments, for instance.","category":"Storable and Cacheable Content","location":"http://juice-shop.demo-apps.svc:3000","osi_layer":"APPLICATION","severity":"INFORMATIONAL","attributes":{"host":"juice-shop.demo-apps.svc","zap_confidence":"2","zap_count":"37","zap_solution":"Validate that the response does not contain sensitive, personal or user-specific information. If it does, consider the use of the following HTTP response headers, to limit, or prevent the content being stored and retrieved from the cache by another user:Cache-Control: no-cache, no-store, must-revalidate, privatePragma: no-cacheExpires: 0This configuration directs both HTTP 1.0 and HTTP 1.1 compliant caching servers to not store the response, and to not retrieve the response (without validation) from the cache, in response to a similar request. ","zap_otherinfo":"In the absence of an explicitly specified caching lifetime directive in the response, a liberal lifetime heuristic of 1 year was assumed. This is permitted by rfc7234.","zap_reference":"https://tools.ietf.org/html/rfc7234https://tools.ietf.org/html/rfc7231http://www.w3.org/Protocols/rfc2616/rfc2616-sec13.html (obsoleted by rfc7234)","zap_cweid":"524","zap_wascid":"13","zap_riskcode":"0","zap_pluginid":"10049","zap_finding_urls":[{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=polling&t=NB_4Ktj&sid=zQ0Mw6vwMbX9lKFCAAJM","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=polling&t=NB_4AGr","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=polling&t=NB_4GeT&sid=Zf_m8hPQmZ3Qj-zKAAJJ","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=polling&t=NB_4MHS","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=polling&t=NB_4KLh&sid=p8N4l1VcorqI-28DAAJL","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/rest/admin/application-configuration","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=polling&t=NB_4LmB","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/rest/languages","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/api/Challenges/?name=Score%20Board","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=polling&t=NB_4KEV","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=polling&t=NB_4Kme","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=polling&t=NB_4LNQ&sid=k8MuVo8TgUS6THldAAJN","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=polling&t=NB_4MNm&sid=Jqb5tSRY7TVpvWxfAAJP","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=polling&t=NB_4GWW","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/rest/user/whoami","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=polling&t=NB_468h&sid=gcMvRjo3zdXdJmvCAAJE","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/rest/products/search?q=","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=polling&t=NB_4617","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/rest/captcha/","method":"GET"},{"uri":"http://juice-shop.demo-apps.svc:3000/robots.txt","method":"GET"}]},"id":"cf1baf78-e38e-4e77-8c78-94a03aa4411b"},{"name":"Non-Storable Content","description":"The response contents are not storable by caching components such as proxy servers. If the response does not contain sensitive, personal or user-specific information, it may benefit from being stored and cached, to improve performance.","category":"Non-Storable Content","location":"http://juice-shop.demo-apps.svc:3000","osi_layer":"APPLICATION","severity":"INFORMATIONAL","attributes":{"host":"juice-shop.demo-apps.svc","zap_confidence":"2","zap_count":"27","zap_solution":"The content may be marked as storable by ensuring that the following conditions are satisfied:The request method must be understood by the cache and defined as being cacheable (\"GET\", \"HEAD\", and \"POST\" are currently defined as cacheable)The response status code must be understood by the cache (one of the 1XX, 2XX, 3XX, 4XX, or 5XX response classes are generally understood)The \"no-store\" cache directive must not appear in the request or response header fieldsFor caching by \"shared\" caches such as \"proxy\" caches, the \"private\" response directive must not appear in the responseFor caching by \"shared\" caches such as \"proxy\" caches, the \"Authorization\" header field must not appear in the request, unless the response explicitly allows it (using one of the \"must-revalidate\", \"public\", or \"s-maxage\" Cache-Control response directives)In addition to the conditions above, at least one of the following conditions must also be satisfied by the response:It must contain an \"Expires\" header fieldIt must contain a \"max-age\" response directiveFor \"shared\" caches such as \"proxy\" caches, it must contain a \"s-maxage\" response directiveIt must contain a \"Cache Control Extension\" that allows it to be cachedIt must have a status code that is defined as cacheable by default (200, 203, 204, 206, 300, 301, 404, 405, 410, 414, 501). ","zap_otherinfo":null,"zap_reference":"https://tools.ietf.org/html/rfc7234https://tools.ietf.org/html/rfc7231http://www.w3.org/Protocols/rfc2616/rfc2616-sec13.html (obsoleted by rfc7234)","zap_cweid":"524","zap_wascid":"13","zap_riskcode":"0","zap_pluginid":"10049","zap_finding_urls":[{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=websocket&sid=7d6AHoAKV74kodunAAJO","method":"GET","evidence":"101"},{"uri":"http://juice-shop.demo-apps.svc:3000/ftp/coupons_2013.md.bak","method":"GET","evidence":"403"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=websocket&sid=QRaHSlvGqPn23CrxAAJI","method":"GET","evidence":"101"},{"uri":"http://juice-shop.demo-apps.svc:3000/ftp/encrypt.pyc","method":"GET","evidence":"403"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=websocket&sid=p8N4l1VcorqI-28DAAJL","method":"GET","evidence":"101"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=websocket&sid=EQLt4SVpH3WQQOI3AAJK","method":"GET","evidence":"101"},{"uri":"http://juice-shop.demo-apps.svc:3000/ftp/quarantine/juicy_malware_windows_64.exe.url","method":"GET","evidence":"403"},{"uri":"http://juice-shop.demo-apps.svc:3000/ftp/package.json.bak","method":"GET","evidence":"403"},{"uri":"http://juice-shop.demo-apps.svc:3000/api/Quantitys/","method":"GET","evidence":"304"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=websocket&sid=ylY-c4ef8ITTNed2AAJH","method":"GET","evidence":"101"},{"uri":"http://juice-shop.demo-apps.svc:3000/api/Challenges/?name=Score%20Board","method":"GET","evidence":"304"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=websocket&sid=k8MuVo8TgUS6THldAAJN","method":"GET","evidence":"101"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=websocket&sid=vAZyt0pkAtDNJ6WaAAJG","method":"GET","evidence":"101"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=websocket&sid=Zf_m8hPQmZ3Qj-zKAAJJ","method":"GET","evidence":"101"},{"uri":"http://juice-shop.demo-apps.svc:3000/ftp/suspicious_errors.yml","method":"GET","evidence":"403"},{"uri":"http://juice-shop.demo-apps.svc:3000/rest/admin/application-version","method":"GET","evidence":"304"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=websocket&sid=Jqb5tSRY7TVpvWxfAAJP","method":"GET","evidence":"101"},{"uri":"http://juice-shop.demo-apps.svc:3000/rest/products/search?q=","method":"GET","evidence":"304"},{"uri":"http://juice-shop.demo-apps.svc:3000/socket.io/?EIO=3&transport=websocket&sid=gcMvRjo3zdXdJmvCAAJE","method":"GET","evidence":"101"},{"uri":"http://juice-shop.demo-apps.svc:3000/ftp/quarantine/juicy_malware_linux_64.url","method":"GET","evidence":"403"}]},"id":"e0b0c31c-9bdb-4116-99ef-58d49f9bdfd2"},{"name":"Dangerous JS Functions","description":"A dangerous JS function seems to be in use that would leave the site vulnerable.","category":"Dangerous JS Functions","location":"http://juice-shop.demo-apps.svc:3000","osi_layer":"APPLICATION","severity":"LOW","attributes":{"host":"juice-shop.demo-apps.svc","zap_confidence":"1","zap_count":"6","zap_solution":"See the references for security advice on the use of these functions.","zap_otherinfo":null,"zap_reference":"https://angular.io/guide/security","zap_cweid":"749","zap_wascid":null,"zap_riskcode":"1","zap_pluginid":"10110","zap_finding_urls":[{"uri":"http://juice-shop.demo-apps.svc:3000/polyfills-es2015.js","method":"GET","evidence":"eVal"},{"uri":"http://juice-shop.demo-apps.svc:3000/main-es2015.js","method":"GET","evidence":"bypassSecurityTrustHtml"},{"uri":"http://juice-shop.demo-apps.svc:3000/main-es5.js","method":"GET","evidence":"bypassSecurityTrustHtml"},{"uri":"http://juice-shop.demo-apps.svc:3000/vendor-es5.js","method":"GET","evidence":"bypassSecurityTrustHtml"},{"uri":"http://juice-shop.demo-apps.svc:3000/polyfills-es5.js","method":"GET","evidence":"eVal"},{"uri":"http://juice-shop.demo-apps.svc:3000/vendor-es2015.js","method":"GET","evidence":"bypassSecurityTrustHtml"}]},"id":"d517f73d-de2b-458e-9c38-8c31b403d9ce"},{"name":"Trace.axd Information Leak","description":"The ASP.NET Trace Viewer (trace.axd) was found to be available. This component can leak a significant amount of valuable information.","category":"Trace.axd Information Leak","location":"http://juice-shop.demo-apps.svc:3000","osi_layer":"APPLICATION","severity":"MEDIUM","attributes":{"host":"juice-shop.demo-apps.svc","zap_confidence":"3","zap_count":"6","zap_solution":"Consider whether or not Trace Viewer is actually required in production, if it isn't then disable it. If it is then ensure access to it requires authentication and authorization.","zap_otherinfo":null,"zap_reference":"https://msdn.microsoft.com/en-us/library/bb386420.aspxhttps://msdn.microsoft.com/en-us/library/wwh16c6c.aspxhttps://www.dotnetperls.com/trace","zap_cweid":"215","zap_wascid":"13","zap_riskcode":"2","zap_pluginid":"40029","zap_finding_urls":[{"uri":"http://juice-shop.demo-apps.svc:3000/assets/trace.axd","method":"GET","evidence":"HTTP/1.1 200 OK"},{"uri":"http://juice-shop.demo-apps.svc:3000/assets/public/trace.axd","method":"GET","evidence":"HTTP/1.1 200 OK"},{"uri":"http://juice-shop.demo-apps.svc:3000/assets/public/images/trace.axd","method":"GET","evidence":"HTTP/1.1 200 OK"},{"uri":"http://juice-shop.demo-apps.svc:3000/trace.axd","method":"GET","evidence":"HTTP/1.1 200 OK"},{"uri":"http://juice-shop.demo-apps.svc:3000/assets/public/images/products/trace.axd","method":"GET","evidence":"HTTP/1.1 200 OK"},{"uri":"http://juice-shop.demo-apps.svc:3000/assets/i18n/trace.axd","method":"GET","evidence":"HTTP/1.1 200 OK"}]},"id":"e626ba24-7230-4bb1-8a31-381c3e273b6a"},{"name":"Anti CSRF Tokens Scanner","description":"A cross-site request forgery is an attack that involves forcing a victim to send an HTTP request to a target destination without their knowledge or intent in order to perform an action as the victim. The underlying cause is application functionality using predictable URL/form actions in a repeatable way. The nature of the attack is that CSRF exploits the trust that a web site has for a user. By contrast, cross-site scripting (XSS) exploits the trust that a user has for a web site. Like XSS, CSRF attacks are not necessarily cross-site, but they can be. Cross-site request forgery is also known as CSRF, XSRF, one-click attack, session riding, confused deputy, and sea surf.CSRF attacks are effective in a number of situations, including: * The victim has an active session on the target site. * The victim is authenticated via HTTP auth on the target site. * The victim is on the same local network as the target site.CSRF has primarily been used to perform an action against a target site using the victim's privileges, but recent techniques have been discovered to disclose information by gaining access to the response. The risk of information disclosure is dramatically increased when the target site is vulnerable to XSS, because XSS can be used as a platform for CSRF, allowing the attack to operate within the bounds of the same-origin policy.","category":"Anti CSRF Tokens Scanner","location":"http://juice-shop.demo-apps.svc:3000","osi_layer":"APPLICATION","severity":"HIGH","attributes":{"host":"juice-shop.demo-apps.svc","zap_confidence":"2","zap_count":"2","zap_solution":"Phase: Architecture and DesignUse a vetted library or framework that does not allow this weakness to occur or provides constructs that make this weakness easier to avoid.For example, use anti-CSRF packages such as the OWASP CSRFGuard.Phase: ImplementationEnsure that your application is free of cross-site scripting issues, because most CSRF defenses can be bypassed using attacker-controlled script.Phase: Architecture and DesignGenerate a unique nonce for each form, place the nonce into the form, and verify the nonce upon receipt of the form. Be sure that the nonce is not predictable (CWE-330).Note that this can be bypassed using XSS.Identify especially dangerous operations. When the user performs a dangerous operation, send a separate confirmation request to ensure that the user intended to perform that operation.Note that this can be bypassed using XSS.Use the ESAPI Session Management control.This control includes a component for CSRF.Do not use the GET method for any request that triggers a state change.Phase: ImplementationCheck the HTTP Referer header to see if the request originated from an expected page. This could break legitimate functionality, because users or proxies may have disabled sending the Referer for privacy reasons.","zap_otherinfo":null,"zap_reference":"http://projects.webappsec.org/Cross-Site-Request-Forgeryhttp://cwe.mitre.org/data/definitions/352.html","zap_cweid":"352","zap_wascid":"9","zap_riskcode":"3","zap_pluginid":"20012","zap_finding_urls":[{"uri":"http://juice-shop.demo-apps.svc:3000/vendor-es5.js","method":"GET","evidence":"