Skip to main content

session

管理浏览器会话、cookie、缓存、代理设置等。

¥Manage browser sessions, cookies, cache, proxy settings, etc.

进程:主进程

¥Process: Main

session 模块可用于创建新的 Session 对象。

¥The session module can be used to create new Session objects.

你还可以使用 WebContentssession 属性或从 session 模块访问现有页面的 session

¥You can also access the session of existing pages by using the session property of WebContents, or from the session module.

const { BrowserWindow } = require('electron')

const win = new BrowserWindow({ width: 800, height: 600 })
win.loadURL('https://github.com')

const ses = win.webContents.session
console.log(ses.getUserAgent())

方法

¥Methods

session 模块有以下方法:

¥The session module has the following methods:

session.fromPartition(partition[, options])

  • partition 字符串

    ¥partition string

  • options 对象(可选)

    ¥options Object (optional)

    • cache 布尔值 - 是否启用缓存。

      ¥cache boolean - Whether to enable cache.

返回 Session - 来自 partition 字符串的会话实例。当存在与 partition 相同的 Session 时,将返回;否则将使用 options 创建一个新的 Session 实例。

¥Returns Session - A session instance from partition string. When there is an existing Session with the same partition, it will be returned; otherwise a new Session instance will be created with options.

如果 partitionpersist: 开头,则页面将使用可用于应用中具有相同 partition 的所有页面的持久会话。如果没有 persist: 前缀,该页面将使用内存会话。如果 partition 为空,则将返回应用的默认会话。

¥If partition starts with persist:, the page will use a persistent session available to all pages in the app with the same partition. if there is no persist: prefix, the page will use an in-memory session. If the partition is empty then default session of the app will be returned.

要创建带有 optionsSession,你必须确保以前从未使用过带有 partitionSession。无法更改现有 Session 对象的 options

¥To create a Session with options, you have to ensure the Session with the partition has never been used before. There is no way to change the options of an existing Session object.

session.fromPath(path[, options])

  • path 字符串

    ¥path string

  • options 对象(可选)

    ¥options Object (optional)

    • cache 布尔值 - 是否启用缓存。

      ¥cache boolean - Whether to enable cache.

返回 Session - 来自 path 字符串指定的绝对路径的会话实例。当存在相同绝对路径的 Session 时,将返回;否则将使用 options 创建一个新的 Session 实例。如果路径不是绝对路径,则调用将引发错误。此外,如果提供空字符串,将会引发错误。

¥Returns Session - A session instance from the absolute path as specified by the path string. When there is an existing Session with the same absolute path, it will be returned; otherwise a new Session instance will be created with options. The call will throw an error if the path is not an absolute path. Additionally, an error will be thrown if an empty string is provided.

要创建带有 optionsSession,你必须确保以前从未使用过带有 pathSession。无法更改现有 Session 对象的 options

¥To create a Session with options, you have to ensure the Session with the path has never been used before. There is no way to change the options of an existing Session object.

属性

¥Properties

session 模块具有以下属性:

¥The session module has the following properties:

session.defaultSession

Session 对象,应用的默认会话对象。

¥A Session object, the default session object of the app.

类:会议

¥Class: Session

获取和设置会话的属性。

¥Get and set properties of a session.

进程:主进程
该类不是从 'electron' 模块导出的。它仅可用作 Electron API 中其他方法的返回值。

¥Process: Main
This class is not exported from the 'electron' module. It is only available as a return value of other methods in the Electron API.

你可以在 session 模块中创建 Session 对象:

¥You can create a Session object in the session module:

const { session } = require('electron')
const ses = session.fromPartition('persist:name')
console.log(ses.getUserAgent())

实例事件

¥Instance Events

以下事件在 Session 的实例上可用:

¥The following events are available on instances of Session:

事件:'will-download'

¥Event: 'will-download'

返回:

¥Returns:

当 Electron 即将下载 webContents 中的 item 时发出。

¥Emitted when Electron is about to download item in webContents.

调用 event.preventDefault() 将取消下载,并且 item 从该进程的下一个周期开始将不可用。

¥Calling event.preventDefault() will cancel the download and item will not be available from next tick of the process.

const { session } = require('electron')
session.defaultSession.on('will-download', (event, item, webContents) => {
event.preventDefault()
require('got')(item.getURL()).then((response) => {
require('node:fs').writeFileSync('/somewhere', response.body)
})
})

事件:'extension-loaded'

¥Event: 'extension-loaded'

返回:

¥Returns:

加载扩展后发出。每当将扩展添加到 "enabled" 扩展集时就会发生这种情况。这包括:

¥Emitted after an extension is loaded. This occurs whenever an extension is added to the "enabled" set of extensions. This includes:

  • 正在从 Session.loadExtension 加载扩展。

    ¥Extensions being loaded from Session.loadExtension.

  • 正在重新加载扩展:

    ¥Extensions being reloaded:

事件:'extension-unloaded'

¥Event: 'extension-unloaded'

返回:

¥Returns:

卸载扩展后发出。当调用 Session.removeExtension 时会发生这种情况。

¥Emitted after an extension is unloaded. This occurs when Session.removeExtension is called.

事件:'extension-ready'

¥Event: 'extension-ready'

返回:

¥Returns:

在加载扩展程序并初始化所有必要的浏览器状态以支持扩展程序后台页面的启动后发出。

¥Emitted after an extension is loaded and all necessary browser state is initialized to support the start of the extension's background page.

事件:'file-system-access-restricted'

¥Event: 'file-system-access-restricted'

返回:

¥Returns:

  • event 事件

    ¥event Event

  • details 对象

    ¥details Object

    • origin 字符串 - 发起对被阻止路径访问的来源。

      ¥origin string - The origin that initiated access to the blocked path.

    • isDirectory 布尔值 - 路径是否为目录。

      ¥isDirectory boolean - Whether or not the path is a directory.

    • path 字符串 - 试图访问的被阻止的路径。

      ¥path string - The blocked path attempting to be accessed.

  • callback 函数

    ¥callback Function

    • action 字符串 - 由于限制路径访问尝试而采取的操作。

      ¥action string - The action to take as a result of the restricted path access attempt.

      • allow - 这将允许尽管处于受限状态,但仍可以访问 path

        ¥allow - This will allow path to be accessed despite restricted status.

      • deny - 这将阻止访问请求并触发 AbortError

        ¥deny - This will block the access request and trigger an AbortError.

      • tryAgain - 这将打开一个新的文件选择器并允许用户选择另一个路径。

        ¥tryAgain - This will open a new file picker and allow the user to choose another path.

const { app, dialog, BrowserWindow, session } = require('electron')

async function createWindow () {
const mainWindow = new BrowserWindow()

await mainWindow.loadURL('https://buzzfeed.com')

session.defaultSession.on('file-system-access-restricted', async (e, details, callback) => {
const { origin, path } = details
const { response } = await dialog.showMessageBox({
message: `Are you sure you want ${origin} to open restricted path ${path}?`,
title: 'File System Access Restricted',
buttons: ['Choose a different folder', 'Allow', 'Cancel'],
cancelId: 2
})

if (response === 0) {
callback('tryAgain')
} else if (response === 1) {
callback('allow')
} else {
callback('deny')
}
})

mainWindow.webContents.executeJavaScript(`
window.showDirectoryPicker({
id: 'electron-demo',
mode: 'readwrite',
startIn: 'downloads',
}).catch(e => {
console.log(e)
})`, true
)
}

app.whenReady().then(() => {
createWindow()

app.on('activate', () => {
if (BrowserWindow.getAllWindows().length === 0) createWindow()
})
})

app.on('window-all-closed', function () {
if (process.platform !== 'darwin') app.quit()
})

事件:'preconnect'

¥Event: 'preconnect'

返回:

¥Returns:

  • event 事件

    ¥event Event

  • preconnectUrl 字符串 - 渲染器请求预连接的 URL。

    ¥preconnectUrl string - The URL being requested for preconnection by the renderer.

  • allowCredentials 布尔值 - 如果渲染器请求连接包含凭据,则为 true(有关更多详细信息,请参阅 spec。)

    ¥allowCredentials boolean - True if the renderer is requesting that the connection include credentials (see the spec for more details.)

当渲染进程请求预连接到 URL 时发出,通常是由于 资源提示

¥Emitted when a render process requests preconnection to a URL, generally due to a resource hint.

事件:'spellcheck-dictionary-initialized'

¥Event: 'spellcheck-dictionary-initialized'

返回:

¥Returns:

  • event 事件

    ¥event Event

  • languageCode 字符串 - 词典文件的语言代码

    ¥languageCode string - The language code of the dictionary file

当 hunspell 字典文件成功初始化时发出。下载文件后会发生这种情况。

¥Emitted when a hunspell dictionary file has been successfully initialized. This occurs after the file has been downloaded.

事件:'spellcheck-dictionary-download-begin'

¥Event: 'spellcheck-dictionary-download-begin'

返回:

¥Returns:

  • event 事件

    ¥event Event

  • languageCode 字符串 - 词典文件的语言代码

    ¥languageCode string - The language code of the dictionary file

当 hunspell 字典文件开始下载时发出

¥Emitted when a hunspell dictionary file starts downloading

事件:'spellcheck-dictionary-download-success'

¥Event: 'spellcheck-dictionary-download-success'

返回:

¥Returns:

  • event 事件

    ¥event Event

  • languageCode 字符串 - 词典文件的语言代码

    ¥languageCode string - The language code of the dictionary file

成功下载 hunspell 字典文件时发出

¥Emitted when a hunspell dictionary file has been successfully downloaded

事件:'spellcheck-dictionary-download-failure'

¥Event: 'spellcheck-dictionary-download-failure'

返回:

¥Returns:

  • event 事件

    ¥event Event

  • languageCode 字符串 - 词典文件的语言代码

    ¥languageCode string - The language code of the dictionary file

当 hunspell 字典文件下载失败时发出。有关失败的详细信息,你应该收集网络日志并检查下载请求。

¥Emitted when a hunspell dictionary file download fails. For details on the failure you should collect a netlog and inspect the download request.

事件:'select-hid-device'

¥Event: 'select-hid-device'

返回:

¥Returns:

  • event 事件

    ¥event Event

  • details 对象

    ¥details Object

  • callback 函数

    ¥callback Function

    • deviceId 字符串 | 空(可选)

      ¥deviceId string | null (optional)

当调用 navigator.hid.requestDevice 时需要选择 HID 设备时发出。应调用 callback 并选择 deviceId;不向 callback 传递任何参数将取消请求。此外,可以使用 ses.setPermissionCheckHandler(handler)ses.setDevicePermissionHandler(handler) 进一步管理 navigator.hid 上的权限。

