Zmiany w działaniu: aplikacje kierowane na Androida 11

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:

Łą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:

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 WorkManagerMigracja 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.