Podobnie jak w poprzednich wersjach Android 11 zawiera zmiany w działaniu aplikacji, które mogą mieć wpływ na Twoją aplikację. Poniższe zmiany w działaniu dotyczą tylko aplikacji kierowanych na Androida 11 lub nowszego. Jeśli Twoja aplikacja ustawia wartość targetSdkVersion
na 30
, musisz ją odpowiednio zmodyfikować, aby obsługiwała te zachowania.
Zapoznaj się też z listą zmian zachowania, które mają wpływ na wszystkie aplikacje działające na Androidzie 11.
Prywatność
Android 11 wprowadza zmiany i ograniczenia, które mają zwiększyć prywatność użytkowników. Oto niektóre z nich:
- Ograniczenia dotyczące miejsca na dane: dostęp do katalogów zewnętrznego miejsca na dane jest ograniczony do katalogu konkretnej aplikacji i do określonych typów multimediów utworzonych przez aplikację.
- Automatyczne resetowanie uprawnień: jeśli użytkownicy nie korzystali z aplikacji przez kilka miesięcy, system automatycznie resetuje jej wrażliwe uprawnienia.
- Dostęp do lokalizacji w tle: użytkownicy muszą zostać przekierowani do ustawień systemu, aby przyznać aplikacjom dostęp do lokalizacji w tle.
- Widoczność pakietu: gdy aplikacja wysyła zapytanie o listę zainstalowanych aplikacji na urządzeniu, zwracana lista jest filtrowana.
Więcej informacji znajdziesz na stronie Prywatność.
Bezpieczeństwo
Tagowanie wskaźnika stosu
Szczegóły zmiany
Zmień nazwę: NATIVE_HEAP_POINTER_TAGGING
Identyfikator zmiany: 135754954
Jak włączyć lub wyłączyć
Podczas testowania zgodności aplikacji z Androidem 11 możesz włączyć lub wyłączyć tę zmianę, korzystając z tych poleceń ADB:
adb shell am compat enable (135754954|NATIVE_HEAP_POINTER_TAGGING) PACKAGE_NAME
adb shell am compat disable (135754954|NATIVE_HEAP_POINTER_TAGGING) PACKAGE_NAME
Więcej informacji o ramach zgodności i zmianach w przełączaniu znajdziesz w artykule Testowanie i debugowanie zmian w zachowaniu platformy w aplikacji.
Wskaźniki stosu mają teraz tag inny niż zero w najistotniejszym bajcie (MSB). Aplikacje, które nieprawidłowo używają wskaźników, w tym te, które modyfikują MSB, mogą teraz ulec awarii lub mieć inne problemy. Ta zmiana jest niezbędna, aby zapewnić obsługę przyszłego sprzętu z włączonym rozszerzeniem ARM Memory Grouping Extension (MTE). Więcej informacji znajdziesz w artykule Tagowane wskaźniki.
Aby wyłączyć tę funkcję, zapoznaj się z dokumentacją dotyczącą pliku allowNativeHeapPointerTagging
manifestu.
Zmiany w powiadomieniach
Niestandardowe powiadomienia z tle są blokowane
Ze względów bezpieczeństwa i dla zapewnienia wygody użytkowników system blokuje powiadomienia, które zawierają widoki niestandardowe, jeśli są one wysyłane w tle przez aplikację przeznaczoną na Androida 11 lub nowszego. Pamiętaj, że nadal dozwolone są komunikaty tekstowe, czyli komunikaty utworzone za pomocą funkcji Toast.makeText()
, które nie wywołują funkcji setView()
.
Jeśli aplikacja mimo to próbuje opublikować toast z widokiem niestandardowym w tle, system nie wyświetli go użytkownikowi. Zamiast tego system rejestruje w logcat następującą wiadomość:
W/NotificationService: Blocking custom toast from package \ <package> due to package not in the foreground
Wywołania zwrotne toast
Jeśli chcesz otrzymywać powiadomienia, gdy toast (tekstowy lub niestandardowy) pojawia się lub znika, użyj metody addCallback()
, która została dodana w Androidzie 11.
Zmiany w interfejsie Text Toast API
Aplikacje kierowane na Androida 11 lub nowszego mają następujące skutki uboczne w przypadku komunikatów tekstowych:
- Metoda
getView()
zwracanull
. - Wartości zwracane przez te metody nie odzwierciedlają rzeczywistych wartości, dlatego nie należy się na nich w aplikacji opierać:
- Te metody nie działają, więc aplikacja nie powinna z nich korzystać:
Łączność
Ograniczony dostęp z możliwością odczytu do bazy danych APN
Szczegóły zmiany
Zmień nazwę: APN_READING_PERMISSION_CHANGE_ID
Zmień identyfikator: 124107808
Jak przełączać
Podczas testowania zgodności aplikacji z Androidem 11 możesz włączyć lub wyłączyć tę zmianę, korzystając z tych poleceń ADB:
adb shell am compat enable (124107808|APN_READING_PERMISSION_CHANGE_ID) PACKAGE_NAME
adb shell am compat disable (124107808|APN_READING_PERMISSION_CHANGE_ID) PACKAGE_NAME
Więcej informacji o ramach kompatybilności i zmianach w przełączaniu znajdziesz w artykule Testowanie i debugowanie zmian w zachowaniu platformy w aplikacji.
Aplikacje kierowane na Androida 11 wymagają teraz uprzywilejowanego uprawnienia Manifest.permission.WRITE_APN_SETTINGS
do odczytu lub dostępu do bazy danych APN telekomunikatora. Próba uzyskania dostępu do bazy danych APN bez tego uprawnienia powoduje wyjątek zabezpieczeń.
Ułatwienia dostępu
Zadeklaruj interakcję z silnikami TTS w pliku manifestu
Ze względu na zmiany w widoczności pakietu aplikacje na Androida 11, które współpracują z silnikiem zamiany tekstu na mowę, muszą dodać do swoich plików manifestu element <queries>
:
<queries> <intent> <action android:name="android.intent.action.TTS_SERVICE" /> </intent> </queries>
Zadeklaruj użycie przycisku ułatwień dostępu w pliku metadanych
Szczegóły zmian
Zmień nazwę: REQUEST_ACCESSIBILITY_BUTTON_CHANGE
Identyfikator zmiany: 136293963
Jak przełączać
Podczas testowania zgodności aplikacji z Androidem 11 możesz włączyć lub wyłączyć tę zmianę, korzystając z tych poleceń ADB:
adb shell am compat enable (136293963|REQUEST_ACCESSIBILITY_BUTTON_CHANGE) PACKAGE_NAME
adb shell am compat disable (136293963|REQUEST_ACCESSIBILITY_BUTTON_CHANGE) PACKAGE_NAME
Więcej informacji o platformie zgodności i wyłączaniu zmian znajdziesz w artykule o testowaniu i debugowaniu zmian w działaniu platformy w aplikacji.
Począwszy od Androida 11 usługa ułatwień dostępu nie może deklarować w czasie działania aplikacji, że ma powiązanie z systemowym przyciskiem ułatwień dostępu. Jeśli dodasz AccessibilityServiceInfo.FLAG_REQUEST_ACCESSIBILITY_BUTTON
do właściwości flags
obiektu AccessibilityServiceInfo
, framework nie przekaże do usługi zdarzeń wywołania przycisku ułatwień dostępu.
Aby otrzymywać wywołania zwrotne dotyczące ułatwień dostępu w usłudze ułatwień dostępu, w pliku metadanych usługi ułatwień dostępu zadeklaruj powiązanie usługi z przyciskiem ułatwień dostępu. Uwzględnij wartość flagRequestAccessibilityButton
w definicji atrybutu accessibilityFlags
. Plik z metadanymi usługi ułatwień dostępu jest zwykle dostępny pod adresem res/raw/accessibilityservice.xml
.
Aparat
Działania związane z intencją multimediów wymagają domyślnego aparatu systemu
Od Androida 11 tylko wstępnie zainstalowane aplikacje aparatu mogą odpowiadać na te działania intencyjne:
android.media.action.VIDEO_CAPTURE
android.media.action.IMAGE_CAPTURE
android.media.action.IMAGE_CAPTURE_SECURE
Jeśli dostępnych jest kilka wstępnie zainstalowanych aplikacji aparatu, system wyświetli użytkownikowi okno dialogowe z prośbą o wybranie aplikacji. Jeśli chcesz, aby Twoja aplikacja używała konkretnej aplikacji aparatu innej firmy do wykonywania zdjęć lub nagrywania filmów w jej imieniu, możesz jawnie określić te intencje, ustawiając nazwę pakietu lub komponent dla danej intencji.
Pakowanie i instalowanie aplikacji
skompresowane pliki zasobów,
Szczegóły zmiany
Zmień nazwę: RESOURCES_ARSC_COMPRESSED
Identyfikator zmiany: 132742131
Jak włączyć lub wyłączyć
Podczas testowania zgodności aplikacji z Androidem 11 możesz włączyć lub wyłączyć tę zmianę, korzystając z tych poleceń ADB:
adb shell am compat enable (132742131|RESOURCES_ARSC_COMPRESSED) PACKAGE_NAME
adb shell am compat disable (132742131|RESOURCES_ARSC_COMPRESSED) PACKAGE_NAME
Więcej informacji o platformie zgodności i przełączanie zmian znajdziesz w artykule o testowaniu i debugowaniu zmian w działaniu platformy w aplikacji.
Aplikacje kierowane na Androida 11 (poziom interfejsu API 30) lub nowszego nie mogą być instalowane, jeśli zawierają skompresowany plik resources.arsc
lub jeśli ten plik nie jest wyrównany co 4 bajty. System nie może przypisać tego pliku do pamięci, jeśli spełniony jest jeden z tych warunków. Tabele zasobów, których nie można mapować w pamięci, muszą być odczytywane do bufora w pamięci RAM, co powoduje niepotrzebne obciążenie pamięci w systemie i znaczne zwiększenie wykorzystania pamięci RAM na urządzeniu.
Jeśli wcześniej używałeś/używałaś skompresowanego pliku resources.arsc
, wypróbuj alternatywne strategie, takie jak skracanie zasobów aplikacji lub inne metody skracania, zaciemniania i optymalizowania aplikacji.
Wymagany schemat podpisywania plików APK w wersji 2
Aplikacje przeznaczone na Androida 11 (poziom interfejsu API 30), które są obecnie podpisane tylko przy użyciu schematu podpisu APK w wersji 1, muszą być teraz podpisane też przy użyciu schematu podpisu APK w wersji 2 lub nowszej. Użytkownicy nie mogą instalować ani aktualizować aplikacji podpisanych tylko przy użyciu schematu podpisu w wersji 1 pliku APK na urządzeniach z Androidem 11.
Aby sprawdzić, czy aplikacja jest podpisana za pomocą schematu podpisu plików APK w wersji 2 lub nowszej, możesz użyć Android Studio lub narzędzia apksigner
w wierszu poleceń.
Firebase
Firebase JobDispatcher i GCMNetworkManager
Jeśli Twoja aplikacja jest kierowana na interfejs API na poziomie 30 lub wyższym, wywołania interfejsu Firebase JobDispatcher i GcmNetworkManager API są wyłączone na urządzeniach z Androidem 6.0 (poziom interfejsu API 23) lub nowszym. Informacje o migracji znajdziesz w artykułach Migracja z Firebase JobDispatcher do WorkManager i Migracja z GCMNetworkManager do WorkManager.
Rozpoznawanie mowy
Ze względu na zmiany w widoczności pakietu aplikacje na Androida 11, które współpracują z usługą rozpoznawania mowy, muszą dodać do plików manifestu element <queries>
:
<queries> <intent> <action android:name="android.speech.RecognitionService" /> </intent> </queries>
Zmiany wywołania zwrotnego w przypadku OnSharedPreferenceChangeListener
Szczegóły zmiany
Zmiana nazwy: CALLBACK_ON_CLEAR_CHANGE
Zmień identyfikator: 119147584
Jak włączyć lub wyłączyć
Podczas testowania zgodności aplikacji z Androidem 11 możesz włączyć lub wyłączyć tę zmianę, korzystając z tych poleceń ADB:
adb shell am compat enable (119147584|CALLBACK_ON_CLEAR_CHANGE) PACKAGE_NAME
adb shell am compat disable (119147584|CALLBACK_ON_CLEAR_CHANGE) PACKAGE_NAME
Więcej informacji o ramach zgodności i zmianach w przełączaniu znajdziesz w artykule Testowanie i debugowanie zmian w zachowaniu platformy w aplikacji.
W przypadku aplikacji kierowanych na Androida 11 (poziom API 30) wywołanie funkcji Editor.clear
powoduje wywołanie funkcji wywołania zwrotnego OnSharedPreferenceChangeListener.onSharedPreferenceChanged
z kluczem null
.
Ograniczenia interfejsu innego niż SDK
Android 11 zawiera zaktualizowane listy ograniczonych interfejsów innych niż SDK, które zostały opracowane we współpracy z deweloperami Androida i na podstawie najnowszych testów wewnętrznych. Zawsze, gdy to możliwe, sprawdzamy, czy dostępne są publiczne alternatywy, zanim zaczniemy ograniczać interfejsy inne niż SDK.
Jeśli Twoja aplikacja nie jest kierowana na Androida 11, niektóre z tych zmian mogą nie mieć na nią wpływu od razu. Mimo że obecnie można korzystać z niektórych interfejsów innych niż SDK (w zależności od docelowego poziomu interfejsu API aplikacji), użycie dowolnej metody lub pola spoza pakietu SDK zawsze wiąże się z dużym ryzykiem uszkodzenia aplikacji.
Jeśli nie masz pewności, czy Twoja aplikacja używa interfejsów innych niż SDK, możesz przetestować ją, aby się tego dowiedzieć. Jeśli Twoja aplikacja korzysta z interfejsów spoza pakietu SDK, zaplanuj migrację do alternatywnych pakietów SDK. Zdajemy sobie jednak sprawę, że w niektórych przypadkach interfejsy inne niż SDK mogą być przydatne. Jeśli nie możesz znaleźć alternatywy dla interfejsu spoza pakietu SDK, który jest używany w funkcji Twojej aplikacji, poproś o nowy publiczny interfejs API.
Więcej informacji o zmianach w tej wersji Androida znajdziesz w artykule Zmiany ograniczeń interfejsu niebędącego interfejsem pakietu SDK w Androidzie 11. Więcej informacji o interfejsach innych niż SDK znajdziesz w artykule Ograniczenia interfejsów innych niż SDK.