¥Emitted when a HID device needs to be selected when a call to navigator.hid.requestDevice is made. callback should be called with deviceId to be selected; passing no arguments to callback will cancel the request. Additionally, permissioning on navigator.hid can be further managed by using ses.setPermissionCheckHandler(handler) and ses.setDevicePermissionHandler(handler).

const { app, BrowserWindow } = require('electron')

let win = null

app.whenReady().then(() => {
win = new BrowserWindow()

win.webContents.session.setPermissionCheckHandler((webContents, permission, requestingOrigin, details) => {
if (permission === 'hid') {
// Add logic here to determine if permission should be given to allow HID selection
return true
}
return false
})

// Optionally, retrieve previously persisted devices from a persistent store
const grantedDevices = fetchGrantedDevices()

win.webContents.session.setDevicePermissionHandler((details) => {
if (new URL(details.origin).hostname === 'some-host' && details.deviceType === 'hid') {
if (details.device.vendorId === 123 && details.device.productId === 345) {
// Always allow this type of device (this allows skipping the call to `navigator.hid.requestDevice` first)
return true
}

// Search through the list of devices that have previously been granted permission
return grantedDevices.some((grantedDevice) => {
return grantedDevice.vendorId === details.device.vendorId &&
grantedDevice.productId === details.device.productId &&
grantedDevice.serialNumber && grantedDevice.serialNumber === details.device.serialNumber
})
}
return false
})

win.webContents.session.on('select-hid-device', (event, details, callback) => {
event.preventDefault()
const selectedDevice = details.deviceList.find((device) => {
return device.vendorId === 9025 && device.productId === 67
})
callback(selectedDevice?.deviceId)
})
})

事件:'hid-device-added'

¥Event: 'hid-device-added'

返回:

¥Returns:

如果在调用 select-hid-device 的回调之前有新设备可用,则在调用 navigator.hid.requestDevice 后发出,并且 select-hid-device 已触发。此事件旨在在使用 UI 要求用户选择设备时使用,以便可以使用新添加的设备更新 UI。

¥Emitted after navigator.hid.requestDevice has been called and select-hid-device has fired if a new device becomes available before the callback from select-hid-device is called. This event is intended for use when using a UI to ask users to pick a device so that the UI can be updated with the newly added device.

事件:'hid-device-removed'

¥Event: 'hid-device-removed'

返回:

¥Returns:

如果在调用 select-hid-device 的回调之前已删除设备,则在调用 navigator.hid.requestDeviceselect-hid-device 已触发后发出。此事件适用于使用 UI 要求用户选择设备,以便更新 UI 以删除指定设备时使用。

¥Emitted after navigator.hid.requestDevice has been called and select-hid-device has fired if a device has been removed before the callback from select-hid-device is called. This event is intended for use when using a UI to ask users to pick a device so that the UI can be updated to remove the specified device.

事件:'hid-device-revoked'

¥Event: 'hid-device-revoked'

返回:

¥Returns:

  • event 事件

    ¥event Event

  • details 对象

    ¥details Object

    • device HID 设备

      ¥device HIDDevice

    • origin 字符串(可选) - 设备已被撤销的来源。

      ¥origin string (optional) - The origin that the device has been revoked from.

调用 HIDDevice.forget() 后发出。当使用 setDevicePermissionHandler 时,此事件可用于帮助维护权限的持久存储。

¥Emitted after HIDDevice.forget() has been called. This event can be used to help maintain persistent storage of permissions when setDevicePermissionHandler is used.

事件:'select-serial-port'

¥Event: 'select-serial-port'

返回:

¥Returns:

  • event 事件

    ¥event Event

  • portList SerialPort[]

  • webContents WebContents

  • callback 函数

    ¥callback Function

    • portId 字符串

      ¥portId string

当调用 navigator.serial.requestPort 时需要选择串行端口时发出。应该在选择 portId 的情况下调用 callback,将空字符串传递给 callback 将取消请求。此外,可以通过使用 ses.setPermissionCheckHandler(handler)serial 权限来管理 navigator.serial 上的权限。

¥Emitted when a serial port needs to be selected when a call to navigator.serial.requestPort is made. callback should be called with portId to be selected, passing an empty string to callback will cancel the request. Additionally, permissioning on navigator.serial can be managed by using ses.setPermissionCheckHandler(handler) with the serial permission.

const { app, BrowserWindow } = require('electron')

let win = null

app.whenReady().then(() => {
win = new BrowserWindow({
width: 800,
height: 600
})

win.webContents.session.setPermissionCheckHandler((webContents, permission, requestingOrigin, details) => {
if (permission === 'serial') {
// Add logic here to determine if permission should be given to allow serial selection
return true
}
return false
})

// Optionally, retrieve previously persisted devices from a persistent store
const grantedDevices = fetchGrantedDevices()

win.webContents.session.setDevicePermissionHandler((details) => {
if (new URL(details.origin).hostname === 'some-host' && details.deviceType === 'serial') {
if (details.device.vendorId === 123 && details.device.productId === 345) {
// Always allow this type of device (this allows skipping the call to `navigator.serial.requestPort` first)
return true
}

// Search through the list of devices that have previously been granted permission
return grantedDevices.some((grantedDevice) => {
return grantedDevice.vendorId === details.device.vendorId &&
grantedDevice.productId === details.device.productId &&
grantedDevice.serialNumber && grantedDevice.serialNumber === details.device.serialNumber
})
}
return false
})

win.webContents.session.on('select-serial-port', (event, portList, webContents, callback) => {
event.preventDefault()
const selectedPort = portList.find((device) => {
return device.vendorId === '9025' && device.productId === '67'
})
if (!selectedPort) {
callback('')
} else {
callback(selectedPort.portId)
}
})
})

事件:'serial-port-added'

¥Event: 'serial-port-added'

返回:

¥Returns:

如果在调用 select-serial-port 的回调之前有新的串行端口可用,则在调用 navigator.serial.requestPortselect-serial-port 已触发后发出。此事件旨在在使用 UI 要求用户选择端口时使用,以便可以使用新添加的端口更新 UI。

¥Emitted after navigator.serial.requestPort has been called and select-serial-port has fired if a new serial port becomes available before the callback from select-serial-port is called. This event is intended for use when using a UI to ask users to pick a port so that the UI can be updated with the newly added port.

事件:'serial-port-removed'

¥Event: 'serial-port-removed'

返回:

¥Returns:

如果在调用 select-serial-port 的回调之前已删除串行端口,则在调用 navigator.serial.requestPortselect-serial-port 已触发后发出。此事件旨在在使用 UI 要求用户选择端口时使用,以便可以更新 UI 以删除指定的端口。

¥Emitted after navigator.serial.requestPort has been called and select-serial-port has fired if a serial port has been removed before the callback from select-serial-port is called. This event is intended for use when using a UI to ask users to pick a port so that the UI can be updated to remove the specified port.

事件:'serial-port-revoked'

¥Event: 'serial-port-revoked'

返回:

¥Returns:

  • event 事件

    ¥event Event

  • details 对象

    ¥details Object

    • port SerialPort

    • frame Web 框架主

      ¥frame WebFrameMain

    • origin 字符串 - 设备已被撤销的来源。

      ¥origin string - The origin that the device has been revoked from.

调用 SerialPort.forget() 后发出。当使用 setDevicePermissionHandler 时,此事件可用于帮助维护权限的持久存储。

¥Emitted after SerialPort.forget() has been called. This event can be used to help maintain persistent storage of permissions when setDevicePermissionHandler is used.

// Browser Process
const { app, BrowserWindow } = require('electron')

app.whenReady().then(() => {
const win = new BrowserWindow({
width: 800,
height: 600
})

win.webContents.session.on('serial-port-revoked', (event, details) => {
console.log(`Access revoked for serial device from origin ${details.origin}`)
})
})
// Renderer Process

const portConnect = async () => {
// Request a port.
const port = await navigator.serial.requestPort()

// Wait for the serial port to open.
await port.open({ baudRate: 9600 })

// ...later, revoke access to the serial port.
await port.forget()
}

事件:'select-usb-device'

¥Event: 'select-usb-device'

返回:

¥Returns:

  • event 事件

    ¥event Event

  • details 对象

    ¥details Object

  • callback 函数

    ¥callback Function

    • deviceId 字符串(可选)

      ¥deviceId string (optional)

当调用 navigator.usb.requestDevice 时需要选择 USB 设备时发出。应调用 callback 并选择 deviceId;不向 callback 传递任何参数将取消请求。此外,可以使用 ses.setPermissionCheckHandler(handler)ses.setDevicePermissionHandler(handler) 进一步管理 navigator.usb 上的权限。

¥Emitted when a USB device needs to be selected when a call to navigator.usb.requestDevice is made. callback should be called with deviceId to be selected; passing no arguments to callback will cancel the request. Additionally, permissioning on navigator.usb can be further managed by using ses.setPermissionCheckHandler(handler) and ses.setDevicePermissionHandler(handler).

const { app, BrowserWindow } = require('electron')

let win = null

app.whenReady().then(() => {
win = new BrowserWindow()

win.webContents.session.setPermissionCheckHandler((webContents, permission, requestingOrigin, details) => {
if (permission === 'usb') {
// Add logic here to determine if permission should be given to allow USB selection
return true
}
return false
})

// Optionally, retrieve previously persisted devices from a persistent store (fetchGrantedDevices needs to be implemented by developer to fetch persisted permissions)
const grantedDevices = fetchGrantedDevices()

win.webContents.session.setDevicePermissionHandler((details) => {
if (new URL(details.origin).hostname === 'some-host' && details.deviceType === 'usb') {
if (details.device.vendorId === 123 && details.device.productId === 345) {
// Always allow this type of device (this allows skipping the call to `navigator.usb.requestDevice` first)
return true
}

// Search through the list of devices that have previously been granted permission
return grantedDevices.some((grantedDevice) => {
return grantedDevice.vendorId === details.device.vendorId &&
grantedDevice.productId === details.device.productId &&
grantedDevice.serialNumber && grantedDevice.serialNumber === details.device.serialNumber
})
}
return false
})

win.webContents.session.on('select-usb-device', (event, details, callback) => {
event.preventDefault()
const selectedDevice = details.deviceList.find((device) => {
return device.vendorId === 9025 && device.productId === 67
})
if (selectedDevice) {
// Optionally, add this to the persisted devices (updateGrantedDevices needs to be implemented by developer to persist permissions)
grantedDevices.push(selectedDevice)
updateGrantedDevices(grantedDevices)
}
callback(selectedDevice?.deviceId)
})
})

