Electron中文手册
  • 文档概述
  • 开发指南目录
  • 构建说明(Linux)
  • 构建说明(macOS)
  • 构建说明(Windows)
  • 构建系统概述
  • 编码规范
  • 在 macOS 中调试
  • 在 Windows 中调试
  • 在C ++代码中使用clang-format
  • 在调试器中设置符号服务器
  • 源代码目录结构
  • Chrome升级清单
  • Chromium 开发指南
  • V8 开发指南
  • 教程目录
    • 关于 Electron
    • Electron 版本说明
    • API弃用说明
    • 快速入门
    • 支持的平台
    • 桌面环境集成
    • 系统通知
    • 离屏渲染
    • 在线/离线事件检测
    • 多线程
    • REPL
    • 键盘快捷键
    • DevTools扩展
    • 使用原生模块
    • 使用 Pepper Flash 插件
    • 使用 Selenium 和 WebDriver
    • 使用 Widevine CDM 插件
    • 应用分发
    • 应用打包
    • 主进程调试
    • 使用 node-inspector 进行主进程调试
    • 使用 VSCode 进行主进程调试
    • Mac App Store应用提交指南
    • Windows App Store应用提交指南
    • 安全,本地功能和你的责任
    • Headless CI Systems 测试
  • API接口目录
    • API接口之公用接口
      • 应用语言
      • 开发概要
      • 专业术语
      • 常见问题
      • 环境变量
      • 快捷键字符串
      • 命令行
      • 客户端请求
      • 剪贴板
      • <File> H5 File文件操作
      • 无框窗口
      • <window.open> window.open打开新窗口或打开时传递消息
      • 沙盒选项
    • API接口之主进程接口
      • 整体控制
      • 全局快捷键
      • 图标创建与应用
      • 屏幕
      • 窗口
      • 菜单
      • 菜单项
      • 系统托盘
      • 网页内容
      • 从主进程到渲染进程的异步通信
      • 对话框
      • 创建和控制视图
      • 会话
      • 会话,缓存和代理等控制
      • 页面请求
      • HTTP/HTTPS请求处理
      • 协议的注册和处理
      • 使用系统默认应用程序管理文件或URL
      • 下载项管理
      • 进程控制
      • Chromium原生网络库
      • 获取系统首选项
      • 电源状态
      • 节能管理
      • 调试工具
      • 奔溃报告
      • 性能数据收集
      • 自动更新
      • TouchBar触摸条
      • TouchBar触摸条按钮
      • TouchBar触摸条拾色器
      • TouchBar触摸条分组
      • TouchBar触摸条scrubber
      • TouchBar触摸条分段控件
      • TouchBar触摸条label标签
      • TouchBar触摸条弹出框
      • TouchBar触摸条滑块
      • TouchBar触摸条间隔符
    • API接口之渲染进程接口
      • 页面渲染
      • <webview> webview标签
      • 渲染进程与主进程通信
      • 从渲染进程到主进程的异步通信
      • 子窗口
      • 捕获桌面资源
  • 结构列表
    • 蓝牙设备对象
    • 证书对象
    • 证书主体对象
    • Cookie对象
    • 崩溃报告对象
    • 桌面捕获源对象
    • 显示器对象
    • 打印机信息对象
    • 文件过滤器对象
    • 最近使用的项目
    • 常用列表项
    • CPU使用率对象即程序占用的CPU资源
    • IO值对象
    • 内存信息对象
    • 进程内存信息对象
    • 内存使用详细信息
    • Mime类型缓冲区
    • 矩形对象
    • 删除客户端证书对象
    • 删除密码对象
    • Scrubber项对象
    • 分段控制对象
    • 快捷方式对象
    • 任务对象
    • 缩略图工具栏按钮对象
    • 上传blob对象
    • 上传数据对象
    • 上传文件系统对象
    • 上传文件对象
    • 上传原始数据对象
Powered by GitBook
On this page
  • 方法
  • crashReporter.start(options)
  • crashReporter.getLastCrashReport()
  • crashReporter.getUploadedReports()
  • crashReporter.getUploadToServer() Linux macOS
  • crashReporter.setUploadToServer(uploadToServer) Linux macOS
  • crashReporter.setExtraParameter(key, value) macOS
  • 崩溃报告负载

Was this helpful?

  1. API接口目录
  2. API接口之主进程接口

奔溃报告

Previous调试工具Next性能数据收集

Last updated 4 years ago

Was this helpful?

将崩溃报告提交到远程服务器。

进程: ,

以下是自动向远程服务器提交崩溃报告的示例:

const {crashReporter} = require('electron')

crashReporter.start({
  productName: 'YourName',
  companyName: 'YourCompany',
  submitURL: 'https://your-domain.com/url-to-submit',
  uploadToServer: true
})

