chrome.identity (original) (raw)
Manifest V3
chrome.identity
Opis
Użyj interfejsu chrome.identity API, aby uzyskać tokeny dostępu OAuth2.
Uprawnienia
identity
Typy
AccountInfo
Właściwości
- Unikalny identyfikator konta. Ten identyfikator nie zmieni się przez cały okres istnienia konta.
AccountStatus
Typ wyliczeniowy
„SYNC”
Określa, że synchronizacja jest włączona na koncie głównym.
„ANY”
Określa, czy istnieje konto podstawowe.
GetAuthTokenResult
Właściwości
- grantedScopes
string[] opcjonalne
Lista zakresów OAuth 2.0 przyznanych rozszerzeniu. - Konkretny token powiązany z żądaniem.
InvalidTokenDetails
Właściwości
- Konkretny token, który należy usunąć z pamięci podręcznej.
ProfileDetails
Właściwości
- accountStatus
AccountStatus opcjonalny
Stan konta głównego zalogowanego w profilu, któregoProfileUserInfopowinien zostać zwrócony. Domyślna wartość to stan kontaSYNC.
ProfileUserInfo
Właściwości
- Adres e-mail konta użytkownika zalogowanego w bieżącym profilu. Puste, jeśli użytkownik nie jest zalogowany lub nie określono uprawnienia
identity.emailw pliku manifestu. - Unikalny identyfikator konta. Ten identyfikator nie zmieni się przez cały okres istnienia konta. Puste, jeśli użytkownik nie jest zalogowany lub (w przypadku M41+) nie określono uprawnienia
identity.emailw pliku manifestu.
TokenDetails
Właściwości
- konto
AccountInfo opcjonalnie
Identyfikator konta, dla którego ma zostać zwrócony token. Jeśli nie zostanie podane, funkcja użyje konta z profilu Chrome: konta synchronizacji, jeśli takie istnieje, lub pierwszego konta Google w internecie. - enableGranularPermissions
wartość logiczna opcjonalna
Chrome w wersji 87 lub nowszej
FlagaenableGranularPermissionsumożliwia rozszerzeniom wcześniejsze włączenie ekranu zgody na szczegółowe uprawnienia, na którym można przyznawać lub odrzucać poszczególne żądane uprawnienia. - interaktywny
wartość logiczna opcjonalna
Pobranie tokena może wymagać zalogowania się użytkownika w Chrome lub zatwierdzenia przez niego zakresów żądanych przez aplikację. Jeśli flaga interaktywności ma wartośćtrue,getAuthTokenwyświetli użytkownikowi odpowiedni komunikat. Gdy flaga ma wartośćfalselub jest pominięta, funkcjagetAuthTokenzwraca błąd za każdym razem, gdy wymagany jest prompt. - zakresy
string[] opcjonalne
Lista zakresów OAuth 2.0, o które należy poprosić.
Jeśli polescopesjest obecne, zastępuje listę zakresów podaną w pliku manifest.json.
WebAuthFlowDetails
Właściwości
- abortOnLoadForNonInteractive
wartość logiczna opcjonalna
Określa, czy w przypadku żądań nieinteraktywnych należy zakończyćlaunchWebAuthFlowpo wczytaniu strony. Ten parametr nie ma wpływu na interaktywne procesy.
Gdy ta opcja jest ustawiona natrue(domyślnie), przepływ kończy się natychmiast po załadowaniu strony. Jeśli ustawisz wartośćfalse, proces zakończy się dopiero po upłynięciu czasutimeoutMsForNonInteractive. Jest to przydatne w przypadku dostawców tożsamości, którzy używają JavaScriptu do przekierowywania po wczytaniu strony. - interaktywny
wartość logiczna opcjonalna
Określa, czy proces autoryzacji ma być uruchamiany w trybie interaktywnym.
Niektóre procesy uwierzytelniania mogą od razu przekierowywać do adresu URL wyniku, dlategolaunchWebAuthFlowukrywa widok internetowy do momentu, gdy pierwsze przekierowanie nastąpi do końcowego adresu URL lub gdy zakończy się ładowanie strony, która ma być wyświetlana.
Jeśli flagainteractivema wartośćtrue, okno będzie wyświetlane po załadowaniu strony. Jeśli flaga ma wartośćfalselub jest pominięta, funkcjalaunchWebAuthFlowzwróci błąd, jeśli początkowa nawigacja nie zakończy przepływu.
W przypadku przepływów, które używają JavaScriptu do przekierowania, wartość parametruabortOnLoadForNonInteractivemożna ustawić nafalsew połączeniu z ustawieniem parametrutimeoutMsForNonInteractive, aby umożliwić stronie wykonanie przekierowań. - timeoutMsForNonInteractive
number opcjonalny
Maksymalny łączny czas (w milisekundach), przez jakilaunchWebAuthFlowmoże działać w trybie nieinteraktywnym. Działa tylko wtedy, gdy zasadainteractivema wartośćfalse. - Adres URL, który rozpoczyna proces autoryzacji.
Metody
clearAllCachedAuthTokens()
Chrome w wersji 87 lub nowszej
chrome.identity.clearAllCachedAuthTokens(): Promise
Resetuje stan interfejsu Identity API:
- Usuwa z pamięci podręcznej tokenów wszystkie tokeny dostępu OAuth2.
- Usuwa ustawienia konta użytkownika
- Cofanie autoryzacji użytkownika we wszystkich procesach uwierzytelniania
Zwroty
getAccounts()
chrome.identity.getAccounts(): Promise<AccountInfo[]>
Pobiera listę obiektów AccountInfo opisujących konta w profilu.
Atrybut getAccounts jest obsługiwany tylko w wersji deweloperskiej.
Zwroty
getAuthToken()
chrome.identity.getAuthToken(
details?: TokenDetails,
): Promise<GetAuthTokenResult>
Pobiera token dostępu OAuth2, używając identyfikatora klienta i zakresów określonych w sekcji oauth2 pliku manifest.json.
Interfejs Identity API buforuje tokeny dostępu w pamięci, więc można wywoływać getAuthToken w sposób nieinteraktywny za każdym razem, gdy jest potrzebny token. Pamięć podręczna tokenów automatycznie obsługuje wygasanie.
Aby zapewnić użytkownikom wygodę, ważne jest, aby żądania interaktywnych tokenów były inicjowane przez interfejs w aplikacji, który wyjaśnia, do czego służy autoryzacja. Jeśli tego nie zrobisz, użytkownicy będą otrzymywać prośby o autoryzację lub ekrany logowania w Chrome (jeśli nie są zalogowani) bez kontekstu. W szczególności nie używaj funkcji getAuthToken interaktywnie przy pierwszym uruchomieniu aplikacji.
Uwaga: jeśli funkcja jest wywoływana z wywołaniem zwrotnym, zamiast zwracać obiekt, zwraca 2 właściwości jako osobne argumenty przekazywane do wywołania zwrotnego.
Parametry
- szczegóły
TokenDetails opcjonalny
Opcje tokena.
Zwroty
- Promise<GetAuthTokenResult>
getProfileUserInfo()
chrome.identity.getProfileUserInfo(
details?: ProfileDetails,
): Promise<ProfileUserInfo>
Pobiera adres e-mail i zaciemniony identyfikator Gaia użytkownika zalogowanego w profilu.
Wymaga uprawnienia identity.email w pliku manifestu. W przeciwnym razie zwraca pusty wynik.
Ten interfejs API różni się od interfejsu identity.getAccounts na 2 sposoby. Zwrócone informacje są dostępne offline i dotyczą tylko konta głównego w profilu.
Parametry
- szczegóły
ProfileDetails opcjonalnie
Opcje profilu.
Zwroty
getRedirectURL()
chrome.identity.getRedirectURL(
path?: string,
): string
Generuje przekierowanie do użycia w zmiennej launchWebAuthFlow.
Wygenerowane adresy URL pasują do wzorca https://<app-id>.chromiumapp.org/*.
Parametry
- ścieżka
string opcjonalny
Ścieżka dołączana na końcu wygenerowanego adresu URL.
Zwroty
launchWebAuthFlow()
chrome.identity.launchWebAuthFlow(
details: WebAuthFlowDetails,
): Promise<string | undefined>
Rozpoczyna proces uwierzytelniania pod określonym adresem URL.
Ta metoda umożliwia przepływy uwierzytelniania z użyciem dostawców tożsamości innych niż Google. W tym celu uruchamia widok internetowy i przekierowuje go do pierwszego adresu URL w przepływie uwierzytelniania dostawcy. Gdy dostawca przekieruje użytkownika na adres URL pasujący do wzorca https://<app-id>.chromiumapp.org/*, okno zostanie zamknięte, a ostateczny adres URL przekierowania zostanie przekazany do funkcji callback.
Aby zapewnić użytkownikom wygodę, ważne jest, aby interaktywne procesy uwierzytelniania były inicjowane przez interfejs w aplikacji, który wyjaśnia, do czego służy autoryzacja. Jeśli tego nie zrobisz, użytkownicy będą otrzymywać prośby o autoryzację bez kontekstu. W szczególności nie uruchamiaj interaktywnego procesu uwierzytelniania przy pierwszym uruchomieniu aplikacji.
Parametry
- Opcje procedury WebAuth.
Zwroty
- Promise<string | undefined>
removeCachedAuthToken()
chrome.identity.removeCachedAuthToken(
details: InvalidTokenDetails,
): Promise
Usuwa token dostępu OAuth2 z pamięci podręcznej tokenów interfejsu API tożsamości.
Jeśli token dostępu okaże się nieprawidłowy, należy przekazać go do funkcji removeCachedAuthToken, aby usunąć go z pamięci podręcznej. Aplikacja może wtedy pobrać nowy token z parametrem getAuthToken.
Parametry
- Informacje o tokenie.
Zwroty
Wydarzenia
onSignInChanged
chrome.identity.onSignInChanged.addListener(
callback: function,
)
Wyzwalane, gdy stan logowania konta w profilu użytkownika ulegnie zmianie.
Parametry
- Parametr
callbackwygląda tak:
(account: AccountInfo, signedIn: boolean) => void- signedIn
Wartość logiczna
- signedIn
O ile nie stwierdzono inaczej, treść tej strony jest objęta licencją Creative Commons – uznanie autorstwa 4.0, a fragmenty kodu są dostępne na licencji Apache 2.0. Szczegółowe informacje na ten temat zawierają zasady dotyczące witryny Google Developers. Java jest zastrzeżonym znakiem towarowym firmy Oracle i jej podmiotów stowarzyszonych.
Ostatnia aktualizacja: 2025-08-11 UTC.