事件:'usb-device-added'

¥Event: 'usb-device-added'

返回:

¥Returns:

如果在调用 select-usb-device 的回调之前有新设备可用,则在调用 navigator.usb.requestDevice 后发出,并且 select-usb-device 已触发。此事件旨在在使用 UI 要求用户选择设备时使用,以便可以使用新添加的设备更新 UI。

¥Emitted after navigator.usb.requestDevice has been called and select-usb-device has fired if a new device becomes available before the callback from select-usb-device is called. This event is intended for use when using a UI to ask users to pick a device so that the UI can be updated with the newly added device.

事件:'usb-device-removed'

¥Event: 'usb-device-removed'

返回:

¥Returns:

如果在调用 select-usb-device 的回调之前已删除设备,则在调用 navigator.usb.requestDeviceselect-usb-device 已触发后发出。此事件适用于使用 UI 要求用户选择设备,以便更新 UI 以删除指定设备时使用。

¥Emitted after navigator.usb.requestDevice has been called and select-usb-device has fired if a device has been removed before the callback from select-usb-device is called. This event is intended for use when using a UI to ask users to pick a device so that the UI can be updated to remove the specified device.

事件:'usb-device-revoked'

¥Event: 'usb-device-revoked'

返回:

¥Returns:

  • event 事件

    ¥event Event

  • details 对象

    ¥details Object

    • device USB 设备

      ¥device USBDevice

    • origin 字符串(可选) - 设备已被撤销的来源。

      ¥origin string (optional) - The origin that the device has been revoked from.

调用 USBDevice.forget() 后发出。当使用 setDevicePermissionHandler 时,此事件可用于帮助维护权限的持久存储。

¥Emitted after USBDevice.forget() has been called. This event can be used to help maintain persistent storage of permissions when setDevicePermissionHandler is used.

实例方法

¥Instance Methods

以下方法可用于 Session 的实例:

¥The following methods are available on instances of Session:

ses.getCacheSize()

返回 Promise<Integer> - 会话的当前缓存大小(以字节为单位)。

¥Returns Promise<Integer> - the session's current cache size, in bytes.

ses.clearCache()

返回 Promise<void> - 当缓存清除操作完成时解决。

¥Returns Promise<void> - resolves when the cache clear operation is complete.

清除会话的 HTTP 缓存。

¥Clears the session’s HTTP cache.

ses.clearStorageData([options])

  • options 对象(可选)

    ¥options Object (optional)

    • origin 字符串(可选) - 应遵循 window.location.origin 的表示 scheme://host:port

      ¥origin string (optional) - Should follow window.location.origin’s representation scheme://host:port.

    • storages 字符串[](可选) - 要清除的存储类型,可以是 cookiesfilesystemindexdblocalstorageshadercachewebsqlserviceworkerscachestorage。如果未指定,则清除所有存储类型。

      ¥storages string[] (optional) - The types of storages to clear, can be cookies, filesystem, indexdb, localstorage, shadercache, websql, serviceworkers, cachestorage. If not specified, clear all storage types.

    • quotas 字符串[](可选) - 要清除的配额类型,可以是 temporarysyncable。如果未指定,则清除所有配额。

      ¥quotas string[] (optional) - The types of quotas to clear, can be temporary, syncable. If not specified, clear all quotas.

返回 Promise<void> - 当存储数据被清除时解决。

¥Returns Promise<void> - resolves when the storage data has been cleared.

ses.flushStorageData()

将任何未写入的 DOMStorage 数据写入磁盘。

¥Writes any unwritten DOMStorage data to disk.

ses.setProxy(config)

返回 Promise<void> - 代理设置过程完成后即可解决。

¥Returns Promise<void> - Resolves when the proxy setting process is complete.

设置代理设置。

¥Sets the proxy settings.

你可能需要 ses.closeAllConnections 关闭当前正在运行的连接,以防止使用先前代理的池套接字被未来的请求重用。

¥You may need ses.closeAllConnections to close currently in flight connections to prevent pooled sockets using previous proxy from being reused by future requests.

ses.resolveHost(host, [options])

  • host 字符串 - 要解析的主机名。

    ¥host string - Hostname to resolve.

  • options 对象(可选)

    ¥options Object (optional)

    • queryType 字符串(可选) - 请求的 DNS 查询类型。如果未指定,解析器将根据 IPv4/IPv6 设置选择 A 或 AAAA(或两者):

      ¥queryType string (optional) - Requested DNS query type. If unspecified, resolver will pick A or AAAA (or both) based on IPv4/IPv6 settings:

      • A - 只获取 A 记录

        ¥A - Fetch only A records

      • AAAA - 仅获取 AAAA 记录。

        ¥AAAA - Fetch only AAAA records.

    • source 字符串(可选) - 用于解析地址的源。默认值允许解析器选择合适的源。仅影响大型外部资源的使用(例如调用系统进行解析或使用 DNS)。即使指定了源,结果仍然可以来自缓存、解析 "localhost" 或 IP 字面量等。以下值之一:

      ¥source string (optional) - The source to use for resolved addresses. Default allows the resolver to pick an appropriate source. Only affects use of big external sources (e.g. calling the system for resolution or using DNS). Even if a source is specified, results can still come from cache, resolving "localhost" or IP literals, etc. One of the following values:

      • any(默认) - 解析器将选择合适的源。结果可能来自 DNS、MulticastDNS、HOSTS 文件等

        ¥any (default) - Resolver will pick an appropriate source. Results could come from DNS, MulticastDNS, HOSTS file, etc

      • system - 结果只能从系统或操作系统中检索,例如 通过 getaddrinfo() 系统调用

        ¥system - Results will only be retrieved from the system or OS, e.g. via the getaddrinfo() system call

      • dns - 结果仅来自 DNS 查询

        ¥dns - Results will only come from DNS queries

      • mdns - 结果仅来自多播 DNS 查询

        ¥mdns - Results will only come from Multicast DNS queries

      • localOnly - 不会使用任何外部资源。结果仅来自快速本地源,无论源设置如何,例如 缓存、hosts 文件、IP 字面量解析等

        ¥localOnly - No external sources will be used. Results will only come from fast local sources that are available no matter the source setting, e.g. cache, hosts file, IP literal resolution, etc.

    • cacheUsage 字符串(可选) - 指示哪些 DNS 缓存条目(如果有)可用于提供响应。以下值之一:

      ¥cacheUsage string (optional) - Indicates what DNS cache entries, if any, can be used to provide a response. One of the following values:

      • allowed(默认) - 如果结果未过时,则可能来自主机缓存

        ¥allowed (default) - Results may come from the host cache if non-stale

      • staleAllowed - 即使结果已过时(由于过期或网络更改),也可能来自主机缓存

        ¥staleAllowed - Results may come from the host cache even if stale (by expiration or network changes)

      • disallowed - 结果不会来自主机缓存。

        ¥disallowed - Results will not come from the host cache.

    • secureDnsPolicy 字符串(可选) - 控制解析器对此请求的安全 DNS 行为。以下值之一:

      ¥secureDnsPolicy string (optional) - Controls the resolver's Secure DNS behavior for this request. One of the following values:

      • allow(默认)

        ¥allow (default)

      • disable

返回 Promise<ResolvedHost> - 使用 host 的已解析 IP 地址进行解析。

¥Returns Promise<ResolvedHost> - Resolves with the resolved IP addresses for the host.

ses.resolveProxy(url)

  • url URL

返回 Promise<string> - 使用 url 的代理信息进行解析。

¥Returns Promise<string> - Resolves with the proxy information for url.

ses.forceReloadProxyConfig()

返回 Promise<void> - 当重置代理服务的所有内部状态并重新应用最新的代理配置(如果已可用)时,将解决此问题。如果代理模式为 pac_script,将再次从 pacScript 获取 pac 脚本。

¥Returns Promise<void> - Resolves when the all internal states of proxy service is reset and the latest proxy configuration is reapplied if it's already available. The pac script will be fetched from pacScript again if the proxy mode is pac_script.

ses.setDownloadPath(path)

  • path 字符串 - 下载位置。

    ¥path string - The download location.

设置下载保存目录。默认情况下,下载目录将为相应应用文件夹下的 Downloads

¥Sets download saving directory. By default, the download directory will be the Downloads under the respective app folder.

ses.enableNetworkEmulation(options)

  • options 对象

    ¥options Object

    • offline 布尔值(可选) - 是否模拟网络中断。默认为 false。

      ¥offline boolean (optional) - Whether to emulate network outage. Defaults to false.

    • latency 双(可选) - RTT(以毫秒为单位)默认为 0,这将禁用延迟限制。

      ¥latency Double (optional) - RTT in ms. Defaults to 0 which will disable latency throttling.

    • downloadThroughput 双(可选) - 下载速率(以 Bps 为单位)。默认为 0,这将禁用下载限制。

      ¥downloadThroughput Double (optional) - Download rate in Bps. Defaults to 0 which will disable download throttling.

    • uploadThroughput 双(可选) - 上传速率(以 Bps 为单位)。默认为 0,这将禁用上传限制。

      ¥uploadThroughput Double (optional) - Upload rate in Bps. Defaults to 0 which will disable upload throttling.

使用 session 的给定配置模拟网络。

¥Emulates network with the given configuration for the session.

const win = new BrowserWindow()

// To emulate a GPRS connection with 50kbps throughput and 500 ms latency.
win.webContents.session.enableNetworkEmulation({
latency: 500,
downloadThroughput: 6400,
uploadThroughput: 6400
})

// To emulate a network outage.
win.webContents.session.enableNetworkEmulation({ offline: true })

ses.preconnect(options)

  • options 对象

    ¥options Object

    • url 字符串 - 预连接的 URL。只有原点与打开套接字相关。

      ¥url string - URL for preconnect. Only the origin is relevant for opening the socket.

    • numSockets 号码(可选) - 要预连接的套接字数量。必须介于 1 和 6 之间。默认为 1。

      ¥numSockets number (optional) - number of sockets to preconnect. Must be between 1 and 6. Defaults to 1.

将给定数量的套接字预先连接到源。

¥Preconnects the given number of sockets to an origin.

ses.closeAllConnections()

返回 Promise<void> - 当所有连接都关闭时解决。

¥Returns Promise<void> - Resolves when all connections are closed.

注意:它将终止/失败当前正在进行的所有请求。

¥Note: It will terminate / fail all requests currently in flight.

ses.fetch(input[, init])

返回 Promise<GlobalResponse> - 见 响应

