Ta strona zawiera opis każdej zmiany zachowania, która wpływa na aplikacje i została dodana do frameworku zgodności w Androidzie 11 (poziom API 30). Korzystaj z tej listy w połączeniu z opcjami dla deweloperów i poleceniami ADB, aby testować i debugować aplikację podczas przygotowywania jej do użycia na Androidzie 11.
ADD_CONTENT_OBSERVER_FLAGS
Identyfikator zmiany: 150939131
Stan domyślny: włączone w przypadku aplikacji kierowanych na Androida 11 (poziom interfejsu API 30) lub nowszego.
W przypadku aplikacji kierowanych na Androida 11 dostępna jest nowa publiczna metoda interfejsu API onChange(boolean, Uri, int)
, która zawiera argument całkowity flags
.
Ta nowa metoda to publiczna alternatywa dla pakietu SDK na potrzeby aplikacji, które korzystają z metody przeciążonej onChange()
innej niż SDK, która zawiera argument będący liczbą całkowitą userId
.
ADMIN_APP_PASSWORD_COMPLEXITY
Identyfikator zmiany: 123562444
Stan domyślny: włączone w przypadku aplikacji kierowanych na Androida 11 (poziom API 30) lub nowszego.
W przypadku aplikacji administracyjnych kierowanych na Androida 11 wyrzucaj błąd, gdy aplikacja ustawia wymóg hasła, który nie jest odpowiedni dla obecnie przypisanej jakości hasła. Jeśli na przykład jakość hasła jest ustawiona na DevicePolicyManager.PASSWORD_QUALITY_UNSPECIFIED
, aplikacja nie będzie mogła ustawić minimalnej długości hasła. W takim przypadku przed próbą ustawienia minimalnej długości hasła aplikacja powinna najpierw wywołać metodę setPasswordQuality()
, a dopiero potem metodę setPasswordMinimumLength()
.
Dodatkowo, gdy aplikacja administratora kierowana na Androida 11 obniża jakość hasła, wszystkie istniejące wymagania dotyczące hasła, które nie mają już zastosowania, są resetowane do wartości domyślnych.
APP_DATA_DIRECTORY_ISOLATION
Identyfikator zmiany: 143937733
Stan domyślny: włączone w przypadku aplikacji kierowanych na Androida 11 (poziom API 30) lub nowszego.
Aplikacje kierowane na Androida 11 nie mają już dostępu do plików w prywatnych katalogach danych żadnej aplikacji, niezależnie od jej docelowej wersji pakietu SDK.
Więcej informacji znajdziesz w artykule o dostępie do katalogów prywatnych.
APN_READING_PERMISSION_CHANGE_ID
Zmień identyfikator: 124107808
Stan domyślny: włączone dla aplikacji kierowanych na Androida 11 (poziom API 30) lub nowszego.
W przypadku aplikacji kierowanych na Androida 11 dostęp do bazy danych APN wymaga teraz uprawnienia Manifest.permission.WRITE_APN_SETTINGS
.
Więcej informacji o tej zmianie znajdziesz w artykule Ograniczony dostęp do odczytu bazy danych APN.
BACKGROUND_RATIONALE_CHANGE_ID
Identyfikator zmiany: 147316723
Stan domyślny: włączone dla aplikacji kierowanych na Androida 11 (poziom API 30) lub nowszego.
Aplikacje muszą teraz podawać uzasadnione powody, za każdym razem, gdy proszą o dostęp do lokalizacji urządzenia w tle.
Więcej informacji o tej zmianie znajdziesz w przewodniku Dostęp do lokalizacji w tle w Androidzie 11, który zawiera informacje o zmianach w zakresie prywatności związanych z lokalizacją w Androidzie 11.
CALLBACK_ON_CLEAR_CHANGE
Zmień identyfikator: 119147584
Stan domyślny: włączone w przypadku aplikacji kierowanych na Androida 11 (poziom interfejsu API 30) lub nowszego.
Za każdym razem, gdy wywołana zostanie funkcja Editor.clear
, wywoływana jest funkcja OnSharedPreferenceChangeListener.onSharedPreferenceChanged
z kluczem null
.
Więcej informacji o tej zmianie znajdziesz w artykule Zmiany w funkcji wywołania zwrotnego OnSharedPreferenceChangeListener.
CALLBACK_ON_MORE_ERROR_CODE_CHANGE
Zmień identyfikator: 130595455
Stan domyślny: włączone w przypadku aplikacji kierowanych na Androida 11 (poziom API 30) lub nowszego.
Kody błędów zostały teraz rozwinięte w przypadku updateAvailableNetworks(List,
Executor,
Consumer)
i setPreferredOpportunisticDataSubscription(int, boolean, Executor,
Consumer)
.
CALL_BACK_ON_CHANGED_LISTENER_WITH_SWITCHED_OP_CHANGE
Identyfikator zmiany: 148180766
Stan domyślny: włączone w przypadku aplikacji kierowanych na Androida 11 (poziom API 30) lub nowszego.
To subtelna zmiana zachowania startWatchingMode(String, String,
AppOpsManager.OnOpChangedListener)
.
Przed tą zmianą system wywołał przełączenie operacji. Po zmianie system wywołuje żądania rzeczywiście żądanej operacji lub wszystkie przełączone operacje, jeśli nie określono żadnej.
CAMERA_MICROPHONE_CAPABILITY_CHANGE_ID
Identyfikator zmiany: 136219221
Stan domyślny: włączone dla aplikacji kierowanych na Androida 11 (poziom API 30) lub nowszego.
W przypadku aplikacji kierowanych na Androida 11 usługi działające na pierwszym planie mają dostęp do kamery i mikrofonu tylko wtedy, gdy w pliku manifestu R.attr.foregroundServiceType
jest odpowiednio skonfigurowana jako ServiceInfo.FOREGROUND_SERVICE_TYPE_CAMERA
lub ServiceInfo.FOREGROUND_SERVICE_TYPE_MICROPHONE
. We wcześniejszych wersjach Androida usługi na pierwszym planie automatycznie uzyskiwały dostęp do kamery i mikrofonu.
Więcej informacji o tej zmianie znajdziesz w artykule Typy usług działających na pierwszym planie w Androidzie 11.
CHANGE_BACKGROUND_CUSTOM_TOAST_BLOCK
Identyfikator zmiany: 128611929
Stan domyślny: włączone dla aplikacji kierowanych na Androida 11 (poziom API 30) lub nowszego.
Aplikacje nie mogą już publikować niestandardowych powiadomień w tle. Aplikacje mogą jednak nadal publikować powiadomienia za pomocą metody Toast.makeText(Context, CharSequence,
int)
i jej wariantów w tle.
Więcej informacji o tej zmianie znajdziesz w sekcji Niestandardowe wyświetlanie powiadomień jest blokowane.
CHANGE_RESTRICT_SAW_INTENT
Identyfikator zmiany: 135920175
Stan domyślny: tej zmiany nie można przełączyć. Jest logowana tylko przez platformę zgodności.
Intencje korzystające z działania android.settings.MANAGE_APP_OVERLAY_PERMISSION
i schematu URI danych package
nie kierują już użytkownika do ekranu danej aplikacji, gdzie może zarządzać powiązanymi uprawnieniami. Zamiast tego użytkownik jest przekierowywany do ekranu, na którym może zarządzać wszystkimi aplikacjami, które poprosiły o to uprawnienie.
CHANGE_TEXT_TOASTS_IN_THE_SYSTEM
Identyfikator zmiany: 147798919
Stan domyślny: włączone w przypadku aplikacji kierowanych na Androida 11 (poziom API 30) lub nowszego.
Komunikaty tekstowe są teraz renderowane przez SystemUI, a nie w aplikacji. Zapobiega to obchodzeniu przez aplikacje ograniczeń dotyczących publikowania niestandardowych komunikatów w tle.
DEFAULT_SCOPED_STORAGE
Identyfikator zmiany: 149924527
Stan domyślny: włączone dla wszystkich aplikacji.
Wszystkie aplikacje kierowane na Androida 11 domyślnie korzystają teraz z ograniczonego miejsca na dane i nie można już zrezygnować z tego miejsca.
Możesz jednak przetestować aplikację bez ograniczonego miejsca na dane, niezależnie od wersji docelowego pakietu SDK i wartości flagi w pliku manifestu. Wystarczy, że wyłączysz tę zmianę.
Więcej informacji o zmianach w ograniczonym miejscu na dane w Androidzie 11 znajdziesz w sekcji Ograniczone miejsce na dane na stronie poświęconej zmianom w miejscu na dane w Androidzie 11.
EMPTY_INTENT_ACTION_CATEGORY
Identyfikator zmiany: 151163173
Stan domyślny: włączone w przypadku aplikacji kierowanych na Androida 11 (poziom API 30) lub nowszego.
W przypadku aplikacji kierowanych na Androida 11 system zgłasza teraz błąd, jeśli action
lub category
filtra intencji jest pustym ciągiem znaków. Błąd w platformie przed Androidem 11 pozwalał na przepuszczenie tego przypadku bez wyświetlania błędu. Pamiętaj, że nie dotyczy to sytuacji, gdy atrybut jest pusty lub go brakuje, ponieważ zawsze powodowało to błąd.
FILTER_APPLICATION_QUERY
Identyfikator zmiany: 135549675
Stan domyślny: włączone w przypadku aplikacji kierowanych na Androida 11 (poziom API 30) lub nowszego.
Aplikacje muszą teraz zadeklarować pakiety i intencje, których zamierzają używać, zanim będą mogły uzyskać szczegółowe informacje o innych aplikacjach na urządzeniu. Deklaracje te należy zamieścić w pliku manifestu aplikacji za pomocą tagu <queries>
.
Więcej informacji o wysyłaniu zapytań do innych zainstalowanych aplikacji i współdziałaniu z nimi w Androidzie 11 znajdziesz na stronie poświęconej widoczności aplikacji.
FORCE_ENABLE_SCOPED_STORAGE
Identyfikator zmiany: wartość: 132649864
Stan domyślny: wyłączone w przypadku wszystkich aplikacji.
Wszystkie aplikacje przeznaczone na Androida 11 domyślnie korzystają z ograniczonego miejsca na dane i nie można już zrezygnować z ograniczonego miejsca na dane.
Jeśli jednak Twoja aplikacja jest nadal kierowana na Androida 10 (poziom interfejsu API 29) lub niższego, możesz przetestować ją z ograniczonym miejscem na dane niezależnie od wersji docelowego pakietu SDK i wartości flagi w manifeście. Aby to zrobić, włącz tę opcję.
Więcej informacji o zmianach dotyczących miejsca na dane w zakresie na Androidzie 11 znajdziesz w sekcji Ograniczone miejsce na dane na stronie, w której znajdziesz informacje o zmianach dotyczących miejsca na dane na Androidzie w Androidzie 11.
GET_DATA_CONNECTION_STATE_R_VERSION
Identyfikator zmiany: 148535736
Stan domyślny: włączone w przypadku aplikacji kierowanych na Androida 11 (poziom API 30) lub nowszego.
Aby sprawdzić wersję pakietu SDK w przypadku PreciseDataConnectionState#getDataConnectionState
.
GET_DATA_STATE_R_VERSION
Identyfikator zmiany: 148534348
Stan domyślny: włączone w przypadku aplikacji kierowanych na Androida 11 (poziom API 30) lub nowszego.
Aby sprawdzić wersję pakietu SDK dla getDataState()
.
GET_PROVIDER_SECURITY_EXCEPTIONS
Identyfikator zmiany: 150935354
Stan domyślny: włączone w przypadku aplikacji kierowanych na Androida 11 (poziom interfejsu API 30) lub nowszego.
W przypadku aplikacji kierowanych na Androida 11 (poziom API 30) lub nowszego nie są już zgłaszane żadne wyjątki związane z zabezpieczeniami.getProvider(String)
GET_TARGET_SDK_VERSION_CODE_CHANGE
Identyfikator zmiany: 145147528
Stan domyślny: włączone dla aplikacji kierowanych na Androida 10 (poziom interfejsu API 29) lub nowszego.
Aby sprawdzić wersję pakietu SDK dla metody SmsManager.sendResolverResult()
.
GWP_ASAN
Identyfikator zmiany: 135634846
Stan domyślny: wyłączone we wszystkich aplikacjach.
Umożliwia wykrywanie w aplikacjach błędów w pamięci natywnej na podstawie próbek.
Więcej informacji o tej zmianie znajdziesz w przewodniku GWP-ASan.
HIDE_MAXTARGETSDK_P_HIDDEN_APIS
Identyfikator zmiany: 149997251
Stan domyślny: włączone dla aplikacji kierowanych na Androida 10 (poziom interfejsu API 29) lub nowszego.
W przypadku aplikacji kierowanych na Androida 10 (poziom interfejsu API 29) lub nowszego usuwa dostęp do wszystkich interfejsów innych niż SDK, które są częścią listy max-target-p
(greylist-max-p
) dla Androida 10 (poziom interfejsu API 29).
HIDE_MAXTARGETSDK_Q_HIDDEN_APIS
Identyfikator zmiany: 149994052
Stan domyślny: włączone w przypadku aplikacji kierowanych na Androida 11 (poziom API 30) lub nowszego.
W przypadku aplikacji kierowanych na Androida 11 (poziom API 30) lub nowszego usuwa dostęp do wszystkich interfejsów niebędących pakietami SDK, które są częścią listy max-target-q
(greylist-max-q
) dla Androida 11 (poziom API 30).
Więcej informacji o tej zmianie znajdziesz w artykule Interfejsy inne niż SDK, które są teraz blokowane w Androidzie 11.
LISTEN_CODE_CHANGE
Identyfikator zmiany: 147600208
Stan domyślny: włączone dla aplikacji kierowanych na Androida 10 (poziom interfejsu API 29) lub nowszego.
Aby sprawdzić wersję pakietu SDK na potrzeby TelephonyManager.listen(PhoneStateListener,
int)
.
BRAK_TAGU_APLIKACJI
Zmień identyfikator: 150776642
Stan domyślny: włączone w przypadku aplikacji kierowanych na Androida 11 (poziom interfejsu API 30) lub nowszego.
W przypadku aplikacji kierowanych na Androida 11 błąd jest teraz generowany, gdy w pliku manifestu aplikacji brakuje tagu application
lub instrumentation
.
TAGOWANIE_SERWERA_NAJWIĘKSZEGO
Identyfikator zmiany: 135754954
Stan domyślny: włączone w przypadku aplikacji kierowanych na Androida 11 (poziom interfejsu API 30) lub nowszego.
W przypadku aplikacji kierowanych na Androida 11 przydzielanie pamięci natywnych sterty ma teraz w najbardziej znaczącym bajcie tag inny niż 0.
Więcej informacji znajdziesz w artykule o oznaczaniu wskaźników stosu.
PHONE_STATE_LISTENER_LIMIT_CHANGE_ID
Identyfikator zmiany: 150880553
Stan domyślny: włączone dla wszystkich aplikacji.
W przypadku aplikacji kierowanych na Androida 11 obowiązuje teraz limit liczby obiektów PhoneStateListener
, które można zarejestrować za pomocą TelephonyManager.listen(PhoneStateListener, int)
.
Domyślny limit to 50, ale może się on zmienić w związku z aktualizacjami konfiguracji urządzeń zdalnych.
Ten limit jest egzekwowany za pomocą IllegalStateException
, rzucanego przez TelephonyManager.listen(PhoneStateListener, int)
, gdy proces naruszający próbuje zarejestrować zbyt dużą liczbę odbiorców.
PREVENT_META_REFLECTION_BLACKLIST_ACCESS
Identyfikator zmiany: 142365358
Stan domyślny: włączone w przypadku aplikacji kierowanych na Androida 11 (poziom API 30) lub nowszego.
Aplikacje kierowane na Androida 11 nie mogą już używać dodatkowej warstwy odbicia lustrzanego do uzyskiwania dostępu do interfejsów spoza pakietu SDK, które są ograniczone.
PROCESS_CAPABILITY_CHANGE_ID
Identyfikator zmiany: 136274596
Stan domyślny: włączone w przypadku aplikacji kierowanych na Androida 11 (poziom API 30) lub nowszego.
W przypadku aplikacji kierowanych na Androida 11 flaga Context.BIND_INCLUDE_CAPABILITIES
może teraz być używana do przekazywania funkcji w trakcie użytkowania z procesu klienta do powiązanej usługi.
REMOVE_ANDROID_TEST_BASE
Identyfikator zmiany: 133396946
Stan domyślny: włączone w przypadku aplikacji kierowanych na Androida 11 (poziom interfejsu API 30) lub nowszego.
W przypadku aplikacji przeznaczonych na Androida 11 biblioteka android.test.base
została usunięta, jeśli aplikacja nie jest od niej zależna (ale jest zależna od klas z biblioteki android.test.base
).android.test.runner
REQUEST_ACCESSIBILITY_BUTTON_CHANGE
Identyfikator zmiany: 136293963
Stan domyślny: włączone w przypadku aplikacji kierowanych na Androida 11 (poziom API 30) lub nowszego.
W przypadku usług ułatwień dostępu kierowanych na Androida 11 flaga FLAG_REQUEST_ACCESSIBILITY_BUTTON
musi być teraz określona w pliku metadanych usługi ułatwień dostępu.
W przeciwnym razie flaga jest ignorowana.
Więcej informacji o tej zmianie znajdziesz w artykule Oświadczenie o korzystaniu z przycisku ułatwień dostępu w pliku metadanych.
RESOURCES_ARSC_COMPRESSED
Identyfikator zmiany: 132742131
Stan domyślny: włączone w przypadku aplikacji kierowanych na Androida 11 (poziom interfejsu API 30) lub nowszego.
Aplikacje kierowane na Androida 11 (poziom API 30) nie mogą być instalowane, jeśli zawierają skompresowany plik resources.arsc
lub jeśli ten plik nie jest wyrównany do granicy 4 bajtów.
Więcej informacji o tej zmianie znajdziesz w artykule Pliki zasobów skompresowanych.
RESTRICT_STORAGE_ACCESS_FRAMEWORK
Identyfikator zmiany: 141600225
Stan domyślny: włączone w przypadku aplikacji kierowanych na Androida 11 (poziom interfejsu API 30) lub nowszego.
Jeśli Twoja aplikacja jest kierowana na Androida 11 i korzysta z ramki dostępu do pamięci (SAF), nie będziesz mieć już dostępu do niektórych katalogów za pomocą działań ACTION_OPEN_DOCUMENT
i ACTION_OPEN_DOCUMENT_TREE
. Więcej informacji o tych zmianach znajdziesz w sekcji Ograniczenia dostępu do dokumentów na stronie, w której omówione są aktualizacje prywatności dotyczące miejsca na dane w Androidzie 11.
SELINUX_LATEST_CHANGES
Identyfikator zmiany: 143539591
Stan domyślny: włączone w przypadku aplikacji kierowanych na Androida 11 (poziom API 30) lub nowszego.
Ta zmiana ogranicza dostęp aplikacji do domeny SELinux untrusted_app_R-targetSDk.
To jedna z podstawowych zmian w platformie zgodności, która pozwala aplikacjom na przełączanie innych zmian objętych zasadą targetSdkVersion
bez zmiany tego elementu (targetSDKVersion
). Z tego powodu nie należy wyłączać tej zmiany w przypadku aplikacji kierowanej na Androida 11, ponieważ w przeciwnym razie nie będzie ona działać.
Ta zmiana nie ma wpływu na aplikacje, które używają wspólnego identyfikatora użytkownika.
THROW_SECURITY_EXCEPTIONS
Zmień identyfikator: 147340954
Stan domyślny: włączone w przypadku aplikacji kierowanych na Androida 11 (poziom API 30) lub nowszego.
Przed Androidem 11 interfejs API setEnabled
wywoływał błąd SecurityException
tylko w przypadku błędu uprawnień. W Androidzie 11 ta zasada już nie obowiązuje. Poza tym SecurityException
można zgłosić z dowolnej liczby powodów, ale żaden z nich nie jest widoczny dla rozmówcy.
Aby zachować dotychczasowe działanie interfejsu API, jeśli w przypadku aplikacji, która nie jest kierowana na Androida 11, wystąpi błąd uprawnień lub błąd egzekwowania, wyjątek zostanie skonwertowany na wyjątek IllegalStateException
, który istniał w źródle przed Androidem 11.
USE_SET_LOCATION_ENABLED
Zmień identyfikator: 117835097
Stan domyślny: włączone w przypadku aplikacji kierowanych na Androida 11 (poziom interfejsu API 30) lub nowszego.
Aplikacje administracyjne kierowane na Androida 11 nie mogą już używać funkcji DevicePolicyManager.setSecureSetting(ComponentName, String, String)
do zmiany wycofanego ustawienia Settings.Secure.LOCATION_MODE
. Zamiast tego należy użyć elementu DevicePolicyManager.setLocationEnabled(ComponentName, boolean)
.