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
  • 实例方法
  • webRequest.onBeforeRequest([filter, ]listener)
  • webRequest.onBeforeSendHeaders([filter, ]listener)
  • webRequest.onSendHeaders([filter, ]listener)
  • webRequest.onHeadersReceived([filter, ]listener)
  • webRequest.onResponseStarted([filter, ]listener)
  • webRequest.onBeforeRedirect([filter, ]listener)
  • webRequest.onCompleted([filter, ]listener)
  • webRequest.onErrorOccurred([filter, ]listener)

Was this helpful?

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

页面请求

Previous会话,缓存和代理等控制NextHTTP/HTTPS请求处理

Last updated 4 years ago

Was this helpful?

在其生命周期的各个阶段截取和修改请求的内容

进程:

WebRequest类的实例是通过使用 Session的 webRequest属性来访问。

每个 API 接收一可选的 filter 和 listener,当 API 事件发生的时候使用 listener(details) 调用 listener, details 是一个用来描述请求的对象.将 null作为 listener传递将取消订阅事件.

filter 是一个拥有 urls 属性的对象,这是一个 url 模式数组,用来过滤掉不匹配指定 url 模式的请求.如果忽略 filter ,那么所有请求都将可以成功匹配.

所有事件的 listener 都有一个回调事件,当 listener 完成它的工作的时候,它将使用一个 response 对象来调用.

为请求添加User-Agent标头的示例:

const {session} = require('electron')
// 将所有请求的代理都修改为下列 url.
const filter = {
  urls: ['https://*.github.com/*', '*://electron.github.io']
}
session.defaultSession.webRequest.onBeforeSendHeaders(filter, (details, callback) => {
  details.requestHeaders['User-Agent'] = 'MyAgent'
  callback({cancel: false, requestHeaders: details.requestHeaders})
})

实例方法

webRequest.onBeforeRequest([filter, ]listener)

用途:即将发起请求时,调用 listener

  • filter Object

  • listener Function

    • urls String[] - URL模式数组,用于过滤与该数组不匹配的请求.

    • details Object

      • id Integer

      • url String

      • method String

      • resourceType String

      • timestamp Double

    • callback Function 使用一个 response 对象来调用 callback

      • response Object

        • cancel Boolean (可选)

        • redirectURL String (可选) - 阻止原始请求被发送或完成,把它重定向到给定的URL。

webRequest.onBeforeSendHeaders([filter, ]listener)

用途:在发送 HTTP 请求的之前,一旦请求头可用,调用 listener

  • urls String[] - URL模式数组,用于过滤与该数组不匹配的请求.

  • filter Object

  • listener Function- 可能会发生在和服务器发起tcp连接之后,发送任何 http 数据之前.

  • details Object

    • id Integer

    • url String

    • method String

    • resourceType String

    • timestamp Double

    • requestHeaders Object

  • callback Function 使用一个 response 对象来调用 callback

    • response Object

      • cancel Boolean (可选)

      • requestHeaders Object (可选) - 当提供时,将使用 headers 发出请求

webRequest.onSendHeaders([filter, ]listener)

用途:当请求被发送到服务器之前,调用 listener

  • urls String[] - URL模式数组,用于过滤与该数组不匹配的请求.

  • filter Object

  • listener Function

    • details Object

      • id Integer

      • url String

      • method String

      • resourceType String

      • timestamp Double

      • requestHeaders Object

以前的 onBeforeSendHeaders 响应的修改在这个监听器触发时是可见的。

webRequest.onHeadersReceived([filter, ]listener)

用途:当接收到请求的HTTP响应头时,调用 listener

  • urls String[] - URL模式数组,用于过滤与该数组不匹配的请求.

  • filter Object

  • listener Function

  • details Object

    • id String

    • url String

    • method String

    • resourceType String

    • timestamp Double

    • statusLine String

    • statusCode Integer

    • responseHeaders Object

  • callback Function 使用一个 response 对象来调用 callback

    • response Object

      • cancel Boolean

      • responseHeaders Object (可选) - 如果提供, 服务器将假定使用这些头来响应.

      • statusLine String (可选) - 应该在覆盖 responseHeaders更改标头状态时提供,否则将使用原始响应标头状态。

webRequest.onResponseStarted([filter, ]listener)

用途:当接收到响应主体的第一个字节时,调用 listener

  • urls String[] - URL模式数组,用于过滤与该数组不匹配的请求.

  • filter Object

  • listener Function

    • details Object

      • id Integer

      • url String

      • method String

      • resourceType String

      • timestamp Double

      • responseHeaders Object

      • fromCache Boolean - 响应是否从磁盘缓存中获取

      • statusCode Integer

      • statusLine String

对于HTTP请求来说,这意味着状态线和响应头可用了.

webRequest.onBeforeRedirect([filter, ]listener)

用途:当服务器发起重定向即将发生时,调用 listener

  • urls String[] - URL模式数组,用于过滤与该数组不匹配的请求.

  • filter Object

  • listener Function

    • details Object

      • id String

      • url String

      • method String

      • resourceType String

      • timestamp Double

      • redirectURL String

      • statusCode Integer

      • ip String (可选) - 请求的真实服务器ip

        actually sent to.

      • fromCache Boolean

      • responseHeaders Object

webRequest.onCompleted([filter, ]listener)

用途:当请求完成时,调用 listener

  • urls String[] - URL模式数组,用于过滤与该数组不匹配的请求.

  • filter Object

  • listener Function

    • details Object

      • id Integer

      • url String

      • method String

      • resourceType String

      • timestamp Double

      • responseHeaders Object

      • fromCache Boolean

      • statusCode Integer

      • statusLine String

webRequest.onErrorOccurred([filter, ]listener)

用途:当发生错误时,调用 listener

  • urls String[] - URL模式数组,用于过滤与该数组不匹配的请求.

  • filter Object

  • listener Function

    • details Object

      • id Integer

      • url String

      • method String

      • resourceType String

      • timestamp Double

      • fromCache Boolean

      • error String - 错误描述.

uploadData - UploadData对象的数组

UploadData[]
主进程