¥Returns Promise<GlobalResponse> - see Response.

使用 Chrome 的网络堆栈发送请求,类似于 fetch() 在渲染器中的工作方式。这与 Node 的 fetch() 不同,后者使用 Node.js 的 HTTP 堆栈。

¥Sends a request, similarly to how fetch() works in the renderer, using Chrome's network stack. This differs from Node's fetch(), which uses Node.js's HTTP stack.

示例:

¥Example:

async function example () {
const response = await net.fetch('https://my.app')
if (response.ok) {
const body = await response.json()
// ... use the result.
}
}

另请参见 net.fetch(),这是一种从 默认会话 发出请求的便捷方法。

¥See also net.fetch(), a convenience method which issues requests from the default session.

有关更多详细信息,请参阅 fetch() 的 MDN 文档。

¥See the MDN documentation for fetch() for more details.

限制:

¥Limitations:

  • net.fetch() 不支持 data:blob: 方案。

    ¥net.fetch() does not support the data: or blob: schemes.

  • integrity 选项的值被忽略。

    ¥The value of the integrity option is ignored.

  • 返回的 Response 对象的 .type.url 值不正确。

    ¥The .type and .url values of the returned Response object are incorrect.

默认情况下,使用 net.fetch 发出的请求可以发送到 定制协议 以及 file:,并且将触发 webRequest 处理程序(如果存在)。当在 RequestInit 中设置非标准 bypassCustomProtocolHandlers 选项时,将不会为此请求调用自定义协议处理程序。这允许将拦截的请求转发到内置处理程序。绕过自定义协议时,webRequest 处理程序仍将被触发。

¥By default, requests made with net.fetch can be made to custom protocols as well as file:, and will trigger webRequest handlers if present. When the non-standard bypassCustomProtocolHandlers option is set in RequestInit, custom protocol handlers will not be called for this request. This allows forwarding an intercepted request to the built-in handler. webRequest handlers will still be triggered when bypassing custom protocols.

protocol.handle('https', (req) => {
if (req.url === 'https://my-app.com') {
return new Response('<body>my app</body>')
} else {
return net.fetch(req, { bypassCustomProtocolHandlers: true })
}
})

ses.disableNetworkEmulation()

禁用 session 已激活的任何网络模拟。重置为原始网络配置。

¥Disables any network emulation already active for the session. Resets to the original network configuration.

ses.setCertificateVerifyProc(proc)

  • proc Function | null

    • request 对象

      ¥request Object

      • hostname 字符串

        ¥hostname string

      • certificate 证书

        ¥certificate Certificate

      • validatedCertificate 证书

        ¥validatedCertificate Certificate

      • isIssuedByKnownRoot 布尔值 - true(如果 Chromium 将根 CA 识别为标准根)。如果不是,则该证书可能是由其根已在本地安装的 MITM 代理生成的(例如,由公司代理)。如果 verificationResult 不是 OK,则不应信任此信息。

        ¥isIssuedByKnownRoot boolean - true if Chromium recognises the root CA as a standard root. If it isn't then it's probably the case that this certificate was generated by a MITM proxy whose root has been installed locally (for example, by a corporate proxy). This should not be trusted if the verificationResult is not OK.

      • verificationResult 字符串 - 如果证书可信,则显示 OK,否则出现类似 CERT_REVOKED 的错误。

        ¥verificationResult string - OK if the certificate is trusted, otherwise an error like CERT_REVOKED.

      • errorCode 整数 - 错误代码。

        ¥errorCode Integer - Error code.

    • callback 函数

      ¥callback Function

      • verificationResult 整数 - 值可以是 此处 中的证书错误代码之一。除了证书错误代码之外,还可以使用以下特殊代码。

        ¥verificationResult Integer - Value can be one of certificate error codes from here. Apart from the certificate error codes, the following special codes can be used.

        • 0 - 表示成功并禁用证书透明度验证。

          ¥0 - Indicates success and disables Certificate Transparency verification.

        • -2 - 表示失败。

          ¥-2 - Indicates failure.

        • -3 - 使用来自 Chromium 的验证结果。

          ¥-3 - Uses the verification result from chromium.

设置 session 的证书验证过程,每当请求服务器证书验证时,将使用 proc(request, callback) 调用 proc。调用 callback(0) 接受证书,调用 callback(-2) 拒绝证书。

¥Sets the certificate verify proc for session, the proc will be called with proc(request, callback) whenever a server certificate verification is requested. Calling callback(0) accepts the certificate, calling callback(-2) rejects it.

调用 setCertificateVerifyProc(null) 将恢复到默认的证书验证过程。

¥Calling setCertificateVerifyProc(null) will revert back to default certificate verify proc.

const { BrowserWindow } = require('electron')
const win = new BrowserWindow()

win.webContents.session.setCertificateVerifyProc((request, callback) => {
const { hostname } = request
if (hostname === 'github.com') {
callback(0)
} else {
callback(-2)
}
})

注意:该过程的结果由网络服务缓存。

¥NOTE: The result of this procedure is cached by the network service.

ses.setPermissionRequestHandler(handler)

  • handler Function | null

    • webContents WebContents - 请求许可的 WebContents。请注意,如果请求来自子帧,你应该使用 requestingUrl 检查请求来源。

      ¥webContents WebContents - WebContents requesting the permission. Please note that if the request comes from a subframe you should use requestingUrl to check the request origin.

    • permission 字符串 - 请求的权限的类型。

      ¥permission string - The type of requested permission.

      • clipboard-read - 请求访问以从剪贴板读取。

        ¥clipboard-read - Request access to read from the clipboard.

      • clipboard-sanitized-write - 请求写入剪贴板的权限。

        ¥clipboard-sanitized-write - Request access to write to the clipboard.

      • display-capture - 通过 屏幕截图 API 请求访问以捕获屏幕。

        ¥display-capture - Request access to capture the screen via the Screen Capture API.

      • fullscreen - 通过 全屏 API 请求控制应用的全屏状态。

        ¥fullscreen - Request control of the app's fullscreen state via the Fullscreen API.

      • geolocation - 通过 地理定位 API 请求访问用户的位置

        ¥geolocation - Request access to the user's location via the Geolocation API

      • idle-detection - 通过 空闲检测器 API 请求访问用户的空闲状态。

        ¥idle-detection - Request access to the user's idle state via the IdleDetector API.

      • media - 请求访问媒体设备,例如摄像头、麦克风和扬声器。

        ¥media - Request access to media devices such as camera, microphone and speakers.

      • mediaKeySystem - 请求访问受 DRM 保护的内容。

        ¥mediaKeySystem - Request access to DRM protected content.

      • midi - 请求 网络 MIDI API 中的 MIDI 访问。

        ¥midi - Request MIDI access in the Web MIDI API.

      • midiSysex - 请求使用 网络 MIDI API 中的系统独占消息。

        ¥midiSysex - Request the use of system exclusive messages in the Web MIDI API.

      • notifications - 请求创建通知并能够使用 通知 API 在用户的系统托盘中显示它们

        ¥notifications - Request notification creation and the ability to display them in the user's system tray using the Notifications API

      • pointerLock - 请求通过 指针锁 API 直接将鼠标移动解释为输入法。这些请求似乎总是源自主机。

        ¥pointerLock - Request to directly interpret mouse movements as an input method via the Pointer Lock API. These requests always appear to originate from the main frame.

      • keyboardLock - 通过 Keyboard Lock API 请求捕获物理键盘上任意或所有按键的按键操作。这些请求似乎总是源自主机。

        ¥keyboardLock - Request capture of keypresses for any or all of the keys on the physical keyboard via the Keyboard Lock API. These requests always appear to originate from the main frame.

      • openExternal - 请求在外部应用中打开链接。

        ¥openExternal - Request to open links in external applications.

      • speaker-selection - 请求通过 发言人选择权限策略 枚举和选择音频输出设备。

        ¥speaker-selection - Request to enumerate and select audio output devices via the speaker-selection permissions policy.

      • storage-access - 允许在第三方上下文中加载的内容使用 存储访问 API.cookie 请求访问第三方 cookie。

        ¥storage-access - Allows content loaded in a third-party context to request access to third-party cookies using the Storage Access API.

      • top-level-storage-access - 允许顶层站点代表来自使用 存储访问 API.0 的同一相关网站集中的另一个站点的嵌入内容请求第三方 cookie 访问。

        ¥top-level-storage-access - Allow top-level sites to request third-party cookie access on behalf of embedded content originating from another site in the same related website set using the Storage Access API.

      • window-management - 使用 getScreenDetails API 请求访问枚举屏幕。

        ¥window-management - Request access to enumerate screens using the getScreenDetails API.

      • unknown - 无法识别的权限请求。

        ¥unknown - An unrecognized permission request.

      • fileSystem - 使用 文件系统 API 请求访问读、写和文件管理功能。

        ¥fileSystem - Request access to read, write, and file management capabilities using the File System API.

    • callback 函数

      ¥callback Function

      • permissionGranted 布尔值 - 允许或拒绝该权限。

        ¥permissionGranted boolean - Allow or deny the permission.

    • details PermissionRequest | FilesystemPermissionRequest | MediaAccessPermissionRequest | OpenExternalPermissionRequest - 有关所请求的权限的其他信息。

      ¥details PermissionRequest | FilesystemPermissionRequest | MediaAccessPermissionRequest | OpenExternalPermissionRequest - Additional information about the permission being requested.

设置可用于响应 session 权限请求的处理程序。调用 callback(true) 将允许该权限,而 callback(false) 将拒绝该权限。要清除处理程序,请调用 setPermissionRequestHandler(null)。请注意,你还必须实现 setPermissionCheckHandler 才能获得完整的权限处理。大多数 Web API 都会进行权限检查,然后在检查被拒绝时发出权限请求。

¥Sets the handler which can be used to respond to permission requests for the session. Calling callback(true) will allow the permission and callback(false) will reject it. To clear the handler, call setPermissionRequestHandler(null). Please note that you must also implement setPermissionCheckHandler to get complete permission handling. Most web APIs do a permission check and then make a permission request if the check is denied.

const { session } = require('electron')
session.fromPartition('some-partition').setPermissionRequestHandler((webContents, permission, callback) => {
if (webContents.getURL() === 'some-host' && permission === 'notifications') {
return callback(false) // denied.
}

callback(true)
})

