说明
chrome.debugger
API 可作为 Chrome 远程调试协议的替代传输方式。使用 chrome.debugger
附加到一个或多个标签页,以检测网络互动、调试 JavaScript、更改 DOM 和 CSS 等。使用 Debuggee
属性 tabId
以 sendCommand
为目标标签页,并通过 onEvent
回调中的 tabId
路由事件。
权限
debugger
安全注意事项
出于安全考虑,chrome.debugger
API 不提供对所有 Chrome DevTools 协议网域的访问权限。可用的网域包括:Accessibility、Audits、CacheStorage、Console、CSS、Database、Debugger、DOM、DOMDebugger、DOMSnapshot、Emulation、Fetch、IO、Input、Inspector、Log、Network、Overlay、Page、Performance、Profiler、Runtime、Storage、Target、Tracing、WebAudio 和 WebAuthn。
清单
您必须在扩展程序的清单中声明 "debugger"
权限才能使用此 API。
{
"name": "My extension",
...
"permissions": [
"debugger",
],
...
}
示例
如需试用此 API,请从 chrome-extension-samples 代码库中安装 debugger API 示例。
类型
Debuggee
调试对象标识符。必须指定 tabId、extensionId 或 targetId
属性
-
extensionId
字符串(选填)
您要调试的扩展程序的 ID。只有在使用
--silent-debugger-extension-api
命令行开关时,才能附加到扩展程序后台页面。 -
tabId
number 可选
您要调试的标签页的 ID。
-
targetId
字符串(选填)
调试目标的不透明 ID。
DebuggerSession
调试器会话标识符。必须指定 tabId、extensionId 或 targetId 中的一个。此外,还可以提供可选的 sessionId。如果为从 onEvent
发送的实参指定了 sessionId,则表示相应事件来自根调试对象会话中的子协议会话。如果传递给 sendCommand
时指定了 sessionId,则它会以根调试会话中的子协议会话为目标。
属性
-
extensionId
字符串(选填)
您要调试的扩展程序的 ID。只有在使用
--silent-debugger-extension-api
命令行开关时,才能附加到扩展程序后台页面。 -
sessionId
字符串(选填)
Chrome DevTools Protocol 会话的不透明 ID。用于标识由 tabId、extensionId 或 targetId 标识的根会话中的子会话。
-
tabId
number 可选
您要调试的标签页的 ID。
-
targetId
字符串(选填)
调试目标的不透明 ID。
DetachReason
连接终止原因。
枚举
"target_closed"
"canceled_by_user"
TargetInfo
调试目标信息
属性
-
已挂接
布尔值
如果调试器已附加,则为 True。
-
extensionId
字符串(选填)
扩展程序 ID,如果 type = 'background_page',则定义该 ID。
-
faviconUrl
字符串(选填)
目标网站图标网址。
-
id
字符串
目标 ID。
-
tabId
number 可选
标签页 ID,如果 type == 'page',则定义该 ID。
-
title
字符串
目标网页标题。
-
目标类型。
-
网址
字符串
目标网址。
TargetInfoType
目标类型。
枚举
“page”
"background_page"
“worker”
“其他”
方法
attach()
chrome.debugger.attach(
target: Debuggee,
requiredVersion: string,
callback?: function,
): Promise<void>
将调试器附加到指定的目标。
参数
-
目标
要附加到的调试目标。
-
requiredVersion
字符串
必需的调试协议版本(“0.1”)。只能附加到主要版本匹配且次要版本大于或等于的调试对象。点击此处可查看协议版本列表。
-
callback
函数 可选
callback
参数如下所示:() => void
返回
-
Promise<void>
Chrome 96 及更高版本仅 Manifest V3 及更高版本支持 Promise,其他平台需要使用回调。
detach()
chrome.debugger.detach(
target: Debuggee,
callback?: function,
): Promise<void>
将调试器与指定目标分离。
参数
-
目标
要从中分离的调试目标。
-
callback
函数 可选
callback
参数如下所示:() => void
返回
-
Promise<void>
Chrome 96 及更高版本仅 Manifest V3 及更高版本支持 Promise,其他平台需要使用回调。
getTargets()
chrome.debugger.getTargets(
callback?: function,
): Promise<TargetInfo[]>
返回可用调试目标的列表。
参数
-
callback
函数 可选
callback
参数如下所示:(result: TargetInfo[]) => void
-
结果
与可用的调试目标对应的 TargetInfo 对象数组。
-
返回
-
Promise<TargetInfo[]>
Chrome 96 及更高版本仅 Manifest V3 及更高版本支持 Promise,其他平台需要使用回调。
sendCommand()
chrome.debugger.sendCommand(
target: DebuggerSession,
method: string,
commandParams?: object,
callback?: function,
): Promise<object | undefined>
将指定命令发送到调试目标。
参数
-
您要向其发送命令的调试目标。
-
method
字符串
方法名称。应该是 远程调试协议定义的方法之一。
-
commandParams
对象(可选)
包含请求参数的 JSON 对象。此对象必须符合给定方法的远程调试参数方案。
-
callback
函数 可选
callback
参数如下所示:(result?: object) => void
-
结果
对象(可选)
包含响应的 JSON 对象。响应的结构因方法名称而异,由远程调试协议中命令说明的“returns”属性定义。
-
返回
-
Promise<object | undefined>
Chrome 96 及更高版本仅 Manifest V3 及更高版本支持 Promise,其他平台需要使用回调。
事件
onDetach
chrome.debugger.onDetach.addListener(
callback: function,
)
当浏览器终止标签页的调试会话时触发。当标签页正在关闭或 Chrome 开发者工具正在为附加的标签页调用时,会发生这种情况。
参数
-
callback
函数
callback
参数如下所示:(source: Debuggee, reason: DetachReason) => void
-
来源
-
reason
-
onEvent
chrome.debugger.onEvent.addListener(
callback: function,
)
每当调试目标问题检测事件时触发。
参数
-
callback
函数
callback
参数如下所示:(source: DebuggerSession, method: string, params?: object) => void
-
method
字符串
-
params
对象(可选)