要设置服务器以接受和处理崩溃报告,您可以使用以下项目:

崩溃报告保存在相对于应用程序的临时目录文件夹中。

对于 YourName的 productName,崩溃报告将存储在临时目录里的 YourName Crashes的文件夹中.

你也可以在启动崩溃报告器之前通过 app.setPath('temp', '/my/custom/temp')定义相应目录.

方法

crashReporter.start(options)

用途:开始收集奔溃报告

  • options Object

    • companyName String (可选)

    • submitURL String - 以POST接收数据的URL

    • productName String (可选) - 默认为 app.getName().

    • uploadToServer Boolean (可选) - 是否上传奔溃报告至系统服务,默认为 true.

    • ignoreSystemCrashHandler Boolean (可选) - 默认为 false.

    • extra Object (可选) - 一个你可以定义的对象,附带在崩溃报告上一起发送 . 只有字符串属性可以被正确发送,不支持嵌套对象.

此方法在使用任何其他 crashReporter API之前调用.

您可从中收集崩溃报告的每个进程(主/渲染器)。

当从不同进程调用时,可以向 crashReporter.start传递不同的选项。

注意由于通过child_process模块创建的子进程无法访问Electron模块。因此,请使用process.crashReporter.start来收集它们的崩溃报告。传递的选项与上面一致,多了一个 crashesDirectory(时存储崩溃报告的目录)。你也可以通过调用process.crash()来测试这个过程。

注意:要在Windows中收集子进程的崩溃报告,您还需要添加此额外的代码。这将启动监控和发送崩溃报告的过程。请用适当的值替换 submitURL, productName和 crashesDirectory。

注意:如果你需要在第一次调用 start后发送额外的/更新的 extra参数,你可以:

在macOS上调用 setExtraParameter.

在Linux或WIN上用新的/更新的 extra参数再次调用 start.

 const args = [
   `--reporter-url=${submitURL}`,
   `--application-name=${productName}`,
   `--crashes-directory=${crashesDirectory}`
 ]
 const env = {
   ELECTRON_INTERNAL_CRASH_SERVICE: 1
 }
 spawn(process.execPath, args, {
   env: env,
   detached: true
 })

注意:在macOS上,Electron是使用新的 crashpad客户端进行崩溃收集和报告,可以从主,渲染器进程和通过 child_process模块创建的任何子进程中收集崩溃。

如果要启用崩溃报告,则需要使用 crashReporter.start从主进程初始化 crashpad。

一旦这样初始化,crashpad处理程序收集来自所有进程的崩溃。

你必须从渲染器进程调用 crashReporter.start,否则渲染器进程的奔溃报告将不含 companyName, productName或任何 extra信息。

crashReporter.getLastCrashReport()

如果没有发送崩溃报告或崩溃报告器尚未启动,则返回 nul。

crashReporter.getUploadedReports()

用途:返回所有上传的崩溃报告。每个报告包含日期和上传的ID

crashReporter.getUploadToServer() Linux macOS

用途:判断是否已将报告提交到服务器

返回 Boolean - 通过 start方法或 setUploadToServer设置

注意: 该API仅限主进程内调用

crashReporter.setUploadToServer(uploadToServer) Linux macOS

用途:判断是否已将报告提交到服务器

  • uploadToServer Boolean Linux macOS - 是否应将报告提交到服务器

通常,是否提交是由用户对系统进行偏好设置而决定的.且不能在 start之前调用该方法,否则无效.

注意: 该API仅限主进程内调用

crashReporter.setExtraParameter(key, value) macOS

用途:设置要与崩溃报告一起发送的额外参数

  • key String - 参数键。

  • value String - 参数值。指定 null或 undefined将从额外的参数中删除键。

当调用 start时,除了通过 extra选项设置的值之外,此处指定值也将被发送。

此API仅在macOS上可用, start 首次调用后,如果您希望在 在Linux和Windows上添加或更新额外参数,

您可以更新 extra选项并再次调用 start。

崩溃报告负载

崩溃报告将发送下面 multipart/form-data POST 型的数据给 submitURL :

  • ver String - Electron 版本.

  • platform String - 例如 'win32'.

  • process_type String - 例如 'renderer'.

  • guid String - 例如 '5e1286fc-da97-479e-918b-6bfb0c3d1c72'

  • _version String - package.json 版本.

  • _productName String - crashReporter options对象中的产品名字.

  • prod String - 基础产品名字. 这种情况为 Electron.

  • _companyName String - crashReporter options对象中的公司名字.

  • upload_file_minidump File - minidump 格式的崩溃报告.

  • crashReporter 中的 extra 对象的所有等级和一个属性.

    options object

用途:返回上次崩溃报告的日期和 ID

CrashReport
socorro
mini-breakpad-server
主进程
渲染进程