ses.setPermissionCheckHandler(handler)

  • handler Function<boolean> | null

    • webContents(WebContents | null) - WebContents 检查权限。请注意,如果请求来自子帧,你应该使用 requestingUrl 检查请求来源。所有进行权限检查的跨源子框架都会将 null webContents 传递给此处理程序,而某些其他权限检查(例如 notifications 检查)将始终通过 null。你应该使用 embeddingOriginrequestingOrigin 来确定所属帧和请求帧分别位于哪个源。

      ¥webContents (WebContents | null) - WebContents checking the permission. Please note that if the request comes from a subframe you should use requestingUrl to check the request origin. All cross origin sub frames making permission checks will pass a null webContents to this handler, while certain other permission checks such as notifications checks will always pass null. You should use embeddingOrigin and requestingOrigin to determine what origin the owning frame and the requesting frame are on respectively.

    • permission 字符串 - 权限检查的类型。

      ¥permission string - Type of permission check.

      • clipboard-read - 请求访问以从剪贴板读取。

        ¥clipboard-read - Request access to read from the clipboard.

      • clipboard-sanitized-write - 请求写入剪贴板的权限。

        ¥clipboard-sanitized-write - Request access to write to the clipboard.

      • geolocation - 通过 地理定位 API 访问用户的地理位置数据

        ¥geolocation - Access the user's geolocation data via the Geolocation API

      • fullscreen - 通过 全屏 API 控制应用的全屏状态。

        ¥fullscreen - Control of the app's fullscreen state via the Fullscreen API.

      • hid - 通过 WebHID API 访问 HID 协议来操作 HID 设备。

        ¥hid - Access the HID protocol to manipulate HID devices via the WebHID API.

      • idle-detection - 通过 空闲检测器 API 访问用户的空闲状态。

        ¥idle-detection - Access the user's idle state via the IdleDetector API.

      • media - 访问相机、麦克风和扬声器等媒体设备。

        ¥media - Access to media devices such as camera, microphone and speakers.

      • mediaKeySystem - 访问受 DRM 保护的内容。

        ¥mediaKeySystem - Access to DRM protected content.

      • midi - 在 网络 MIDI API 中启用 MIDI 访问。

        ¥midi - Enable MIDI access in the Web MIDI API.

      • midiSysex - 使用 网络 MIDI API 中的系统独占消息。

        ¥midiSysex - Use system exclusive messages in the Web MIDI API.

      • notifications - 使用 通知 API 配置并向用户显示桌面通知。

        ¥notifications - Configure and display desktop notifications to the user with the Notifications API.

      • openExternal - 在外部应用中打开链接。

        ¥openExternal - Open links in external applications.

      • pointerLock - 通过 指针锁 API 直接将鼠标移动解释为输入法。这些请求似乎总是源自主机。

        ¥pointerLock - Directly interpret mouse movements as an input method via the Pointer Lock API. These requests always appear to originate from the main frame.

      • serial - 使用 网络串行 API 读取和写入串行设备。

        ¥serial - Read from and write to serial devices with the Web Serial API.

      • storage-access - 允许在第三方上下文中加载的内容使用 存储访问 API.cookie 请求访问第三方 cookie。

        ¥storage-access - Allows content loaded in a third-party context to request access to third-party cookies using the Storage Access API.

      • top-level-storage-access - 允许顶层站点代表来自使用 存储访问 API.0 的同一相关网站集中的另一个站点的嵌入内容请求第三方 cookie 访问。

        ¥top-level-storage-access - Allow top-level sites to request third-party cookie access on behalf of embedded content originating from another site in the same related website set using the Storage Access API.

      • usb - 使用 网络 USB API 将非标准通用串行总线 (USB) 兼容设备服务公开到网络。

        ¥usb - Expose non-standard Universal Serial Bus (USB) compatible devices services to the web with the WebUSB API.

    • requestingOrigin 字符串 - 权限检查的原始 URL

      ¥requestingOrigin string - The origin URL of the permission check

    • details 对象 - 某些属性仅适用于某些权限类型。

      ¥details Object - Some properties are only available on certain permission types.

      • embeddingOrigin 字符串(可选) - 嵌入进行权限检查的框架的框架的起源。仅为进行权限检查的跨源子框架设置。

        ¥embeddingOrigin string (optional) - The origin of the frame embedding the frame that made the permission check. Only set for cross-origin sub frames making permission checks.

      • securityOrigin 字符串(可选) - media 检查的安全来源。

        ¥securityOrigin string (optional) - The security origin of the media check.

      • mediaType 字符串(可选) - 请求的媒体访问类型可以是 videoaudiounknown

        ¥mediaType string (optional) - The type of media access being requested, can be video, audio or unknown

      • requestingUrl 字符串(可选) - 请求框架加载的最后一个 URL。不为进行权限检查的跨源子框架提供此功能。

        ¥requestingUrl string (optional) - The last URL the requesting frame loaded. This is not provided for cross-origin sub frames making permission checks.

      • isMainFrame 布尔值 - 发出请求的框架是否为主框架

        ¥isMainFrame boolean - Whether the frame making the request is the main frame

设置可用于响应 session 权限检查的处理程序。返回 true 将允许该权限,false 将拒绝该权限。请注意,你还必须实现 setPermissionRequestHandler 才能获得完整的权限处理。大多数 Web API 都会进行权限检查,然后在检查被拒绝时发出权限请求。要清除处理程序,请调用 setPermissionCheckHandler(null)

¥Sets the handler which can be used to respond to permission checks for the session. Returning true will allow the permission and false will reject it. Please note that you must also implement setPermissionRequestHandler to get complete permission handling. Most web APIs do a permission check and then make a permission request if the check is denied. To clear the handler, call setPermissionCheckHandler(null).

const { session } = require('electron')
const url = require('url')
session.fromPartition('some-partition').setPermissionCheckHandler((webContents, permission, requestingOrigin) => {
if (new URL(requestingOrigin).hostname === 'some-host' && permission === 'notifications') {
return true // granted
}

return false // denied
})

ses.setDisplayMediaRequestHandler(handler)

  • handler Function | null

    • request 对象

      ¥request Object

      • frame Web 框架主 - 请求访问媒体的框架。

        ¥frame WebFrameMain - Frame that is requesting access to media.

      • securityOrigin 字符串 - 发出请求的页面的来源。

        ¥securityOrigin String - Origin of the page making the request.

      • videoRequested Boolean - 如果 Web 内容请求视频流,则为 true。

        ¥videoRequested Boolean - true if the web content requested a video stream.

      • audioRequested Boolean - 如果 Web 内容请求音频流,则为 true。

        ¥audioRequested Boolean - true if the web content requested an audio stream.

      • userGesture Boolean - 触发此请求时用户手势是否处于活动状态。

        ¥userGesture Boolean - Whether a user gesture was active when this request was triggered.

    • callback 函数

      ¥callback Function

      • streams 对象

        ¥streams Object

        • video Object | Web 框架主 (optional)

          ¥video Object | WebFrameMain (optional)

          • id 字符串 - 被授予的流的 ID。这通常来自 桌面捕获源 对象。

            ¥id String - The id of the stream being granted. This will usually come from a DesktopCapturerSource object.

          • name 字符串 - 被授予的流的名称。这通常来自 桌面捕获源 对象。

            ¥name String - The name of the stream being granted. This will usually come from a DesktopCapturerSource object.

        • audio 字符串| Web 框架主(可选) - 如果指定了字符串,则可以是 loopbackloopbackWithMute。指定环回设备将捕获系统音频,目前仅在 Windows 上支持。如果指定了 WebFrameMain,将从该帧捕获音频。

          ¥audio String | WebFrameMain (optional) - If a string is specified, can be loopback or loopbackWithMute. Specifying a loopback device will capture system audio, and is currently only supported on Windows. If a WebFrameMain is specified, will capture audio from that frame.

        • enableLocalEcho Boolean (optional) - 如果 audioWeb 框架主 并且设置为 true,则音频的本地播放将不会静音(例如,使用 MediaRecorder 录制 WebFrameMain 并将此标志设置为 true 将允许音频在录制时传递到扬声器)。默认为 false

          ¥enableLocalEcho Boolean (optional) - If audio is a WebFrameMain and this is set to true, then local playback of audio will not be muted (e.g. using MediaRecorder to record WebFrameMain with this flag set to true will allow audio to pass through to the speakers while recording). Default is false.

当 Web 内容请求通过 navigator.mediaDevices.getDisplayMedia API 访问显示媒体时,将调用此处理程序。使用 desktopCapturer API 选择要授予访问权限的流。

¥This handler will be called when web content requests access to display media via the navigator.mediaDevices.getDisplayMedia API. Use the desktopCapturer API to choose which stream(s) to grant access to.

const { session, desktopCapturer } = require('electron')

session.defaultSession.setDisplayMediaRequestHandler((request, callback) => {
desktopCapturer.getSources({ types: ['screen'] }).then((sources) => {
// Grant access to the first screen found.
callback({ video: sources[0] })
})
})

Web 框架主 对象作为视频或音频流传递将从该帧捕获视频或音频流。

¥Passing a WebFrameMain object as a video or audio stream will capture the video or audio stream from that frame.

const { session } = require('electron')

session.defaultSession.setDisplayMediaRequestHandler((request, callback) => {
// Allow the tab to capture itself.
callback({ video: request.frame })
})

传递 null 而不是函数会将处理程序重置为其默认状态。

¥Passing null instead of a function resets the handler to its default state.

ses.setDevicePermissionHandler(handler)

  • handler Function<boolean> | null

    • details 对象

      ¥details Object

      • deviceType 字符串 - 请求权限的设备类型可以是 hidserialusb

        ¥deviceType string - The type of device that permission is being requested on, can be hid, serial, or usb.

      • origin 字符串 - 设备权限检查的原始 URL。

        ¥origin string - The origin URL of the device permission check.

      • device HID 设备 | SerialPort | USB 设备 - 正在请求权限的设备。

        ¥device HIDDevice | SerialPort | USBDevice - the device that permission is being requested for.

设置可用于响应 session 的设备权限检查的处理程序。返回 true 将允许设备被允许,而 false 将拒绝它。要清除处理程序,请调用 setDevicePermissionHandler(null)。该处理程序可用于向设备提供默认许可,而无需首先调用设备许可(例如通过 navigator.hid.requestDevice)。如果未定义此处理程序,则将使用通过设备选择(例如通过 navigator.hid.requestDevice)授予的默认设备权限。此外,Electron 的默认行为是将授予的设备权限存储在内存中。如果需要长期存储,开发者可以存储授予的设备权限(例如,在处理 select-hid-device 事件时),然后使用 setDevicePermissionHandler 从该存储中读取。

