JavaScript Analysis
Static Analysis
Gather JavaScript Files
1. Filter Proxy HTTP history to only show files with the js extension:
2. Within Burp Suite's Proxy HTTP history, click the Filter bar at the top of the GUI.
Burp Suite’s proxy history
3. Mark the resulting list of JavaScript files and Copy URLs
4. Save the URLs to a text file `js.txt`
5. Use `wget -i js.txt` to download them
6. Alternatively, you can use the developer tools of your browser,
to download files one by one:Identify Endpoints
python linkfinder.py -i 'js/*' -o result.html
python linkfinder.py -i 'js/*' -o cliBookmark this js code to extract all paths from js files
javascript:(function(){var scripts=document.getElementsByTagName("script"),regex=/(?<=(\\"|\\'|\\`))\\/[a-zA-Z0-9_?&=\\/\\-\\#\\.]*(?=(\\"|\\'|\\`))/g;const%20results=new%20Set;for(var%20i=0;i<scripts.length;i++){var%20t=scripts[i].src;""!=t&&fetch(t).then(function(t){return%20t.text()}).then(function(t){var%20e=t.matchAll(regex);for(let%20r%20of%20e)results.add(r[0])}).catch(function(t){console.log("An%20error%20occurred:%20",t)})}var%20pageContent=document.documentElement.outerHTML,matches=pageContent.matchAll(regex);for(const%20match%20of%20matches)results.add(match[0]);function%20writeResults(){results.forEach(function(t){document.write(t+"<br>")})}setTimeout(writeResults,3e3);})();This OneLiner extracts all API endpoints from AngularJS & Angular JavaScript files
Detect Secrets
With truffelhog tool
With Burp
Detect Outdated Liberaries with
retire JShttps://chromewebstore.google.com/detail/retirejs/moibopkbhjceeedibkbkbchbjnkadmom?hl=enSearch for their exploit in https://security.snyk.io/
Manually Extract Endpoints and Paths
Dynamic Analysis
Function Monitoring
Break Points on modifications
Last updated
Was this helpful?