Opis
Aby zarządzać ustawieniami serwera proxy w Chrome, użyj interfejsu chrome.proxy API. Ten interfejs API korzysta z prototypu ChromeSetting interfejsu API typu do pobierania i ustawiania konfiguracji serwera proxy.
Uprawnienia
proxyPlik manifestu
Aby korzystać z interfejsu API ustawień serwera proxy, musisz zadeklarować uprawnienie „proxy” w pliku manifestu rozszerzenia. Na przykład:
{
"name": "My extension",
...
"permissions": [
"proxy"
],
...
}
Obiekty i właściwości
Ustawienia serwera proxy są zdefiniowane w obiekcie proxy.ProxyConfig. W zależności od ustawień serwera proxy w Chrome,
ustawienia mogą zawierać proxy.ProxyRules lub proxy.PacScript.
Tryby serwera proxy
Atrybut mode obiektu ProxyConfig określa ogólne zachowanie Chrome w odniesieniu do korzystania z serwera proxy. Może przyjmować te wartości:
direct- W trybie
directwszystkie połączenia są tworzone bezpośrednio, bez udziału serwera proxy. Ten tryb nie dopuszcza żadnych dodatkowych parametrów w obiekcieProxyConfig. auto_detect- W trybie
auto_detectkonfiguracja serwera proxy jest określana przez skrypt PAC, który można pobrać pod adresem http://wpad/wpad.dat. Ten tryb nie dopuszcza żadnych dodatkowych parametrów w obiekcieProxyConfig. pac_script- W trybie
pac_scriptkonfiguracja serwera proxy jest określana przez skrypt PAC, który jest pobierany z adresu URL określonego w obiekcieproxy.PacScriptlub dosłownie pobierany z elementudataokreślonego w obiekcieproxy.PacScript. Poza tym ten tryb nie dopuszcza żadnych dodatkowych parametrów w obiekcieProxyConfig. fixed_servers- W trybie
fixed_serverskonfiguracja serwera proxy jest zakodowana w obiekcieproxy.ProxyRules. Jego struktura jest opisana w sekcji Reguły serwera proxy. Poza tym trybfixed_serversnie dopuszcza żadnych dodatkowych parametrów w obiekcieProxyConfig. system- W trybie
systemkonfiguracja serwera proxy jest pobierana z systemu operacyjnego. Ten tryb nie dopuszcza żadnych dodatkowych parametrów w obiekcieProxyConfig. Pamiętaj, że trybsystemróżni się od ustawienia konfiguracji serwera proxy. W tym drugim przypadku Chrome wraca do ustawień systemowych tylko wtedy, gdy żadne opcje wiersza poleceń nie wpływają na konfigurację serwera proxy.
Reguły serwera proxy
Obiekt proxy.ProxyRules może zawierać atrybut singleProxy lub podzbiór atrybutów
proxyForHttp, proxyForHttps, proxyForFtp, i fallbackProxy.
W pierwszym przypadku ruch HTTP, HTTPS i FTP jest przekierowywany przez określony serwer proxy. Inny ruch jest wysyłany bezpośrednio. W drugim przypadku zachowanie jest nieco bardziej subtelne: jeśli serwer proxy jest skonfigurowany dla protokołu HTTP, HTTPS lub FTP, odpowiedni ruch jest przekierowywany przez określony serwer. Jeśli taki serwer proxy nie jest określony lub ruch używa innego protokołu niż HTTP, HTTPS lub FTP, używany jest fallbackProxy. Jeśli nie określono fallbackProxy, ruch jest wysyłany bezpośrednio bez serwera proxy.
Obiekty serwera proxy
Serwer proxy jest konfigurowany w obiekcie proxy.ProxyServer. Połączenie z serwerem proxy (zdefiniowanym przez atrybut host) używa protokołu zdefiniowanego w atrybucie scheme. Jeśli nie określono scheme, połączenie z serwerem proxy domyślnie używa protokołu http.
Jeśli w obiekcie proxy.ProxyServer nie zdefiniowano port, port jest wyprowadzany ze schematu.
Domyślne porty:
| Schemat | Port |
|---|---|
| http | 80 |
| https | 443 |
| socks4 | 1080 |
| socks5 | 1080 |
Lista pomijanych
Poszczególne serwery można wykluczyć z przekierowywania za pomocą bypassList. Ta lista może zawierać te wpisy:
[SCHEME://]HOST_PATTERN[:PORT]Dopasuj wszystkie nazwy hostów, które pasują do wzorca
HOST_PATTERN. Początkowy znak"."jest interpretowany jako"*.".Przykłady:
"foobar.com", "*foobar.com", "*.foobar.com", "*foobar.com:99", "https://x.*.y.com:99".Wzór Dopasowania Nie pasuje ".foobar.com""www.foobar.com""foobar.com""*.foobar.com""www.foobar.com""foobar.com""foobar.com""foobar.com""www.foobar.com""*foobar.com""foobar.com","www.foobar.com","foofoobar.com"[SCHEME://]IP_LITERAL[:PORT]Dopasuj adresy URL, które są literałami adresów IP. Koncepcyjnie jest to podobne do pierwszego przypadku, ale z wyjątkami dotyczącymi kanonizacji literałów IP. Na przykład dopasowanie do „[0:0:0::1]” jest takie samo jak dopasowanie do „[::1]”, ponieważ kanonizacja IPv6 jest wykonywana wewnętrznie.
Przykłady:
127.0.1,[0:0::1],[::1]:80,https://[::1]:443IP_LITERAL/PREFIX_LENGTH_IN_BITSDopasuj dowolny adres URL zawierający literał IP (
IP_LITERAL) w danym zakresie. Zakres adresów IP (PREFIX_LENGTH_IN_BITS) jest określany za pomocą notacji CIDR.Dopasuj dowolny adres URL zawierający literał IP w danym zakresie. Zakres adresów IP jest określany za pomocą notacji CIDR. Przykłady:
"192.168.1.1/16", "fefe:13::abc/33"<local>Literał
<local>pasuje do prostych nazw hostów. Prosta nazwa hosta to nazwa, która nie zawiera kropek i nie jest literałem IP. Na przykładexampleilocalhostto proste nazwy hostów, aexample.com,example.i[::1]nie.Przykład:
"<local>"
Przykłady
Poniższy kod ustawia serwer proxy SOCKS 5 dla połączeń HTTP ze wszystkimi serwerami z wyjątkiem foobar.com i używa połączeń bezpośrednich dla wszystkich innych protokołów. Ustawienia dotyczą zwykłych i incognito okien, ponieważ okna incognito dziedziczą ustawienia ze zwykłych okien. Zapoznaj się też z dokumentacją interfejsu Types API.
var config = {
mode: "fixed_servers",
rules: {
proxyForHttp: {
scheme: "socks5",
host: "1.2.3.4"
},
bypassList: ["foobar.com"]
}
};
chrome.proxy.settings.set(
{value: config, scope: 'regular'},
function() {}
);
Poniższy kod ustawia niestandardowy skrypt PAC.
var config = {
mode: "pac_script",
pacScript: {
data: "function FindProxyForURL(url, host) {\n" +
" if (host == 'foobar.com')\n" +
" return 'PROXY blackhole:80';\n" +
" return 'DIRECT';\n" +
"}"
}
};
chrome.proxy.settings.set(
{value: config, scope: 'regular'},
function() {}
);
Następny fragment kodu wysyła zapytanie o aktualnie obowiązujące ustawienia serwera proxy. Obowiązujące ustawienia serwera proxy mogą być określone przez inne rozszerzenie lub przez zasadę. Szczegółowe informacje znajdziesz w dokumentacji interfejsu Types API.
chrome.proxy.settings.get(
{'incognito': false},
function(config) {
console.log(JSON.stringify(config));
}
);
Pamiętaj, że obiekt value przekazywany do set() nie jest identyczny z obiektem value przekazywanym do funkcji wywołania zwrotnego get(). Ten drugi będzie zawierać element rules.proxyForHttp.port.
Typy
Mode
Typ wyliczeniowy
"direct"
"auto_detect"
"pac_script"
"fixed_servers"
"system"
PacScript
Obiekt zawierający informacje o automatycznej konfiguracji serwera proxy. Dokładnie 1 pole powinno być niepuste.
Właściwości
-
dane
ciąg znaków opcjonalny
Skrypt PAC.
-
obowiązkowe
wartość logiczna opcjonalna
Jeśli ma wartość true, nieprawidłowy skrypt PAC uniemożliwi stosowi sieciowemu powrót do połączeń bezpośrednich. Wartość domyślna to fałsz.
-
URL
ciąg znaków opcjonalny
Adres URL pliku PAC, którego chcesz użyć.
ProxyConfig
Obiekt zawierający pełną konfigurację serwera proxy.
Właściwości
-
tryb
„direct” = nigdy nie używaj serwera proxy; „auto_detect” = automatycznie wykrywaj ustawienia serwera proxy; „pac_script” = używaj określonego skryptu PAC; „fixed_servers” = ręcznie określ serwery proxy; „system” = używaj systemowych ustawień serwera proxy.
-
pacScript
PacScript opcjonalny
Skrypt automatycznej konfiguracji serwera proxy (PAC) dla tej konfiguracji. Użyj go w trybie „pac_script”.
-
reguły
ProxyRules opcjonalny
Reguły serwera proxy opisujące tę konfigurację. Użyj go w trybie „fixed_servers”.
ProxyRules
Obiekt zawierający zbiór reguł serwera proxy dla wszystkich protokołów. Użyj właściwości „singleProxy” lub (podzbioru) „proxyForHttp”, „proxyForHttps”, „proxyForFtp” i „fallbackProxy”.
Właściwości
-
bypassList
string[] opcjonalny
Lista serwerów, z którymi można się łączyć bez serwera proxy.
-
fallbackProxy
ProxyServer opcjonalny
Serwer proxy, który ma być używany do wszystkiego innego lub jeśli nie określono żadnego z serwerów proxyFor...
-
proxyForFtp
ProxyServer opcjonalny
Serwer proxy, który ma być używany do żądań FTP.
-
proxyForHttp
ProxyServer opcjonalny
Serwer proxy, który ma być używany do żądań HTTP.
-
proxyForHttps
ProxyServer opcjonalny
Serwer proxy, który ma być używany do żądań HTTPS.
-
singleProxy
ProxyServer opcjonalny
Serwer proxy, który ma być używany do wszystkich żądań dotyczących poszczególnych adresów URL (czyli http, https i ftp).
ProxyServer
Obiekt zawierający specyfikację pojedynczego serwera proxy.
Właściwości
-
host
ciąg znaków
Nazwa hosta lub adres IP serwera proxy. Nazwy hostów muszą być w formacie ASCII (w formacie Punycode). IDNA nie jest jeszcze obsługiwana.
-
port
liczba opcjonalna
Port serwera proxy. Domyślnie jest to port zależny od schematu.
-
schemat
Schemat opcjonalny
Schemat (protokół) samego serwera proxy. Domyślnie jest to „http”.
Scheme
Typ wyliczeniowy
"http"
"https"
"quic"
"socks4"
"socks5"
Właściwości
settings
Ustawienia serwera proxy, których chcesz użyć. Wartością tego ustawienia jest obiekt ProxyConfig.
Wydarzenia
onProxyError
chrome.proxy.onProxyError.addListener(
callback: function,
)
Informuje o błędach serwera proxy.
Parametry
-
callback
funkcja
Parametr
callbackwygląda tak:(details: object) => void
-
szczegóły
obiekt
-
szczegóły
ciąg znaków
Dodatkowe informacje o błędzie, np. błąd środowiska wykonawczego JavaScript.
-
błąd
ciąg znaków
Opis błędu.
-
fatal
wartość logiczna
Jeśli ma wartość true, błąd był krytyczny i transakcja sieciowa została przerwana. W przeciwnym razie używane jest połączenie bezpośrednie.
-
-