¥Sets the handler which can be used to respond to device permission checks for the session. Returning true will allow the device to be permitted and false will reject it. To clear the handler, call setDevicePermissionHandler(null). This handler can be used to provide default permissioning to devices without first calling for permission to devices (eg via navigator.hid.requestDevice). If this handler is not defined, the default device permissions as granted through device selection (eg via navigator.hid.requestDevice) will be used. Additionally, the default behavior of Electron is to store granted device permission in memory. If longer term storage is needed, a developer can store granted device permissions (eg when handling the select-hid-device event) and then read from that storage with setDevicePermissionHandler.

const { app, BrowserWindow } = require('electron')

let win = null

app.whenReady().then(() => {
win = new BrowserWindow()

win.webContents.session.setPermissionCheckHandler((webContents, permission, requestingOrigin, details) => {
if (permission === 'hid') {
// Add logic here to determine if permission should be given to allow HID selection
return true
} else if (permission === 'serial') {
// Add logic here to determine if permission should be given to allow serial port selection
} else if (permission === 'usb') {
// Add logic here to determine if permission should be given to allow USB device selection
}
return false
})

// Optionally, retrieve previously persisted devices from a persistent store
const grantedDevices = fetchGrantedDevices()

win.webContents.session.setDevicePermissionHandler((details) => {
if (new URL(details.origin).hostname === 'some-host' && details.deviceType === 'hid') {
if (details.device.vendorId === 123 && details.device.productId === 345) {
// Always allow this type of device (this allows skipping the call to `navigator.hid.requestDevice` first)
return true
}

// Search through the list of devices that have previously been granted permission
return grantedDevices.some((grantedDevice) => {
return grantedDevice.vendorId === details.device.vendorId &&
grantedDevice.productId === details.device.productId &&
grantedDevice.serialNumber && grantedDevice.serialNumber === details.device.serialNumber
})
} else if (details.deviceType === 'serial') {
if (details.device.vendorId === 123 && details.device.productId === 345) {
// Always allow this type of device (this allows skipping the call to `navigator.hid.requestDevice` first)
return true
}
}
return false
})

win.webContents.session.on('select-hid-device', (event, details, callback) => {
event.preventDefault()
const selectedDevice = details.deviceList.find((device) => {
return device.vendorId === 9025 && device.productId === 67
})
callback(selectedDevice?.deviceId)
})
})

ses.setUSBProtectedClassesHandler(handler)

  • handler Function<string[]> | null

    • details 对象

      ¥details Object

      • protectedClasses 字符串[] - 当前受保护的 USB 类别列表。可能的类值包括:

        ¥protectedClasses string[] - The current list of protected USB classes. Possible class values include:

        • audio

        • audio-video

        • hid

        • mass-storage

        • smart-card

        • video

        • wireless

设置可用于覆盖哪个 USB 类受到保护。处理程序的返回值是 USB 类的字符串数组,应将其视为受保护的(例如,在渲染器中不可用)。数组的有效值为:

¥Sets the handler which can be used to override which USB classes are protected. The return value for the handler is a string array of USB classes which should be considered protected (eg not available in the renderer). Valid values for the array are:

  • audio

  • audio-video

  • hid

  • mass-storage

  • smart-card

  • video

  • wireless

从处理程序返回一个空字符串数组将允许所有 USB 类;返回传入的数组将维护受保护 USB 类的默认列表(如果未定义处理程序,这也是默认行为)。要清除处理程序,请调用 setUSBProtectedClassesHandler(null)

¥Returning an empty string array from the handler will allow all USB classes; returning the passed in array will maintain the default list of protected USB classes (this is also the default behavior if a handler is not defined). To clear the handler, call setUSBProtectedClassesHandler(null).

const { app, BrowserWindow } = require('electron')

let win = null

app.whenReady().then(() => {
win = new BrowserWindow()

win.webContents.session.setUSBProtectedClassesHandler((details) => {
// Allow all classes:
// return []
// Keep the current set of protected classes:
// return details.protectedClasses
// Selectively remove classes:
return details.protectedClasses.filter((usbClass) => {
// Exclude classes except for audio classes
return usbClass.indexOf('audio') === -1
})
})
})

ses.setBluetoothPairingHandler(handler) Windows Linux

  • handler Function | null

    • details 对象

      ¥details Object

      • deviceId 字符串

        ¥deviceId string

      • pairingKind 字符串 - 请求的配对提示的类型。以下值之一:

        ¥pairingKind string - The type of pairing prompt being requested. One of the following values:

        • confirm 此提示请求确认蓝牙设备应配对。

          ¥confirm This prompt is requesting confirmation that the Bluetooth device should be paired.

        • confirmPin 此提示请求确认所提供的 PIN 码与设备上显示的 PIN 码相符。

          ¥confirmPin This prompt is requesting confirmation that the provided PIN matches the pin displayed on the device.

        • providePin 此提示请求为设备提供 PIN。

          ¥providePin This prompt is requesting that a pin be provided for the device.

      • frame Web 框架主

        ¥frame WebFrameMain

      • pin 字符串(可选) - 用于验证 pairingKind 是否为 confirmPin 的引脚值。

        ¥pin string (optional) - The pin value to verify if pairingKind is confirmPin.

    • callback 函数

      ¥callback Function

      • response 对象

        ¥response Object

        • confirmed 布尔值 - 如果取消对话框,则应传入 false。如果 pairingKindconfirmconfirmPin,则该值应指示配对是否已确认。如果 pairingKindprovidePin,则在提供值时该值应为 true

          ¥confirmed boolean - false should be passed in if the dialog is canceled. If the pairingKind is confirm or confirmPin, this value should indicate if the pairing is confirmed. If the pairingKind is providePin the value should be true when a value is provided.

        • pin 字符串 | 空(可选) - 当 pairingKindprovidePin 时,该值应该是蓝牙设备所需的引脚。

          ¥pin string | null (optional) - When the pairingKind is providePin this value should be the required pin for the Bluetooth device.

设置处理程序以响应蓝牙配对请求。该处理程序允许开发者处理在配对前需要额外验证的设备。如果未定义处理程序,Linux 或 Windows 上任何需要额外验证的配对都将自动取消。macOS 不需要处理程序,因为 macOS 会自动处理配对。要清除处理程序,请调用 setBluetoothPairingHandler(null)

¥Sets a handler to respond to Bluetooth pairing requests. This handler allows developers to handle devices that require additional validation before pairing. When a handler is not defined, any pairing on Linux or Windows that requires additional validation will be automatically cancelled. macOS does not require a handler because macOS handles the pairing automatically. To clear the handler, call setBluetoothPairingHandler(null).

const { app, BrowserWindow, session } = require('electron')
const path = require('node:path')

function createWindow () {
let bluetoothPinCallback = null

const mainWindow = new BrowserWindow({
webPreferences: {
preload: path.join(__dirname, 'preload.js')
}
})

mainWindow.webContents.session.setBluetoothPairingHandler((details, callback) => {
bluetoothPinCallback = callback
// Send a IPC message to the renderer to prompt the user to confirm the pairing.
// Note that this will require logic in the renderer to handle this message and
// display a prompt to the user.
mainWindow.webContents.send('bluetooth-pairing-request', details)
})

// Listen for an IPC message from the renderer to get the response for the Bluetooth pairing.
mainWindow.webContents.ipc.on('bluetooth-pairing-response', (event, response) => {
bluetoothPinCallback(response)
})
}

app.whenReady().then(() => {
createWindow()
})

ses.clearHostResolverCache()

返回 Promise<void> - 操作完成后解决。

¥Returns Promise<void> - Resolves when the operation is complete.

清除主机解析器缓存。

¥Clears the host resolver cache.

ses.allowNTLMCredentialsForDomains(domains)

  • domains 字符串 - 启用集成身份验证的服务器的逗号分隔列表。

    ¥domains string - A comma-separated list of servers for which integrated authentication is enabled.

动态设置是否始终发送 HTTP NTLM 或协商身份验证的凭据。

¥Dynamically sets whether to always send credentials for HTTP NTLM or Negotiate authentication.

const { session } = require('electron')
// consider any url ending with `example.com`, `foobar.com`, `baz`
// for integrated authentication.
session.defaultSession.allowNTLMCredentialsForDomains('*example.com, *foobar.com, *baz')

// consider all urls for integrated authentication.
session.defaultSession.allowNTLMCredentialsForDomains('*')

ses.setUserAgent(userAgent[, acceptLanguages])

  • userAgent 字符串

    ¥userAgent string

  • acceptLanguages 字符串(可选)

    ¥acceptLanguages string (optional)

覆盖此会话的 userAgentacceptLanguages

¥Overrides the userAgent and acceptLanguages for this session.

acceptLanguages 必须是逗号分隔的语言代码有序列表,例如 "en-US,fr,de,ko,zh-CN,ja"

¥The acceptLanguages must a comma separated ordered list of language codes, for example "en-US,fr,de,ko,zh-CN,ja".

这不会影响现有的 WebContents,并且每个 WebContents 都可以使用 webContents.setUserAgent 覆盖会话范围的用户代理。

¥This doesn't affect existing WebContents, and each WebContents can use webContents.setUserAgent to override the session-wide user agent.

ses.isPersistent()

返回 boolean - 此会话是否是持久会话。BrowserWindow 的默认 webContents 会话是持久的。从分区创建会话时,前缀为 persist: 的会话将是持久的,而其他会话将是临时的。

¥Returns boolean - Whether or not this session is a persistent one. The default webContents session of a BrowserWindow is persistent. When creating a session from a partition, session prefixed with persist: will be persistent, while others will be temporary.

ses.getUserAgent()

返回 string - 此会话的用户代理。

¥Returns string - The user agent for this session.

