2010-11-15 16:51:01 +08:00
|
|
|
## Executing JavaScript
|
2010-10-28 20:18:16 +08:00
|
|
|
|
2010-11-15 16:51:01 +08:00
|
|
|
You can access this module with:
|
2010-10-28 20:18:16 +08:00
|
|
|
|
2010-11-16 10:37:27 +08:00
|
|
|
var vm = require('vm');
|
2010-10-28 20:18:16 +08:00
|
|
|
|
2010-11-16 10:37:27 +08:00
|
|
|
JavaScript code can be compiled and run immediately or compiled, saved, and run later.
|
2010-10-28 20:18:16 +08:00
|
|
|
|
|
|
|
|
2010-11-16 10:37:27 +08:00
|
|
|
### vm.runInThisContext(code, [filename])
|
2010-10-28 20:18:16 +08:00
|
|
|
|
2010-11-16 10:37:27 +08:00
|
|
|
`vm.runInThisContext()` compiles `code` as if it were loaded from `filename`,
|
2010-10-28 20:18:16 +08:00
|
|
|
runs it and returns the result. Running code does not have access to local scope. `filename` is optional.
|
|
|
|
|
2010-11-16 10:37:27 +08:00
|
|
|
Example of using `vm.runInThisContext` and `eval` to run the same code:
|
2010-10-28 20:18:16 +08:00
|
|
|
|
|
|
|
var localVar = 123,
|
|
|
|
usingscript, evaled,
|
2010-11-16 11:21:56 +08:00
|
|
|
vm = require('vm');
|
2010-10-28 20:18:16 +08:00
|
|
|
|
2010-11-16 10:37:27 +08:00
|
|
|
usingscript = vm.runInThisContext('localVar = 1;',
|
|
|
|
'myfile.vm');
|
2010-10-28 20:18:16 +08:00
|
|
|
console.log('localVar: ' + localVar + ', usingscript: ' +
|
|
|
|
usingscript);
|
|
|
|
evaled = eval('localVar = 1;');
|
|
|
|
console.log('localVar: ' + localVar + ', evaled: ' +
|
|
|
|
evaled);
|
|
|
|
|
|
|
|
// localVar: 123, usingscript: 1
|
|
|
|
// localVar: 1, evaled: 1
|
|
|
|
|
2010-11-16 10:37:27 +08:00
|
|
|
`vm.runInThisContext` does not have access to the local scope, so `localVar` is unchanged.
|
2010-10-28 20:18:16 +08:00
|
|
|
`eval` does have access to the local scope, so `localVar` is changed.
|
|
|
|
|
2010-11-16 10:37:27 +08:00
|
|
|
In case of syntax error in `code`, `vm.runInThisContext` emits the syntax error to stderr
|
2010-10-28 20:18:16 +08:00
|
|
|
and throws.an exception.
|
|
|
|
|
|
|
|
|
2010-11-16 10:37:27 +08:00
|
|
|
### vm.runInNewContext(code, [sandbox], [filename])
|
2010-10-28 20:18:16 +08:00
|
|
|
|
2010-11-16 10:37:27 +08:00
|
|
|
`vm.runInNewContext` compiles `code` to run in `sandbox` as if it were loaded from `filename`,
|
2010-10-28 20:18:16 +08:00
|
|
|
then runs it and returns the result. Running code does not have access to local scope and
|
|
|
|
the object `sandbox` will be used as the global object for `code`.
|
|
|
|
`sandbox` and `filename` are optional.
|
|
|
|
|
|
|
|
Example: compile and execute code that increments a global variable and sets a new one.
|
|
|
|
These globals are contained in the sandbox.
|
|
|
|
|
|
|
|
var util = require('util'),
|
2010-11-16 11:21:56 +08:00
|
|
|
vm = require('vm'),
|
2010-10-28 20:18:16 +08:00
|
|
|
sandbox = {
|
|
|
|
animal: 'cat',
|
|
|
|
count: 2
|
|
|
|
};
|
|
|
|
|
2010-11-16 10:37:27 +08:00
|
|
|
vm.runInNewContext('count += 1; name = "kitty"', sandbox, 'myfile.vm');
|
2010-10-28 20:18:16 +08:00
|
|
|
console.log(util.inspect(sandbox));
|
|
|
|
|
|
|
|
// { animal: 'cat', count: 3, name: 'kitty' }
|
|
|
|
|
|
|
|
Note that running untrusted code is a tricky business requiring great care. To prevent accidental
|
2010-11-16 10:37:27 +08:00
|
|
|
global variable leakage, `vm.runInNewContext` is quite useful, but safely running untrusted code
|
2010-10-28 20:18:16 +08:00
|
|
|
requires a separate process.
|
|
|
|
|
2010-11-16 10:37:27 +08:00
|
|
|
In case of syntax error in `code`, `vm.runInThisContext` emits the syntax error to stderr
|
2010-10-28 20:18:16 +08:00
|
|
|
and throws an exception.
|
|
|
|
|
|
|
|
|
2010-11-16 10:37:27 +08:00
|
|
|
### vm.createScript(code, [filename])
|
2010-10-28 20:18:16 +08:00
|
|
|
|
2010-11-15 16:51:01 +08:00
|
|
|
`createScript` compiles `code` as if it were loaded from `filename`,
|
2010-11-16 10:37:27 +08:00
|
|
|
but does not run it. Instead, it returns a `vm.Script` object representing this compiled code.
|
2010-10-28 20:18:16 +08:00
|
|
|
This script can be run later many times using methods below.
|
|
|
|
The returned script is not bound to any global object.
|
|
|
|
It is bound before each run, just for that run. `filename` is optional.
|
|
|
|
|
2010-11-15 16:51:01 +08:00
|
|
|
In case of syntax error in `code`, `createScript` prints the syntax error to stderr
|
2010-10-28 20:18:16 +08:00
|
|
|
and throws an exception.
|
|
|
|
|
|
|
|
|
|
|
|
### script.runInThisContext()
|
|
|
|
|
2010-11-16 10:37:27 +08:00
|
|
|
Similar to `vm.runInThisContext` but a method of a precompiled `Script` object.
|
2010-10-28 20:18:16 +08:00
|
|
|
`script.runInThisContext` runs the code of `script` and returns the result.
|
|
|
|
Running code does not have access to local scope, but does have access to the `global` object
|
|
|
|
(v8: in actual context).
|
|
|
|
|
|
|
|
Example of using `script.runInThisContext` to compile code once and run it multiple times:
|
|
|
|
|
2010-11-16 11:21:56 +08:00
|
|
|
var vm = require('vm');
|
2010-11-15 16:51:01 +08:00
|
|
|
|
2010-10-28 20:18:16 +08:00
|
|
|
globalVar = 0;
|
|
|
|
|
2010-11-16 10:37:27 +08:00
|
|
|
var script = vm.createScript('globalVar += 1', 'myfile.vm');
|
2010-10-28 20:18:16 +08:00
|
|
|
|
2010-11-15 16:51:01 +08:00
|
|
|
for (var i = 0; i < 1000 ; i += 1) {
|
|
|
|
script.runInThisContext();
|
2010-10-28 20:18:16 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
console.log(globalVar);
|
|
|
|
|
|
|
|
// 1000
|
|
|
|
|
|
|
|
|
|
|
|
### script.runInNewContext([sandbox])
|
|
|
|
|
2010-11-16 10:37:27 +08:00
|
|
|
Similar to `vm.runInNewContext` a method of a precompiled `Script` object.
|
2010-10-28 20:18:16 +08:00
|
|
|
`script.runInNewContext` runs the code of `script` with `sandbox` as the global object and returns the result.
|
|
|
|
Running code does not have access to local scope. `sandbox` is optional.
|
|
|
|
|
|
|
|
Example: compile code that increments a global variable and sets one, then execute this code multiple times.
|
|
|
|
These globals are contained in the sandbox.
|
|
|
|
|
|
|
|
var util = require('util'),
|
2010-11-16 11:21:56 +08:00
|
|
|
vm = require('vm'),
|
2010-10-28 20:18:16 +08:00
|
|
|
sandbox = {
|
|
|
|
animal: 'cat',
|
|
|
|
count: 2
|
|
|
|
};
|
|
|
|
|
2010-11-16 10:37:27 +08:00
|
|
|
var script = vm.createScript('count += 1; name = "kitty"', 'myfile.vm');
|
2010-10-28 20:18:16 +08:00
|
|
|
|
2010-11-15 16:51:01 +08:00
|
|
|
for (var i = 0; i < 10 ; i += 1) {
|
|
|
|
script.runInNewContext(sandbox);
|
2010-10-28 20:18:16 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
console.log(util.inspect(sandbox));
|
|
|
|
|
|
|
|
// { animal: 'cat', count: 12, name: 'kitty' }
|
|
|
|
|
|
|
|
Note that running untrusted code is a tricky business requiring great care. To prevent accidental
|
|
|
|
global variable leakage, `script.runInNewContext` is quite useful, but safely running untrusted code
|
|
|
|
requires a separate process.
|