The Script Console add-on allows you to run scripts that can be embedded within ZAP and can access internal ZAP data structures.
It supports any scripting language that supports JSR 223 (http://www.jcp.org/en/jsr/detail?id=223) , including:
WARNING - scripts run with the same permissions as ZAP, so do not run any scripts that you do not trust!
Different types of scripts are supported:
Note: Add-ons can add additional types of scripts, which should be described in the help of the corresponding add-on.
All scripts that are run automatically are initially ‘disabled’ - you must enable them via the The Scripts ’tree’ tab before they will run.
If an error occurs when they run then they will be disabled.
When you select the script then the last error will be shown in the Script Console tab.
Targeted scripts can be invoked by right clicking on a record in the Sites or History tabs and selecting the ‘Invoke with script…’ menu item.
All scripting languages can be used for all script types, but only those languages that have been downloaded from the ZAP Marketplace will typically have templates. However you may well be able to adapt a template for another language.
If your favourite language is not available on the Marketplace then please raise a new issue via the “Online/Report an issue” menu item.
Variables can be shared between all scripts via the class org.zaproxy.zap.extension.script.ScriptVars.
For example in JavaScript you can use this class as follows:
org.zaproxy.zap.extension.script.ScriptVars.setGlobalVar("var.name","value")
org.zaproxy.zap.extension.script.ScriptVars.getGlobalVar("var.name")
Variables can be shared between separate invocations of the same script via the same org.zaproxy.zap.extension.script.ScriptVars class.
For example in JavaScript you can use this class as follows:
org.zaproxy.zap.extension.script.ScriptVars.setScriptVar(this.context, "var.name","value")
org.zaproxy.zap.extension.script.ScriptVars.getScriptVar(this.context, "var.name")
Note that these methods are only usable from scripting languages that provide access to the ScriptContext (like JavaScript). For other scripting languages (in ZAP versions after 2.7.0) the variables can be accessed/set by manually specifying the name of the script:
org.zaproxy.zap.extension.script.ScriptVars.setScriptVar("ScriptName", "var.name","value")
org.zaproxy.zap.extension.script.ScriptVars.getScriptVar("ScriptName", "var.name")
Newer versions of ZAP (after 2.8.0) allow to set custom global/script variables, which can be of any type not just strings, for example, lists, maps.
In JavaScript they are accessed/set as follows:
` var ScriptVars = Java.type(“org.zaproxy.zap.extension.script.ScriptVars”)
ScriptVars.setScriptCustomVar(this.context, “var.name”, {x: 1, y: 3}) print(ScriptVars.getScriptCustomVar(this.context, “var.name”).y) // Prints 3
ScriptVars.setGlobalCustomVar(“var.name”, [“A”, “B”, “C”, “D”]) print(ScriptVars.getGlobalCustomVar(“var.name”)[2]) // Prints C `
The Script Console tab | ||
The Scripts ’tree’ tab |
https://github.com/zaproxy/zaproxy/wiki/InternalDetails | ZAP internal objects | |
https://javadoc.io/doc/org.zaproxy/zap | ZAP javadocs | |
https://wiki.openjdk.java.net/display/Nashorn/Rhino+Migration+Guide | Rhino Migration Guide |