ses.setSSLConfig(config)

  • config 对象

    ¥config Object

    • minVersion 字符串(可选) - 可以是 tls1tls1.1tls1.2tls1.3。连接到远程服务器时允许的最低 SSL 版本。默认为 tls1

      ¥minVersion string (optional) - Can be tls1, tls1.1, tls1.2 or tls1.3. The minimum SSL version to allow when connecting to remote servers. Defaults to tls1.

    • maxVersion 字符串(可选) - 可以是 tls1.2tls1.3。连接到远程服务器时允许的最大 SSL 版本。默认为 tls1.3

      ¥maxVersion string (optional) - Can be tls1.2 or tls1.3. The maximum SSL version to allow when connecting to remote servers. Defaults to tls1.3.

    • disabledCipherSuites Integer[] (optional) - 除了网络内置策略禁用的密码套件之外,还应明确阻止使用的密码套件列表。支持的字面量形式:0xAABB,其中 AA 是 cipher_suite[0],BB 是 cipher_suite[1],如 RFC 2246 第 7.4.1.2 节中所定义。这种形式的无法识别但可解析的密码套件不会返回错误。前任:要禁用 TLS_RSA_WITH_RC4_128_MD5,请指定 0x0004,要禁用 TLS_ECDH_ECDSA_WITH_RC4_128_SHA,请指定 0xC002。请注意,无法使用此机制禁用 TLSv1.3 密码。

      ¥disabledCipherSuites Integer[] (optional) - List of cipher suites which should be explicitly prevented from being used in addition to those disabled by the net built-in policy. Supported literal forms: 0xAABB, where AA is cipher_suite[0] and BB is cipher_suite[1], as defined in RFC 2246, Section 7.4.1.2. Unrecognized but parsable cipher suites in this form will not return an error. Ex: To disable TLS_RSA_WITH_RC4_128_MD5, specify 0x0004, while to disable TLS_ECDH_ECDSA_WITH_RC4_128_SHA, specify 0xC002. Note that TLSv1.3 ciphers cannot be disabled using this mechanism.

设置会话的 SSL 配置。所有后续网络请求都将使用新配置。现有的网络连接(例如 WebSocket 连接)不会被终止,但池中的旧套接字不会被新连接重用。

¥Sets the SSL configuration for the session. All subsequent network requests will use the new configuration. Existing network connections (such as WebSocket connections) will not be terminated, but old sockets in the pool will not be reused for new connections.

ses.getBlobData(identifier)

  • identifier 字符串 - 有效的 UUID。

    ¥identifier string - Valid UUID.

返回 Promise<Buffer> - 使用 blob 数据进行解析。

¥Returns Promise<Buffer> - resolves with blob data.

ses.downloadURL(url[, options])

  • url 字符串

    ¥url string

  • options 对象(可选)

    ¥options Object (optional)

    • headers 记录<字符串,字符串>(可选) - HTTP 请求标头。

      ¥headers Record<string, string> (optional) - HTTP request headers.

启动 url 处资源的下载。API 将生成可通过 will-download 事件访问的 DownloadItem

¥Initiates a download of the resource at url. The API will generate a DownloadItem that can be accessed with the will-download event.

注意:与 webContents.downloadURL 不同,这不会执行与页面来源相关的任何安全检查。

¥Note: This does not perform any security checks that relate to a page's origin, unlike webContents.downloadURL.

ses.createInterruptedDownload(options)

  • options 对象

    ¥options Object

    • path 字符串 - 下载的绝对路径。

      ¥path string - Absolute path of the download.

    • urlChain 字符串[] - 用于下载的完整 URL 链。

      ¥urlChain string[] - Complete URL chain for the download.

    • mimeType 字符串(可选)

      ¥mimeType string (optional)

    • offset 整数 - 下载的起始范围。

      ¥offset Integer - Start range for the download.

    • length 整数 - 下载的总长度。

      ¥length Integer - Total length of the download.

    • lastModified 字符串(可选) - Last-Modified 标头值。

      ¥lastModified string (optional) - Last-Modified header value.

    • eTag 字符串(可选) - ETag 标头值。

      ¥eTag string (optional) - ETag header value.

    • startTime 双(可选) - 自 UNIX 纪元以来开始下载的时间(以秒为单位)。

      ¥startTime Double (optional) - Time when download was started in number of seconds since UNIX epoch.

允许从之前的 Session 恢复 cancelledinterrupted 下载。API 将生成可通过 will-download 事件访问的 DownloadItemDownloadItem 不会有任何与之关联的 WebContents,初始状态将为 interrupted。仅当在 DownloadItem 上调用 resume API 时才会开始下载。

¥Allows resuming cancelled or interrupted downloads from previous Session. The API will generate a DownloadItem that can be accessed with the will-download event. The DownloadItem will not have any WebContents associated with it and the initial state will be interrupted. The download will start only when the resume API is called on the DownloadItem.

ses.clearAuthCache()

返回 Promise<void> - 当会话的 HTTP 身份验证缓存被清除时解析。

¥Returns Promise<void> - resolves when the session’s HTTP authentication cache has been cleared.

ses.setPreloads(preloads)

  • preloads 字符串[] - 预加载脚本的绝对路径数组

    ¥preloads string[] - An array of absolute path to preload scripts

添加将在正常 preload 脚本运行之前在与此会话关联的所有 Web 内容上执行的脚本。

¥Adds scripts that will be executed on ALL web contents that are associated with this session just before normal preload scripts run.

ses.getPreloads()

返回 string[] 已注册的预加载脚本的路径数组。

¥Returns string[] an array of paths to preload scripts that have been registered.

ses.setCodeCachePath(path)

  • path 字符串 - 存储渲染器生成的 v8 JS 代码缓存的绝对路径。

    ¥path String - Absolute path to store the v8 generated JS code cache from the renderer.

设置存储本次会话生成的 JS 代码缓存 的目录。在此调用之前,用户不需要创建目录,如果不存在,运行时将创建,否则将使用现有目录。如果无法创建目录,则将不会使用代码缓存,并且与代码缓存相关的所有操作都将在运行时内默默失败。默认情况下,该目录将为相应用户数据文件夹下的 Code Cache

¥Sets the directory to store the generated JS code cache for this session. The directory is not required to be created by the user before this call, the runtime will create if it does not exist otherwise will use the existing directory. If directory cannot be created, then code cache will not be used and all operations related to code cache will fail silently inside the runtime. By default, the directory will be Code Cache under the respective user data folder.

请注意,默认情况下,仅对 http(s) URL 启用代码缓存,要为自定义协议启用代码缓存,必须在注册协议时指定 codeCache: truestandard: true

¥Note that by default code cache is only enabled for http(s) URLs, to enable code cache for custom protocols, codeCache: true and standard: true must be specified when registering the protocol.

ses.clearCodeCaches(options)

  • options 对象

    ¥options Object

    • urls 字符串[](可选) - 需要删除生成代码缓存的资源对应的 url 数组。如果列表为空,则缓存目录中的所有条目都将被删除。

      ¥urls String[] (optional) - An array of url corresponding to the resource whose generated code cache needs to be removed. If the list is empty then all entries in the cache directory will be removed.

返回 Promise<void> - 当代码缓存清除操作完成时解决。

¥Returns Promise<void> - resolves when the code cache clear operation is complete.

ses.setSpellCheckerEnabled(enable)

  • enable 布尔值

    ¥enable boolean

设置是否启用内置拼写检查器。

¥Sets whether to enable the builtin spell checker.

ses.isSpellCheckerEnabled()

返回 boolean - 是否启用内置拼写检查器。

¥Returns boolean - Whether the builtin spell checker is enabled.

ses.setSpellCheckerLanguages(languages)

  • languages 字符串[] - 用于启用拼写检查器的语言代码数组。

    ¥languages string[] - An array of language codes to enable the spellchecker for.

内置的拼写检查器不会自动检测用户输入的语言。为了让拼写检查器正确检查单词,你必须使用一组语言代码调用此 API。你可以使用 ses.availableSpellCheckerLanguages 属性获取支持的语言代码列表。

¥The built in spellchecker does not automatically detect what language a user is typing in. In order for the spell checker to correctly check their words you must call this API with an array of language codes. You can get the list of supported language codes with the ses.availableSpellCheckerLanguages property.

注意:在 macOS 上,使用操作系统拼写检查器并会自动检测你的语言。此 API 在 macOS 上是无操作的。

¥Note: On macOS the OS spellchecker is used and will detect your language automatically. This API is a no-op on macOS.

ses.getSpellCheckerLanguages()

返回 string[] - 启用拼写检查器的语言代码数组。如果此列表为空,拼写检查器将回退到使用 en-US。默认情况下,启动时如果此设置为空列表,Electron 将尝试使用当前操作系统区域设置填充此设置。此设置在重新启动后仍然保留。

¥Returns string[] - An array of language codes the spellchecker is enabled for. If this list is empty the spellchecker will fallback to using en-US. By default on launch if this setting is an empty list Electron will try to populate this setting with the current OS locale. This setting is persisted across restarts.

注意:在 macOS 上,使用操作系统拼写检查器并拥有自己的语言列表。在 macOS 上,此 API 将返回操作系统配置的任何语言。

¥Note: On macOS the OS spellchecker is used and has its own list of languages. On macOS, this API will return whichever languages have been configured by the OS.

ses.setSpellCheckerDictionaryDownloadURL(url)

  • url 字符串 - Electron 用于下载 hunspell 词典的基本 URL。

    ¥url string - A base URL for Electron to download hunspell dictionaries from.

默认情况下,Electron 将从 Chromium CDN 下载 hunspell 词典。如果你想覆盖此行为,你可以使用此 API 将词典下载器指向你自己托管的 hunspell 词典版本。我们在每个版本中发布一个 hunspell_dictionaries.zip 文件,其中包含你需要在此处托管的文件。

¥By default Electron will download hunspell dictionaries from the Chromium CDN. If you want to override this behavior you can use this API to point the dictionary downloader at your own hosted version of the hunspell dictionaries. We publish a hunspell_dictionaries.zip file with each release which contains the files you need to host here.

文件服务器必须不区分大小写。如果你无法执行此操作,则必须将每个文件上传两次:一次使用 ZIP 文件中的大小写,一次使用文件名全部小写。

¥The file server must be case insensitive. If you cannot do this, you must upload each file twice: once with the case it has in the ZIP file and once with the filename as all lowercase.

如果 hunspell_dictionaries.zip 中存在的文件在 https://example.com/dictionaries/language-code.bdic 中可用,那么你应该使用 ses.setSpellCheckerDictionaryDownloadURL('https://example.com/dictionaries/') 调用此 api。请注意末尾的斜杠。词典的 URL 格式为 ${url}${filename}

¥If the files present in hunspell_dictionaries.zip are available at https://example.com/dictionaries/language-code.bdic then you should call this api with ses.setSpellCheckerDictionaryDownloadURL('https://example.com/dictionaries/'). Please note the trailing slash. The URL to the dictionaries is formed as ${url}${filename}.

注意:在 macOS 上,使用操作系统拼写检查器,因此我们不下载任何字典文件。此 API 在 macOS 上是无操作的。

¥Note: On macOS the OS spellchecker is used and therefore we do not download any dictionary files. This API is a no-op on macOS.

ses.listWordsInSpellCheckerDictionary()

返回 Promise<string[]> - 应用自定义词典中所有单词的数组。当从磁盘加载完整字典时解决。

¥Returns Promise<string[]> - An array of all words in app's custom dictionary. Resolves when the full dictionary is loaded from disk.

