2015-09-11 04:30:37 +00:00
|
|
|
# session
|
|
|
|
|
2016-04-30 16:53:21 +00:00
|
|
|
> 브라우저 세션, 쿠키, 캐시, 프록시 설정 등을 관리합니다.
|
|
|
|
|
2015-11-20 22:51:52 +00:00
|
|
|
`session` 모듈은 새로운 `Session` 객체를 만드는데 사용할 수 있습니다.
|
|
|
|
|
2016-06-30 02:32:14 +00:00
|
|
|
또한 [`WebContents`](web-contents.md)의 `session` 속성이나 `session` 모듈을 통해 현재 존재하는 페이지의 `session`에 접근할 수 있습니다.
|
2015-09-11 04:30:37 +00:00
|
|
|
|
|
|
|
```javascript
|
2016-06-30 02:32:14 +00:00
|
|
|
const {session, BrowserWindow} = require('electron')
|
2015-09-11 04:30:37 +00:00
|
|
|
|
2016-06-30 02:32:14 +00:00
|
|
|
let win = new BrowserWindow({width: 800, height: 600})
|
|
|
|
win.loadURL('http://github.com')
|
2015-09-11 04:30:37 +00:00
|
|
|
|
2016-06-30 02:32:14 +00:00
|
|
|
let ses = win.webContents.session
|
2015-09-11 04:30:37 +00:00
|
|
|
```
|
|
|
|
|
2015-11-20 22:51:52 +00:00
|
|
|
## Methods
|
|
|
|
|
|
|
|
`session` 모듈은 다음과 같은 메서드를 가지고 있습니다:
|
|
|
|
|
2016-09-15 16:27:10 +00:00
|
|
|
### `session.fromPartition(partition[, options])`
|
2015-11-20 22:51:52 +00:00
|
|
|
|
|
|
|
* `partition` String
|
2016-09-15 16:27:10 +00:00
|
|
|
* `options` Object
|
|
|
|
* `cache` Boolean - 캐시를 활성화할지 여부.
|
2015-11-20 22:51:52 +00:00
|
|
|
|
2016-09-15 16:27:10 +00:00
|
|
|
`partition` 문자열로부터 `Session` 인스턴스를 만들어 반환합니다. 이미 `partition`에
|
|
|
|
해당하는 `Session`이 존재할 경우, 해당 세션이 반환됩니다. 그렇지않은 경우 `Session`
|
|
|
|
인스턴스가 `options`에 맞춰 새로 생성됩니다.
|
2015-11-20 22:51:52 +00:00
|
|
|
|
|
|
|
`partition`이 `persist:`로 시작하면 페이지는 지속성 세션을 사용하며 다른 모든 앱 내의
|
|
|
|
페이지에서 같은 `partition`을 사용할 수 있습니다. 만약 `persist:` 접두어로 시작하지
|
2016-06-12 17:51:35 +00:00
|
|
|
않으면 페이지는 인-메모리 세션을 사용합니다. `partition`을 지정하지 않으면 애플리케이션의
|
2015-11-20 22:51:52 +00:00
|
|
|
기본 세션이 반환됩니다.
|
|
|
|
|
2016-09-15 16:27:10 +00:00
|
|
|
`options`에 맞춰 `Session`을 생성하려면, `partition`에 해당하는 `Session`이 이미
|
|
|
|
이전에 사용되지 않고 있는지 확인해야 합니다. 이미 존재하는 `Session` 객체의
|
|
|
|
`options`를 변경하는 방법은 없습니다.
|
|
|
|
|
2015-11-20 22:51:52 +00:00
|
|
|
## Properties
|
|
|
|
|
|
|
|
`session` 모듈은 다음과 같은 속성을 가지고 있습니다:
|
|
|
|
|
2016-09-15 16:27:10 +00:00
|
|
|
### `session.defaultSession`
|
2015-09-11 04:30:37 +00:00
|
|
|
|
2016-06-12 17:51:35 +00:00
|
|
|
애플리케이션의 기본 세션 객체를 반환합니다.
|
2015-11-20 22:51:52 +00:00
|
|
|
|
|
|
|
## Class: Session
|
|
|
|
|
2016-09-15 16:27:10 +00:00
|
|
|
> 세션의 속성을 가져오거나 설정합니다.
|
|
|
|
|
2015-11-20 22:51:52 +00:00
|
|
|
`session` 모듈을 사용하여 `Session` 객체를 생성할 수 있습니다:
|
|
|
|
|
|
|
|
```javascript
|
|
|
|
const session = require('electron').session;
|
|
|
|
|
2016-05-10 07:27:14 +00:00
|
|
|
const ses = session.fromPartition('persist:name');
|
2015-11-20 22:51:52 +00:00
|
|
|
```
|
|
|
|
|
|
|
|
### Instance Events
|
|
|
|
|
|
|
|
`Session` 객체는 다음과 같은 이벤트를 가지고 있습니다:
|
|
|
|
|
|
|
|
#### Event: 'will-download'
|
2015-09-11 04:30:37 +00:00
|
|
|
|
|
|
|
* `event` Event
|
2015-09-26 01:36:26 +00:00
|
|
|
* `item` [DownloadItem](download-item.md)
|
2015-09-11 04:30:37 +00:00
|
|
|
* `webContents` [WebContents](web-contents.md)
|
|
|
|
|
|
|
|
Electron의 `webContents`에서 `item`을 다운로드할 때 발생하는 이벤트입니다.
|
|
|
|
|
2016-02-17 13:46:36 +00:00
|
|
|
`event.preventDefault()` 메서드를 호출하면 다운로드를 취소하고, 프로세스의 다음
|
|
|
|
틱부터 `item`을 사용할 수 없게 됩니다.
|
2015-09-11 04:30:37 +00:00
|
|
|
|
|
|
|
```javascript
|
2016-05-10 07:27:14 +00:00
|
|
|
session.defaultSession.on('will-download', (event, item, webContents) => {
|
2015-09-11 04:30:37 +00:00
|
|
|
event.preventDefault();
|
2016-05-10 07:27:14 +00:00
|
|
|
require('request')(item.getURL(), (data) => {
|
2015-09-11 04:30:37 +00:00
|
|
|
require('fs').writeFileSync('/somewhere', data);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
```
|
|
|
|
|
2015-11-20 22:51:52 +00:00
|
|
|
### Instance Methods
|
2015-09-11 04:30:37 +00:00
|
|
|
|
2016-06-30 02:32:14 +00:00
|
|
|
`Session` 객체는 다음과 같은 메서드를 가지고 있습니다:
|
2015-09-11 04:30:37 +00:00
|
|
|
|
2016-01-21 17:39:37 +00:00
|
|
|
#### `ses.getCacheSize(callback)`
|
|
|
|
|
|
|
|
* `callback` Function
|
|
|
|
* `size` Integer - 바이트로 표현된 캐시 크기
|
|
|
|
|
|
|
|
세션의 현재 캐시 크기를 반환합니다.
|
|
|
|
|
2015-11-20 22:51:52 +00:00
|
|
|
#### `ses.clearCache(callback)`
|
2015-09-11 04:30:37 +00:00
|
|
|
|
|
|
|
* `callback` Function - 작업이 완료되면 호출됩니다.
|
|
|
|
|
|
|
|
세션의 HTTP 캐시를 비웁니다.
|
|
|
|
|
2016-09-15 16:27:10 +00:00
|
|
|
#### `ses.clearStorageData([options, callback])`
|
2015-09-11 04:30:37 +00:00
|
|
|
|
|
|
|
* `options` Object (optional), proprties:
|
2015-11-19 19:46:05 +00:00
|
|
|
* `origin` String - `scheme://host:port`와 같은 `window.location.origin` 규칙을
|
|
|
|
따르는 origin 문자열.
|
2015-09-11 04:30:37 +00:00
|
|
|
* `storages` Array - 비우려는 스토리지의 종류, 다음과 같은 타입을 포함할 수 있습니다:
|
|
|
|
`appcache`, `cookies`, `filesystem`, `indexdb`, `local storage`,
|
|
|
|
`shadercache`, `websql`, `serviceworkers`
|
|
|
|
* `quotas` Array - 비우려는 할당의 종류, 다음과 같은 타입을 포함할 수 있습니다:
|
|
|
|
`temporary`, `persistent`, `syncable`.
|
2016-09-15 16:27:10 +00:00
|
|
|
* `callback` Function (optional) - 작업이 완료되면 호출됩니다.
|
2015-09-11 04:30:37 +00:00
|
|
|
|
|
|
|
웹 스토리지의 데이터를 비웁니다.
|
|
|
|
|
2016-01-11 04:11:10 +00:00
|
|
|
#### `ses.flushStorageData()`
|
|
|
|
|
|
|
|
디스크에 사용되지 않은 DOMStorage 데이터를 모두 덮어씌웁니다.
|
|
|
|
|
2015-11-20 22:51:52 +00:00
|
|
|
#### `ses.setProxy(config, callback)`
|
2015-09-11 04:30:37 +00:00
|
|
|
|
2016-01-11 04:11:10 +00:00
|
|
|
* `config` Object
|
|
|
|
* `pacScript` String - PAC 파일과 관련된 URL입니다.
|
|
|
|
* `proxyRules` String - 사용할 프록시의 규칙을 나타냅니다.
|
2016-09-15 16:27:10 +00:00
|
|
|
* `proxyBypassRules` String - 어떤 URL이 프록시 설정을 무시되어야 하는지를
|
|
|
|
지정하는 규칙입니다.
|
2015-09-11 04:30:37 +00:00
|
|
|
* `callback` Function - 작업이 완료되면 호출됩니다.
|
|
|
|
|
2016-01-11 04:11:10 +00:00
|
|
|
프록시 설정을 적용합니다.
|
2015-09-11 04:30:37 +00:00
|
|
|
|
2016-01-11 04:11:10 +00:00
|
|
|
`pacScript`와 `proxyRules`이 같이 제공되면 `proxyRules` 옵션은 무시되며 `pacScript`
|
|
|
|
컨픽만 적용됩니다.
|
|
|
|
|
|
|
|
`proxyRules`는 다음과 같은 규칙을 따릅니다:
|
2015-10-23 20:57:37 +00:00
|
|
|
|
2015-09-11 04:30:37 +00:00
|
|
|
```
|
2016-01-11 04:11:10 +00:00
|
|
|
proxyRules = schemeProxies[";"<schemeProxies>]
|
|
|
|
schemeProxies = [<urlScheme>"="]<proxyURIList>
|
|
|
|
urlScheme = "http" | "https" | "ftp" | "socks"
|
|
|
|
proxyURIList = <proxyURL>[","<proxyURIList>]
|
|
|
|
proxyURL = [<proxyScheme>"://"]<proxyHost>[":"<proxyPort>]
|
2015-09-11 04:30:37 +00:00
|
|
|
```
|
|
|
|
|
2016-01-11 04:11:10 +00:00
|
|
|
예시:
|
2016-01-30 22:05:39 +00:00
|
|
|
|
2016-01-11 04:11:10 +00:00
|
|
|
* `http=foopy:80;ftp=foopy2` - http:// URL에 `foopy:80` HTTP 프록시를 사용합니다.
|
|
|
|
`foopy2:80` 는 ftp:// URL에 사용됩니다.
|
|
|
|
* `foopy:80` - 모든 URL에 `foopy:80` 프록시를 사용합니다.
|
|
|
|
* `foopy:80,bar,direct://` - 모든 URL에 `foopy:80` HTTP 프록시를 사용합니다.
|
|
|
|
문제가 발생하여 `foopy:80`를 사용할 수 없는 경우 `bar`를 대신 사용하여 장애를
|
|
|
|
복구하며 그 다음 문제가 생긴 경우 프록시를 사용하지 않습니다.
|
|
|
|
* `socks4://foopy` - 모든 URL에 `foopy:1000` SOCKS v4 프록시를 사용합니다.
|
|
|
|
* `http=foopy,socks5://bar.com` - http:// URL에 `foopy` HTTP 프록시를 사용합니다.
|
|
|
|
문제가 발생하여 `foopy`를 사용할 수 없는 경우 SOCKS5 `bar.com` 프록시를 대신
|
|
|
|
사용합니다.
|
|
|
|
* `http=foopy,direct://` - http:// URL에 `foopy` HTTP 프록시를 사용합니다. 그리고
|
|
|
|
문제가 발생하여 `foopy`를 사용할 수 없는 경우 프록시를 사용하지 않습니다.
|
|
|
|
* `http=foopy;socks=foopy2` - http:// URL에 `foopy` HTTP 프록시를 사용합니다.
|
|
|
|
그리고 `socks4://foopy2` 프록시를 다른 모든 URL에 사용합니다.
|
|
|
|
|
2016-09-15 16:27:10 +00:00
|
|
|
`proxyBypassRules`는 밑에서 묘사된 규칙의 콤마로 구분된 목록입니다:
|
|
|
|
|
|
|
|
* `[ URL_SCHEME "://" ] HOSTNAME_PATTERN [ ":" <port> ]`
|
|
|
|
|
|
|
|
Match all hostnames that match the pattern HOSTNAME_PATTERN.
|
|
|
|
|
|
|
|
예시:
|
|
|
|
"foobar.com", "*foobar.com", "*.foobar.com", "*foobar.com:99",
|
|
|
|
"https://x.*.y.com:99"
|
|
|
|
|
|
|
|
* `"." HOSTNAME_SUFFIX_PATTERN [ ":" PORT ]`
|
|
|
|
|
|
|
|
Match a particular domain suffix.
|
|
|
|
|
|
|
|
예시:
|
|
|
|
".google.com", ".com", "http://.google.com"
|
|
|
|
|
|
|
|
* `[ SCHEME "://" ] IP_LITERAL [ ":" PORT ]`
|
|
|
|
|
|
|
|
Match URLs which are IP address literals.
|
|
|
|
|
|
|
|
예시:
|
|
|
|
"127.0.1", "[0:0::1]", "[::1]", "http://[::1]:99"
|
|
|
|
|
|
|
|
* `IP_LITERAL "/" PREFIX_LENGHT_IN_BITS`
|
|
|
|
|
|
|
|
Match any URL that is to an IP literal that falls between the
|
|
|
|
given range. IP range is specified using CIDR notation.
|
|
|
|
|
|
|
|
예시:
|
|
|
|
"192.168.1.1/16", "fefe:13::abc/33".
|
|
|
|
|
|
|
|
* `<local>`
|
|
|
|
|
|
|
|
Match local addresses. The meaning of `<local>` is whether the
|
|
|
|
host matches one of: "127.0.0.1", "::1", "localhost".
|
|
|
|
|
2016-06-29 13:34:51 +00:00
|
|
|
#### `ses.resolveProxy(url, callback)`
|
2015-11-20 22:51:52 +00:00
|
|
|
|
|
|
|
* `url` URL
|
|
|
|
* `callback` Function
|
|
|
|
|
|
|
|
`url`의 프록시 정보를 해석합니다. `callback`은 요청이 수행되었을 때
|
|
|
|
`callback(proxy)` 형태로 호출됩니다.
|
|
|
|
|
|
|
|
#### `ses.setDownloadPath(path)`
|
2015-09-11 04:30:37 +00:00
|
|
|
|
|
|
|
* `path` String - 다운로드 위치
|
|
|
|
|
2016-06-12 17:51:35 +00:00
|
|
|
다운로드 저장 위치를 지정합니다. 기본 다운로드 위치는 각 애플리케이션 데이터 디렉터리의
|
2015-11-19 19:46:05 +00:00
|
|
|
`Downloads` 폴더입니다.
|
2015-09-28 20:35:33 +00:00
|
|
|
|
2015-11-20 22:51:52 +00:00
|
|
|
#### `ses.enableNetworkEmulation(options)`
|
2015-09-28 20:35:33 +00:00
|
|
|
|
|
|
|
* `options` Object
|
2016-09-15 16:27:10 +00:00
|
|
|
* `offline` Boolean (optional) - 네트워크 연결 끊김을 에뮬레이트할지 여부입니다.
|
|
|
|
기본값은 false입니다.
|
|
|
|
* `latency` Double (optional) - 밀리세컨드당 RTT입니다. 기본값은 0이며 이는
|
|
|
|
레이턴시 스로틀링을 비활성화합니다.
|
|
|
|
* `downloadThroughput` Double (optional) - Bps 단위의 다운로드 속도입니다.
|
|
|
|
기본값은 0이며 이는 다운로드 스로틀링을 비활성화합니다.
|
|
|
|
* `uploadThroughput` Double (optional) - Bps 단위의 업로드 속도입니다. 기본값은
|
|
|
|
0이며 이는 업로드 스로틀링을 비활성화합니다.
|
2015-09-28 20:35:33 +00:00
|
|
|
|
|
|
|
제공된 설정으로 `session`의 네트워크를 에뮬레이트합니다.
|
|
|
|
|
|
|
|
```javascript
|
|
|
|
// 50kbps의 처리량과 함께 500ms의 레이턴시로 GPRS 연결을 에뮬레이트합니다.
|
|
|
|
window.webContents.session.enableNetworkEmulation({
|
|
|
|
latency: 500,
|
|
|
|
downloadThroughput: 6400,
|
|
|
|
uploadThroughput: 6400
|
|
|
|
});
|
|
|
|
|
|
|
|
// 네트워크가 끊긴 상태를 에뮬레이트합니다.
|
|
|
|
window.webContents.session.enableNetworkEmulation({offline: true});
|
|
|
|
```
|
|
|
|
|
2015-11-20 22:51:52 +00:00
|
|
|
#### `ses.disableNetworkEmulation()`
|
2015-09-28 20:35:33 +00:00
|
|
|
|
|
|
|
활성화된 `session`의 에뮬레이션을 비활성화합니다. 기본 네트워크 설정으로 돌아갑니다.
|
2015-11-20 22:51:52 +00:00
|
|
|
|
|
|
|
#### `ses.setCertificateVerifyProc(proc)`
|
|
|
|
|
|
|
|
* `proc` Function
|
|
|
|
|
|
|
|
`session`에 인증서의 유효성을 확인하는 프로세스(proc)를 등록합니다. `proc`은 서버
|
|
|
|
인증서 유효성 검증 요청이 들어왔을 때 언제나 `proc(hostname, certificate, callback)`
|
|
|
|
형식으로 호출됩니다. `callback(true)`을 호출하면 인증을 승인하고 `callback(false)`를
|
|
|
|
호출하면 인증을 거부합니다.
|
|
|
|
|
|
|
|
`setCertificateVerifyProc(null)`을 호출하면 기본 검증 프로세스로 되돌립니다.
|
|
|
|
|
|
|
|
```javascript
|
2016-05-10 07:27:14 +00:00
|
|
|
myWindow.webContents.session.setCertificateVerifyProc((hostname, cert, callback) => {
|
|
|
|
if (hostname === 'github.com')
|
2015-11-20 22:51:52 +00:00
|
|
|
callback(true);
|
|
|
|
else
|
|
|
|
callback(false);
|
|
|
|
});
|
|
|
|
```
|
2016-02-01 18:58:51 +00:00
|
|
|
#### `ses.setPermissionRequestHandler(handler)`
|
|
|
|
|
|
|
|
* `handler` Function
|
|
|
|
* `webContents` Object - [WebContents](web-contents.md) 권한을 요청.
|
2016-04-22 14:23:39 +00:00
|
|
|
* `permission` String - 'media', 'geolocation', 'notifications',
|
2016-04-21 03:33:56 +00:00
|
|
|
'midiSysex', 'pointerLock', 'fullscreen', 'openExternal'의 나열.
|
2016-04-22 14:23:39 +00:00
|
|
|
* `callback` Function - 권한 허용 및 거부.
|
2016-02-01 18:58:51 +00:00
|
|
|
|
|
|
|
`session`의 권한 요청에 응답을 하는데 사용하는 핸들러를 설정합니다.
|
2016-02-07 07:02:48 +00:00
|
|
|
`callback(true)`를 호출하면 권한 제공을 허용하고 `callback(false)`를
|
2016-02-01 18:58:51 +00:00
|
|
|
호출하면 권한 제공을 거부합니다.
|
|
|
|
|
|
|
|
```javascript
|
2016-05-10 07:27:14 +00:00
|
|
|
session.fromPartition(partition).setPermissionRequestHandler((webContents, permission, callback) => {
|
2016-02-01 18:58:51 +00:00
|
|
|
if (webContents.getURL() === host) {
|
2016-05-10 18:14:06 +00:00
|
|
|
if (permission === 'notifications') {
|
2016-02-07 07:02:48 +00:00
|
|
|
callback(false); // 거부됨.
|
2016-02-01 18:58:51 +00:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-02-07 07:02:48 +00:00
|
|
|
callback(true);
|
2016-02-01 18:58:51 +00:00
|
|
|
});
|
|
|
|
```
|
2015-12-12 12:41:17 +00:00
|
|
|
|
2016-02-17 13:46:36 +00:00
|
|
|
#### `ses.clearHostResolverCache([callback])`
|
|
|
|
|
|
|
|
* `callback` Function (optional) - 작업이 완료되면 호출됩니다.
|
|
|
|
|
|
|
|
호스트 리소버(resolver) 캐시를 지웁니다.
|
|
|
|
|
2016-06-03 08:47:21 +00:00
|
|
|
#### `ses.allowNTLMCredentialsForDomains(domains)`
|
|
|
|
|
|
|
|
* `domains` String - 통합 인증을 사용하도록 설정할 쉼표로 구분된 서버의 리스트.
|
|
|
|
|
|
|
|
동적으로 HTTP NTML 또는 Negotiate 인증을 위해 언제나 자격 증명을 보낼지 여부를
|
|
|
|
설정합니다.
|
|
|
|
|
|
|
|
```javascript
|
|
|
|
// 통합 인증을 위해 `example.com`, `foobar.com`, `baz`로 끝나는
|
|
|
|
// 모든 url을 지정합니다.
|
|
|
|
session.defaultSession.allowNTLMCredentialsForDomains('*example.com, *foobar.com, *baz')
|
|
|
|
|
|
|
|
// 통합 인증을 위해 모든 url을 지정합니다.
|
|
|
|
session.defaultSession.allowNTLMCredentialsForDomains('*')
|
|
|
|
```
|
|
|
|
|
2016-06-29 13:34:51 +00:00
|
|
|
#### `ses.setUserAgent(userAgent[, acceptLanguages])`
|
|
|
|
|
|
|
|
* `userAgent` String
|
|
|
|
* `acceptLanguages` String (optional)
|
|
|
|
|
2016-06-29 17:50:41 +00:00
|
|
|
현재 세션에 대해 `userAgent`와 `acceptLanguages`를 덮어씁니다.
|
2016-06-29 13:34:51 +00:00
|
|
|
|
2016-06-29 17:50:41 +00:00
|
|
|
`acceptLanguages`는 반드시 쉼표로 구분된 순서에 맞춘 언어 코드의 리스트여야 하며
|
|
|
|
예를 들면 `"en-US,fr,de,ko,zh-CN,ja"` 입니다.
|
2016-06-29 13:34:51 +00:00
|
|
|
|
2016-06-29 17:50:41 +00:00
|
|
|
이는 현재 존재하는 `WebContents`에 적용되지 않으며 각 `WebContents`는
|
|
|
|
`webContents.setUserAgent`를 사용하여 세션 전체의 유저 에이전트를 덮어쓸 수 있습니다.
|
2016-06-29 13:34:51 +00:00
|
|
|
|
|
|
|
#### `ses.getUserAgent()`
|
|
|
|
|
2016-06-30 02:32:14 +00:00
|
|
|
현재 세션의 유저 에이전트를 표현하는 `String`을 반환합니다.
|
|
|
|
|
|
|
|
### Instance Properties
|
|
|
|
|
|
|
|
다음은 `Session` 인스턴스에서 사용할 수 있는 속성들입니다:
|
|
|
|
|
|
|
|
#### `ses.cookies`
|
|
|
|
|
|
|
|
현재 세션의 `Cookies` 클래스 인스턴스를 반환합니다.
|
2016-06-29 13:34:51 +00:00
|
|
|
|
2015-12-12 12:41:17 +00:00
|
|
|
#### `ses.webRequest`
|
|
|
|
|
2016-06-30 02:32:14 +00:00
|
|
|
현재 세션의 `WebRequest` 클래스 인스턴스를 반환합니다.
|
|
|
|
|
|
|
|
#### `ses.protocol`
|
|
|
|
|
|
|
|
현재 세션의 [protocol](protocol.md) 모듈 인스턴스를 반환합니다.
|
|
|
|
|
|
|
|
```javascript
|
|
|
|
const {app, session} = require('electron')
|
|
|
|
const path = require('path')
|
|
|
|
|
|
|
|
app.on('ready', function () {
|
|
|
|
const protocol = session.fromPartition(partitionName).protocol
|
|
|
|
protocol.registerFileProtocol('atom', function (request, callback) {
|
|
|
|
var url = request.url.substr(7)
|
|
|
|
callback({path: path.normalize(__dirname + '/' + url)})
|
|
|
|
}, function (error) {
|
|
|
|
if (error)
|
|
|
|
console.error('Failed to register protocol')
|
|
|
|
})
|
|
|
|
})
|
|
|
|
```
|
|
|
|
|
|
|
|
## Class: Cookies
|
|
|
|
|
2016-09-15 16:27:10 +00:00
|
|
|
> 세션의 쿠키를 변경하거나 요청합니다.
|
|
|
|
|
|
|
|
`Cookies` 클래스의 인스턴스는 `Session`의 `cookies` 속성을 통해 접근합니다.
|
2016-06-30 02:32:14 +00:00
|
|
|
|
|
|
|
예를 들어:
|
2015-12-12 12:41:17 +00:00
|
|
|
|
2016-06-30 02:32:14 +00:00
|
|
|
```javascript
|
|
|
|
// 모든 쿠키를 요청합니다.
|
|
|
|
session.defaultSession.cookies.get({}, (error, cookies) => {
|
|
|
|
console.log(cookies);
|
|
|
|
});
|
|
|
|
|
|
|
|
// url에 관련된 쿠키를 모두 가져옵니다.
|
|
|
|
session.defaultSession.cookies.get({url: 'http://www.github.com'}, (error, cookies) => {
|
|
|
|
console.log(cookies);
|
|
|
|
});
|
|
|
|
|
|
|
|
// 지정한 쿠키 데이터를 설정합니다.
|
|
|
|
// 동일한 쿠키가 있으면 해당 쿠키를 덮어씁니다.
|
|
|
|
const cookie = {url: 'http://www.github.com', name: 'dummy_name', value: 'dummy'};
|
|
|
|
session.defaultSession.cookies.set(cookie, (error) => {
|
|
|
|
if (error)
|
|
|
|
console.error(error);
|
|
|
|
});
|
|
|
|
```
|
|
|
|
|
|
|
|
### Instance Methods
|
|
|
|
|
|
|
|
다음은 `Cookies` 객체에서 사용할 수 있는 메서드들입니다:
|
|
|
|
|
|
|
|
#### `ses.cookies.get(filter, callback)`
|
|
|
|
|
|
|
|
* `filter` Object
|
|
|
|
* `url` String (optional) - `url`에 해당하는 쿠키를 취득합니다. 이 속성을
|
|
|
|
생략하면 모든 url에서 찾습니다.
|
|
|
|
* `name` String (optional) - 쿠키의 이름입니다.
|
|
|
|
* `domain` String (optional) - 도메인 또는 서브 도메인에 일치하는 쿠키를
|
|
|
|
취득합니다.
|
|
|
|
* `path` String (optional) - `path`에 일치하는 쿠키를 취득합니다.
|
|
|
|
* `secure` Boolean (optional) - 보안 속성에 따라 쿠키를 필터링합니다.
|
|
|
|
* `session` Boolean (optional) - 세션 또는 지속성 쿠키를 필터링합니다.
|
|
|
|
* `callback` Function
|
|
|
|
|
|
|
|
`details` 객체에서 묘사한 모든 쿠키를 요청합니다. 모든 작업이 끝나면 `callback`이
|
|
|
|
`callback(error, cookies)` 형태로 호출됩니다.
|
|
|
|
|
|
|
|
`cookies`는 `cookie` 객체의 배열입니다.
|
|
|
|
|
|
|
|
* `cookie` Object
|
|
|
|
* `name` String - 쿠키의 이름.
|
|
|
|
* `value` String - 쿠키의 값.
|
|
|
|
* `domain` String - 쿠키의 도메인.
|
|
|
|
* `hostOnly` String - 쿠키가 호스트 전용인가에 대한 여부.
|
|
|
|
* `path` String - 쿠키의 경로.
|
|
|
|
* `secure` Boolean - 쿠키가 안전한 것으로 표시되는지에 대한 여부.
|
|
|
|
* `httpOnly` Boolean - 쿠키가 HTTP로만 표시되는지에 대한 여부.
|
|
|
|
* `session` Boolean - 쿠키가 세션 쿠키 또는 만료일이 있는 영구 쿠키인지에 대한
|
|
|
|
여부.
|
|
|
|
* `expirationDate` Double - (Option) UNIX 시간으로 표시되는 쿠키의 만료일에
|
|
|
|
대한 초 단위 시간. 세션 쿠키는 지원되지 않음.
|
|
|
|
|
|
|
|
#### `ses.cookies.set(details, callback)`
|
|
|
|
|
|
|
|
* `details` Object
|
|
|
|
* `url` String - 쿠키에 대한 `url` 링크.
|
|
|
|
* `name` String - 쿠키의 이름입니다. 기본적으로 비워두면 생략됩니다.
|
|
|
|
* `value` String - 쿠키의 값입니다. 기본적으로 비워두면 생략됩니다.
|
|
|
|
* `domain` String - 쿠키의 도메인입니다. 기본적으로 비워두면 생략됩니다.
|
|
|
|
* `path` String - 쿠키의 경로입니다. 기본적으로 비워두면 생략됩니다.
|
|
|
|
* `secure` Boolean - 쿠키가 안전한 것으로 표시되는지에 대한 여부입니다. 기본값은
|
|
|
|
false입니다.
|
|
|
|
* `httpOnly` Boolean - 쿠키가 Http 전용으로 표시되는지에 대한 여부입니다. 기본값은
|
|
|
|
false입니다.
|
|
|
|
* `expirationDate` Double (optional) - UNIX 시간으로 표시되는 쿠키의 만료일에
|
|
|
|
대한 초 단위 시간입니다. 생략되면 쿠키가 세션 쿠기가 되며 세션 사이에 유지되지
|
|
|
|
않게 됩니다.
|
|
|
|
* `callback` Function
|
|
|
|
|
|
|
|
`details` 객체에 따라 쿠키를 설정합니다. 작업이 완료되면 `callback`이
|
|
|
|
`callback(error)` 형태로 호출됩니다.
|
|
|
|
|
|
|
|
#### `ses.cookies.remove(url, name, callback)`
|
|
|
|
|
|
|
|
* `url` String - 쿠키와 관련된 URL입니다.
|
|
|
|
* `name` String - 지울 쿠키의 이름입니다.
|
|
|
|
* `callback` Function
|
|
|
|
|
|
|
|
`url`과 `name`에 일치하는 쿠키를 삭제합니다. 작업이 완료되면 `callback`이
|
|
|
|
`callback()` 형식으로 호출됩니다.
|
|
|
|
|
|
|
|
## Class: WebRequest
|
|
|
|
|
2016-09-15 16:27:10 +00:00
|
|
|
> 생명주기 동안의 다양한 단계를 가지는 요청의 콘텐츠를 가로채고 변경합니다.
|
|
|
|
|
|
|
|
`WebRequest` 클래스의 인스턴스는 `Session`의 `webRequest` 속성을 통해 접근할 수
|
|
|
|
있습니다.
|
2016-06-30 02:32:14 +00:00
|
|
|
|
|
|
|
`WebRequest`의 메서드는 선택적인 `filter`와 `listener` 속성을 허용하며 `listener`는
|
|
|
|
API의 이벤트가 발생했을 때 `listener(details)` 형식으로 호출되고, `details`는 요청에
|
|
|
|
관한 내용을 표현하는 객체입니다. `listener`에 `null`을 전달하면 이벤트의 구독을
|
|
|
|
해제합니다.
|
2015-12-12 12:41:17 +00:00
|
|
|
|
|
|
|
`filter`는 `urls` 속성을 가진 객체입니다. 이 속성은 URL 규칙의 배열이며 URL 규칙에
|
|
|
|
일치하지 않는 요청을 모두 거르는데 사용됩니다. 만약 `filter`가 생략되면 모든 요청을
|
|
|
|
여과 없이 통과시킵니다.
|
|
|
|
|
|
|
|
어떤 `listener`의 이벤트들은 `callback`을 같이 전달하는데, 이벤트 처리시
|
|
|
|
`listener`의 작업을 완료한 후 `response` 객체를 포함하여 호출해야 합니다.
|
|
|
|
|
2016-06-30 02:32:14 +00:00
|
|
|
다음은 요청에 `User-Agent` 헤더를 추가하는 예시입니다:
|
|
|
|
|
2015-12-12 12:41:17 +00:00
|
|
|
```javascript
|
|
|
|
// 다음 url에 대한 User Agent를 조작합니다.
|
2016-05-10 07:27:14 +00:00
|
|
|
const filter = {
|
2016-05-10 18:14:06 +00:00
|
|
|
urls: ['https://*.github.com/*', '*://electron.github.io']
|
2016-06-30 02:32:14 +00:00
|
|
|
}
|
2015-12-12 12:41:17 +00:00
|
|
|
|
2016-05-10 07:27:14 +00:00
|
|
|
session.defaultSession.webRequest.onBeforeSendHeaders(filter, (details, callback) => {
|
2016-06-30 02:32:14 +00:00
|
|
|
details.requestHeaders['User-Agent'] = "MyAgent"
|
|
|
|
callback({cancel: false, requestHeaders: details.requestHeaders})
|
|
|
|
})
|
2015-12-12 12:41:17 +00:00
|
|
|
```
|
|
|
|
|
2016-06-30 02:32:14 +00:00
|
|
|
### Instance Methods
|
|
|
|
|
|
|
|
다음은 `WebRequest` 객체에서 사용할 수 있는 메서드들입니다:
|
|
|
|
|
|
|
|
#### `webRequest.onBeforeRequest([filter, ]listener)`
|
2015-12-12 12:41:17 +00:00
|
|
|
|
|
|
|
* `filter` Object
|
|
|
|
* `listener` Function
|
|
|
|
|
|
|
|
요청이 발생하면 `listener`가 `listener(details, callback)` 형태로 호출됩니다.
|
|
|
|
|
|
|
|
* `details` Object
|
|
|
|
* `id` Integer
|
|
|
|
* `url` String
|
|
|
|
* `method` String
|
|
|
|
* `resourceType` String
|
|
|
|
* `timestamp` Double
|
2016-01-29 00:09:26 +00:00
|
|
|
* `uploadData` Array (optional)
|
|
|
|
* `callback` Function
|
|
|
|
|
|
|
|
`uploadData`는 `data` 객체의 배열입니다:
|
|
|
|
|
|
|
|
* `data` Object
|
2016-04-30 16:11:21 +00:00
|
|
|
* `bytes` Buffer - 전송될 콘텐츠.
|
2016-01-29 00:09:26 +00:00
|
|
|
* `file` String - 업로드될 파일의 경로.
|
2015-12-12 12:41:17 +00:00
|
|
|
|
|
|
|
`callback`은 `response` 객체와 함께 호출되어야 합니다:
|
|
|
|
|
|
|
|
* `response` Object
|
2015-12-18 17:02:30 +00:00
|
|
|
* `cancel` Boolean (optional)
|
|
|
|
* `redirectURL` String (optional) - 원래 요청은 전송과 완료가 방지되지만 이
|
2015-12-12 12:41:17 +00:00
|
|
|
속성을 지정하면 해당 URL로 리다이렉트됩니다.
|
|
|
|
|
2016-06-30 02:32:14 +00:00
|
|
|
#### `webRequest.onBeforeSendHeaders([filter, ]listener)`
|
2015-12-12 12:41:17 +00:00
|
|
|
|
|
|
|
* `filter` Object
|
|
|
|
* `listener` Function
|
|
|
|
|
|
|
|
HTTP 요청을 보내기 전 요청 헤더를 사용할 수 있을 때 `listener`가
|
|
|
|
`listener(details, callback)` 형태로 호출됩니다. 이 이벤트는 서버와의 TCP 연결이
|
|
|
|
완료된 후에 발생할 수도 있지만 http 데이터가 전송되기 전에 발생합니다.
|
|
|
|
|
|
|
|
* `details` Object
|
|
|
|
* `id` Integer
|
|
|
|
* `url` String
|
|
|
|
* `method` String
|
|
|
|
* `resourceType` String
|
|
|
|
* `timestamp` Double
|
|
|
|
* `requestHeaders` Object
|
2016-01-29 00:09:26 +00:00
|
|
|
* `callback` Function
|
2015-12-12 12:41:17 +00:00
|
|
|
|
|
|
|
`callback`은 `response` 객체와 함께 호출되어야 합니다:
|
|
|
|
|
|
|
|
* `response` Object
|
2015-12-18 17:02:30 +00:00
|
|
|
* `cancel` Boolean (optional)
|
|
|
|
* `requestHeaders` Object (optional) - 이 속성이 제공되면, 요청은 이 헤더로
|
2015-12-12 12:41:17 +00:00
|
|
|
만들어 집니다.
|
|
|
|
|
2016-06-30 02:32:14 +00:00
|
|
|
#### `webRequest.onSendHeaders([filter, ]listener)`
|
2015-12-12 12:41:17 +00:00
|
|
|
|
|
|
|
* `filter` Object
|
|
|
|
* `listener` Function
|
|
|
|
|
|
|
|
서버에 요청이 전송되기 바로 전에 `listener`가 `listener(details)` 형태로 호출됩니다.
|
|
|
|
이전 `onBeforeSendHeaders`의 response와 다른점은 리스너가 호출되는 시간으로 볼 수
|
|
|
|
있습니다.
|
|
|
|
|
|
|
|
* `details` Object
|
|
|
|
* `id` Integer
|
|
|
|
* `url` String
|
|
|
|
* `method` String
|
|
|
|
* `resourceType` String
|
|
|
|
* `timestamp` Double
|
|
|
|
* `requestHeaders` Object
|
|
|
|
|
2016-06-30 02:32:14 +00:00
|
|
|
#### `webRequest.onHeadersReceived([filter, ]listener)`
|
2015-12-12 12:41:17 +00:00
|
|
|
|
|
|
|
* `filter` Object
|
|
|
|
* `listener` Function
|
|
|
|
|
|
|
|
요청의 HTTP 응답 헤더를 받았을 때 `listener`가 `listener(details, callback)` 형태로
|
|
|
|
호출됩니다.
|
|
|
|
|
|
|
|
* `details` Object
|
|
|
|
* `id` String
|
|
|
|
* `url` String
|
|
|
|
* `method` String
|
|
|
|
* `resourceType` String
|
|
|
|
* `timestamp` Double
|
|
|
|
* `statusLine` String
|
|
|
|
* `statusCode` Integer
|
|
|
|
* `responseHeaders` Object
|
2016-01-29 00:09:26 +00:00
|
|
|
* `callback` Function
|
2015-12-12 12:41:17 +00:00
|
|
|
|
|
|
|
`callback`은 `response` 객체와 함께 호출되어야 합니다:
|
|
|
|
|
|
|
|
* `response` Object
|
|
|
|
* `cancel` Boolean
|
2015-12-18 17:02:30 +00:00
|
|
|
* `responseHeaders` Object (optional) - 이 속성이 제공되면 서버는 이 헤더와
|
2015-12-12 12:41:17 +00:00
|
|
|
함께 응답합니다.
|
2016-04-14 13:55:09 +00:00
|
|
|
* `statusLine` String (optional) - `responseHeaders`를 덮어쓸 땐, 헤더의 상태를
|
|
|
|
변경하기 위해 반드시 지정되어야 합니다. 그렇지 않은 경우, 기존의 응답 헤더의 상태가
|
|
|
|
사용됩니다.
|
2015-12-12 12:41:17 +00:00
|
|
|
|
2016-06-30 02:32:14 +00:00
|
|
|
#### `webRequest.onResponseStarted([filter, ]listener)`
|
2015-12-12 12:41:17 +00:00
|
|
|
|
|
|
|
* `filter` Object
|
|
|
|
* `listener` Function
|
|
|
|
|
|
|
|
요청 본문의 첫 번째 바이트를 받았을 때 `listener`가 `listener(details)` 형태로
|
|
|
|
호출됩니다. 이는 HTTP 요청에서 상태 줄과 요청 헤더가 사용 가능한 상태를 의미합니다.
|
|
|
|
|
|
|
|
* `details` Object
|
|
|
|
* `id` Integer
|
|
|
|
* `url` String
|
|
|
|
* `method` String
|
|
|
|
* `resourceType` String
|
|
|
|
* `timestamp` Double
|
|
|
|
* `responseHeaders` Object
|
|
|
|
* `fromCache` Boolean - 응답을 디스크 캐시에서 가져올지에 대한 여부.
|
|
|
|
* `statusCode` Integer
|
|
|
|
* `statusLine` String
|
|
|
|
|
2016-06-30 02:32:14 +00:00
|
|
|
#### `webRequest.onBeforeRedirect([filter, ]listener)`
|
2015-12-12 12:41:17 +00:00
|
|
|
|
|
|
|
* `filter` Object
|
|
|
|
* `listener` Function
|
|
|
|
|
|
|
|
서버에서 시작된 리다이렉트가 발생했을 때 `listener`가 `listener(details)` 형태로
|
|
|
|
호출됩니다.
|
|
|
|
|
|
|
|
* `details` Object
|
|
|
|
* `id` String
|
|
|
|
* `url` String
|
|
|
|
* `method` String
|
|
|
|
* `resourceType` String
|
|
|
|
* `timestamp` Double
|
|
|
|
* `redirectURL` String
|
|
|
|
* `statusCode` Integer
|
2015-12-18 17:02:30 +00:00
|
|
|
* `ip` String (optional) - 요청이 실질적으로 전송될 서버 아이피 주소.
|
2015-12-12 12:41:17 +00:00
|
|
|
* `fromCache` Boolean
|
|
|
|
* `responseHeaders` Object
|
|
|
|
|
2016-06-30 02:32:14 +00:00
|
|
|
#### `webRequest.onCompleted([filter, ]listener)`
|
2015-12-12 12:41:17 +00:00
|
|
|
|
|
|
|
* `filter` Object
|
|
|
|
* `listener` Function
|
|
|
|
|
|
|
|
요청이 완료되면 `listener`가 `listener(details)` 형태로 호출됩니다.
|
|
|
|
|
|
|
|
* `details` Object
|
|
|
|
* `id` Integer
|
|
|
|
* `url` String
|
|
|
|
* `method` String
|
|
|
|
* `resourceType` String
|
|
|
|
* `timestamp` Double
|
|
|
|
* `responseHeaders` Object
|
|
|
|
* `fromCache` Boolean
|
|
|
|
* `statusCode` Integer
|
|
|
|
* `statusLine` String
|
|
|
|
|
2016-06-30 02:32:14 +00:00
|
|
|
#### `webRequest.onErrorOccurred([filter, ]listener)`
|
2015-12-12 12:41:17 +00:00
|
|
|
|
|
|
|
* `filter` Object
|
|
|
|
* `listener` Function
|
|
|
|
|
|
|
|
에러가 발생하면 `listener`가 `listener(details)` 형태로 호출됩니다.
|
|
|
|
|
|
|
|
* `details` Object
|
|
|
|
* `id` Integer
|
|
|
|
* `url` String
|
|
|
|
* `method` String
|
|
|
|
* `resourceType` String
|
|
|
|
* `timestamp` Double
|
|
|
|
* `fromCache` Boolean
|
|
|
|
* `error` String - 에러 설명.
|