javascript - 如何从外部来源捕获 console.log?
问题描述
我了解如何修改 console.log 函数以拦截日志并将其推送到数组中。但是,这似乎不适用于所有控制台日志。在我的 html 中,我加载了一个 html webapp ( \creative\300x600 with video\index.html
),它也console.log("click detected")
可以在我的 chrome 开发工具中看到,但不会被控制台捕获。ogs(代码示例中的第二个脚本)。我怀疑因为这是一个正在加载的外部文件,所以我无法拦截它。
是否有解决方案可以从任何来源获取所有 console.log 并保存?
<!DOCTYPE html>
<head>
<script>
//add index.html to div on click
function load_home() {
console.log("Loaded");
document.getElementById("content").src='creative\\300x600 with video\\index.html';
}
window.addEventListener("click",load_home);
</script>
<script>
//modify console.log
console.defaultLog = console.log.bind(console);
console.logs = [];
console.log = function() {
console.defaultLog.apply(console, arguments);
console.logs.push(Array.from(arguments));
};
</script>
</head>
<html>
<iframe id="content" style="width: 300px; height:600px; background-color:blue" ></iframe>
</body>
</html>
编辑:
尝试在 div 而不是 iframe 上制作它,同样的问题是无法记录外部 html 的 console.log。仅从 console.log("loaded")
load_home 函数被记录。
<!DOCTYPE html>
<head>
<script>
function load_home() {
console.log("Loaded");
document.getElementById("content").innerHTML='<object type="text/html" data="creative\\300x600 with video\\index.html" ></object>';
}
window.addEventListener("click",load_home);
</script>
<script>
console.defaultLog = console.log.bind(console);
console.logs = [];
console.log = function() {
console.defaultLog.apply(console, arguments);
console.logs.push(Array.from(arguments));
};
</script>
</head>
<html>
<div id="content" style="width: 300px; height:600px; z-index:-1;" ,"onclick=load_home();" </div>
</body>
</html>
解决方案
这里的问题就是因为这个iframe
。iframe
s 有一个不同的window
对象,独立于父window
对象。这意味着您对父级所做的任何修改window.console
都不会影响 iframe 的window.console
.
您可以通过获取框架的window
对象contentWindow
并修改其console
. 但是你必须为每一个现在和未来 iframe
都这样做。此外,您无法访问contentWindow
从另一个域呈现页面的 iframe。
如果您尝试捕获所有帧的日志并以某种方式将它们合并到一个大日志中,那么更好的选择是console
在您要跟踪的每个页面上都使用相同的 -altering 脚本。然后将所有日志发送到服务器,按时间戳或其他方式排序。这几乎就是Sentry的工作方式。
推荐阅读
- java - Spring Boot 更新用户数据的最佳方法是什么?
- vba - 如何在 VBA 中循环查找对话框
- reactjs - 组件即使在状态突变 redux 下也能工作
- javascript - 解析 json 数组并遍历 Pivot.js 的所有数据
- php - 在 MySQL 中添加用户的多个收藏夹
- python - 为 Raspberry Pi 使用 Google 的语音到文本 API
- css - Flexbox - 响应式缩小
- android - 如何使用 SQLite 修复 CursorIndexOutOfBoundsException 并检索数据
- c# - 为什么无限循环中的foreach循环会永远持续下去?
- css - 桌面导航版背景颜色不起作用?