Answers:
我不确定firefox,但是在v8 / chrome中,您可以在Error构造函数上使用一种称为的方法captureStackTrace
。(更多信息在这里)
因此,获取该漏洞的一种方法是:
var getStackTrace = function() {
var obj = {};
Error.captureStackTrace(obj, getStackTrace);
return obj.stack;
};
console.log(getStackTrace());
通常,getStackTrace
在捕获时将在堆栈中。那里的第二个参数排除getStackTrace
在堆栈跟踪之外。
Error().stack
。虽然在Firefox中对象和函数名称丢失,而在chrome中对象名称丢失(与相同Error.captureStackTrace
),但Error().stack
它们在两种浏览器上均可工作,并且为我提供了足够的信息来进行调试。
Error.stack是您所需要的。它适用于Chrome和Firefox。例如
try { var a = {}; a.debug(); } catch(ex) {console.log(ex.stack)}
将提供Chrome:
TypeError: Object #<Object> has no method 'debug'
at eval at <anonymous> (unknown source)
at eval (native)
at Object._evaluateOn (unknown source)
at Object._evaluateAndWrap (unknown source)
at Object.evaluate (unknown source)
在Firefox中:
@http://www.google.com.ua/:87 _firebugInjectedEvaluate("with(_FirebugCommandLine){try { var a = {}; a.debug() } catch(ex) {console.log(ex.stack)}\n};")
@http://www.google.com.ua/:87 _firebugEvalEvent([object Event])
@http://www.google.com.ua/:67
(new Error).stack
这将为现代的Chrome,Firefox,Opera和IE10 +提供堆栈跟踪(作为字符串数组)
function getStackTrace () {
var stack;
try {
throw new Error('');
}
catch (error) {
stack = error.stack || '';
}
stack = stack.split('\n').map(function (line) { return line.trim(); });
return stack.splice(stack[0] == 'Error' ? 2 : 1);
}
用法:
console.log(getStackTrace().join('\n'));
它从堆栈中排除了自己的调用以及Chrome和Firefox(但不是IE)使用的标题“错误”。
它不应在旧版浏览器上崩溃,而应返回空数组。如果需要更通用的解决方案,请查看stacktrace.js。它支持的浏览器列表确实令人印象深刻,但在我看来,这对打算执行的小任务非常重要:37KB的压缩文本,包括所有依赖项。
有一个名为stacktrace.js的库,可为您提供跨浏览器堆栈跟踪。您可以通过包含脚本并在任何时候调用来简单地使用它:
var trace = printStackTrace();
这仅是Konstantin出色代码的较小改进。它减少了捕获捕捉的开销,并且仅实例化了错误堆栈:
function getStackTrace () {
let stack = new Error().stack || '';
stack = stack.split('\n').map(function (line) { return line.trim(); });
return stack.splice(stack[0] == 'Error' ? 2 : 1);
}
我通常想要特定级别的堆栈跟踪(对于我的自定义记录器),因此在调用时也可以:
getStackTrace()[2]; // get stack trace info 2 levels-deep