ses.addWordToSpellCheckerDictionary(word)

  • word 字符串 - 你要添加到词典中的单词

    ¥word string - The word you want to add to the dictionary

返回 boolean - 该单词是否成功写入自定义词典。此 API 不适用于非持久(内存中)会话。

¥Returns boolean - Whether the word was successfully written to the custom dictionary. This API will not work on non-persistent (in-memory) sessions.

注意:在 macOS 和 Windows 10 上,该单词也将写入操作系统自定义词典

¥Note: On macOS and Windows 10 this word will be written to the OS custom dictionary as well

ses.removeWordFromSpellCheckerDictionary(word)

  • word 字符串 - 你要从词典中删除的单词

    ¥word string - The word you want to remove from the dictionary

返回 boolean - 该单词是否已成功从自定义词典中删除。此 API 不适用于非持久(内存中)会话。

¥Returns boolean - Whether the word was successfully removed from the custom dictionary. This API will not work on non-persistent (in-memory) sessions.

注意:在 macOS 和 Windows 10 上,该单词也将从操作系统自定义词典中删除

¥Note: On macOS and Windows 10 this word will be removed from the OS custom dictionary as well

ses.loadExtension(path[, options])

  • path 字符串 - 包含解压的 Chrome 扩展程序的目录路径

    ¥path string - Path to a directory containing an unpacked Chrome extension

  • options 对象(可选)

    ¥options Object (optional)

    • allowFileAccess 布尔值 - 是否允许扩展通过 file:// 协议读取本地文件并将内容脚本注入 file:// 页面。这是必需的,例如 用于在 file:// URL 上加载 devtools 扩展。默认为 false。

      ¥allowFileAccess boolean - Whether to allow the extension to read local files over file:// protocol and inject content scripts into file:// pages. This is required e.g. for loading devtools extensions on file:// URLs. Defaults to false.

返回 Promise<Extension> - 加载扩展时解决。

¥Returns Promise<Extension> - resolves when the extension is loaded.

如果无法加载扩展,此方法将引发异常。如果安装扩展时出现警告(例如,如果扩展请求 Electron 不支持的 API),那么它们将被记录到控制台。

¥This method will raise an exception if the extension could not be loaded. If there are warnings when installing the extension (e.g. if the extension requests an API that Electron does not support) then they will be logged to the console.

请注意,Electron 不支持所有 Chrome 扩展 API。有关支持内容的更多详细信息,请参阅 支持的扩展 API

¥Note that Electron does not support the full range of Chrome extensions APIs. See Supported Extensions APIs for more details on what is supported.

请注意,在 Electron 的早期版本中,加载的扩展将被记住以供将来运行应用。这已不再是这种情况:如果你希望加载扩展,则必须在应用每次启动时调用 loadExtension

¥Note that in previous versions of Electron, extensions that were loaded would be remembered for future runs of the application. This is no longer the case: loadExtension must be called on every boot of your app if you want the extension to be loaded.

const { app, session } = require('electron')
const path = require('node:path')

app.whenReady().then(async () => {
await session.defaultSession.loadExtension(
path.join(__dirname, 'react-devtools'),
// allowFileAccess is required to load the devtools extension on file:// URLs.
{ allowFileAccess: true }
)
// Note that in order to use the React DevTools extension, you'll need to
// download and unzip a copy of the extension.
})

此 API 不支持加载打包的 (.crx) 扩展名。

¥This API does not support loading packed (.crx) extensions.

注意:在 app 模块的 ready 事件发出之前,无法调用此 API。

¥Note: This API cannot be called before the ready event of the app module is emitted.

注意:不支持将扩展加载到内存中(非持久)会话中,并且会引发错误。

¥Note: Loading extensions into in-memory (non-persistent) sessions is not supported and will throw an error.

ses.removeExtension(extensionId)

  • extensionId 字符串 - 要删除的扩展 ID

    ¥extensionId string - ID of extension to remove

卸载扩展。

¥Unloads an extension.

注意:在 app 模块的 ready 事件发出之前,无法调用此 API。

¥Note: This API cannot be called before the ready event of the app module is emitted.

ses.getExtension(extensionId)

  • extensionId 字符串 - 查询分机 ID

    ¥extensionId string - ID of extension to query

返回 Extension | null - 具有给定 ID 的已加载扩展。

¥Returns Extension | null - The loaded extension with the given ID.

注意:在 app 模块的 ready 事件发出之前,无法调用此 API。

¥Note: This API cannot be called before the ready event of the app module is emitted.

ses.getAllExtensions()

返回 Extension[] - 所有加载的扩展的列表。

¥Returns Extension[] - A list of all loaded extensions.

注意:在 app 模块的 ready 事件发出之前,无法调用此 API。

¥Note: This API cannot be called before the ready event of the app module is emitted.

ses.getStoragePath()

返回 string | null - 此会话的数据保留在磁盘上的绝对文件系统路径。对于内存会话,返回 null

¥Returns string | null - The absolute file system path where data for this session is persisted on disk. For in memory sessions this returns null.

ses.clearData([options])

  • options 对象(可选)

    ¥options Object (optional)

    • dataTypes 字符串[](可选) - 要清除的数据类型。默认情况下,这将清除所有类型的数据。

      ¥dataTypes String[] (optional) - The types of data to clear. By default, this will clear all types of data.

      • backgroundFetch - 后台获取

        ¥backgroundFetch - Background Fetch

      • cache - 缓存

        ¥cache - Cache

      • cookies - Cookies

      • downloads - 下载

        ¥downloads - Downloads

      • fileSystems - 文件系统

        ¥fileSystems - File Systems

      • indexedDB - 索引数据库

        ¥indexedDB - IndexedDB

      • localStorage - 本地存储

        ¥localStorage - Local Storage

      • serviceWorkers - 服务工作进程

        ¥serviceWorkers - Service Workers

      • webSQL - WebSQL

    • origins 字符串[](可选) - 仅清除这些来源的数据。不能与 excludeOrigins 一起使用。

      ¥origins String[] (optional) - Clear data for only these origins. Cannot be used with excludeOrigins.

    • excludeOrigins 字符串[](可选) - 清除除这些来源之外的所有来源的数据。不能与 origins 一起使用。

      ¥excludeOrigins String[] (optional) - Clear data for all origins except these ones. Cannot be used with origins.

    • avoidClosingConnections 布尔值(可选) - 跳过删除会关闭当前网络连接的 cookie。(默认值:false

      ¥avoidClosingConnections boolean (optional) - Skips deleting cookies that would close current network connections. (Default: false)

    • originMatchingMode 字符串(可选) - 将数据与源匹配的行为。

      ¥originMatchingMode String (optional) - The behavior for matching data to origins.

      • third-parties-included(默认) - 在第一方上下文中,存储与源匹配;在第三方上下文中,存储与顶层站点匹配。

        ¥third-parties-included (default) - Storage is matched on origin in first-party contexts and top-level-site in third-party contexts.

      • origin-in-all-contexts - 在所有上下文中,存储仅与源匹配。

        ¥origin-in-all-contexts - Storage is matched on origin only in all contexts.

返回 Promise<void> - 清除所有数据后解析。

¥Returns Promise<void> - resolves when all data has been cleared.

清除各种不同类型的数据。

¥Clears various different types of data.

此方法清除更多类型的数据,并且比 clearStorageData 方法更彻底。

¥This method clears more types of data and is more thourough than the clearStorageData method.

注意:Cookie 的存储范围比来源更广。当删除 cookies 并通过 origins(或 excludeOrigins)进行过滤时,cookie 将在 可注册域名 级别被删除。例如,清除源 https://really.specific.origin.example.com/ 的 cookie 将最终清除 example.com 的所有 cookie。清除来源 https://my.website.example.co.uk/ 的 cookie 最终将清除 example.co.uk 的所有 cookie。

¥Note: Cookies are stored at a broader scope than origins. When removing cookies and filtering by origins (or excludeOrigins), the cookies will be removed at the registrable domain level. For example, clearing cookies for the origin https://really.specific.origin.example.com/ will end up clearing all cookies for example.com. Clearing cookies for the origin https://my.website.example.co.uk/ will end up clearing all cookies for example.co.uk.

有关更多信息,请参阅 Chromium 的 BrowsingDataRemover 接口

¥For more information, refer to Chromium's BrowsingDataRemover interface.

实例属性

¥Instance Properties

以下属性在 Session 的实例上可用:

¥The following properties are available on instances of Session:

ses.availableSpellCheckerLanguages 只读

¥ses.availableSpellCheckerLanguages Readonly

一个 string[] 数组,包含所有已知的可用拼写检查语言。向 setSpellCheckerLanguages API 提供不在该数组中的语言代码将导致错误。

¥A string[] array which consists of all the known available spell checker languages. Providing a language code to the setSpellCheckerLanguages API that isn't in this array will result in an error.

ses.spellCheckerEnabled

boolean 指示是否启用内置拼写检查器。

¥A boolean indicating whether builtin spell checker is enabled.

ses.storagePath 只读

¥ses.storagePath Readonly

string | null 指示此会话的数据保留在磁盘上的绝对文件系统路径。对于内存会话,返回 null

¥A string | null indicating the absolute file system path where data for this session is persisted on disk. For in memory sessions this returns null.

ses.cookies 只读

¥ses.cookies Readonly

此会话的 Cookies 对象。

¥A Cookies object for this session.

ses.serviceWorkers 只读

¥ses.serviceWorkers Readonly

此会话的 ServiceWorkers 对象。

¥A ServiceWorkers object for this session.

ses.webRequest 只读

¥ses.webRequest Readonly

此会话的 WebRequest 对象。

¥A WebRequest object for this session.

ses.protocol 只读

¥ses.protocol Readonly

此会话的 Protocol 对象。

¥A Protocol object for this session.

const { app, session } = require('electron')
const path = require('node:path')

app.whenReady().then(() => {
const protocol = session.fromPartition('some-partition').protocol
if (!protocol.registerFileProtocol('atom', (request, callback) => {
const url = request.url.substr(7)
callback({ path: path.normalize(path.join(__dirname, url)) })
})) {
console.error('Failed to register protocol')
}
})

ses.netLog 只读

¥ses.netLog Readonly

此会话的 NetLog 对象。

¥A NetLog object for this session.

const { app, session } = require('electron')

app.whenReady().then(async () => {
const netLog = session.fromPartition('some-partition').netLog
netLog.startLogging('/path/to/net-log')
// After some network events
const path = await netLog.stopLogging()
console.log('Net-logs written to', path)
})