Kompilowanie aplikacji platformy Xamarin dla systemu iOS
Ważne
Program Visual Studio App Center ma zostać wycofany 31 marca 2025 r. Mimo że możesz nadal używać programu Visual Studio App Center do momentu jej pełnego wycofania, istnieje kilka zalecanych alternatyw, do których można rozważyć migrację.
Dowiedz się więcej o osiach czasu pomocy technicznej i alternatywach.
Uwaga
Obsługiwane wersje i wymagania w usłudze App Center obsługują projekty Portable Class Library (PCL) i .NET Standard . Zapoznaj się z tematem Cloud Build Machines for versions of .NET Standard ( Maszyny kompilacji w chmurze ), aby zapoznać się z wersjami platformy .NET Standard. Usługa App Center nie obsługuje składników ze sklepu składników Xamarin i zalecamy korzystanie z pakietów NuGet zawsze, gdy są dostępne. Jeśli używasz składnika, którego nie można zamienić, skontaktuj się z nami. Zobacz pomoc i opinie.
Aby rozpocząć tworzenie pierwszej aplikacji platformy Xamarin dla systemu iOS, należy wykonać następujące kroki:
- Połącz się z kontem usługi repozytorium (GitHub, Bitbucket, VSTS, Azure DevOps).
- Wybierz repozytorium i gałąź, w której znajduje się aplikacja.
- Skonfiguruj projekt lub obszar roboczy kompilacji oraz schemat, który chcesz skompilować.
Uwaga
Aby aplikacja działała na rzeczywistym urządzeniu, kompilacja musi być podpisana kodem z prawidłowym profilem aprowizacji i certyfikatem.
1. Łączenie repozytorium
Jeśli wcześniej nie nawiązaliśmy połączenia z kontem usługi repozytorium, musisz nawiązać z nim połączenie. Po nawiązaniu połączenia konta wybierz repozytorium, w którym znajduje się projekt systemu iOS. Aby skonfigurować kompilację dla repozytorium, musisz mieć uprawnienia administratora i ściągania.
2. Wybieranie gałęzi
Po wybraniu repozytorium wybierz gałąź, którą chcesz skompilować. Domyślnie zostaną wyświetlone wszystkie aktywne gałęzie.
3. Konfigurowanie pierwszej kompilacji
Przed pierwszą kompilacją należy skonfigurować projekt Xamarin.
3.1. Projekt/rozwiązanie
Usługa App Center automatycznie wykrywa pliki rozwiązania i projektu w repozytorium, jeśli znajdują się one w zakresie analizy. Wybierz .sln lub csproj/.fsproj , które chcesz skompilować.
Uwaga
Aby uzyskać najlepszą wydajność, analiza jest obecnie ograniczona do dwóch poziomów katalogu dla .sln i czterech poziomów katalogów dla pliku csproj/fsproj , w tym katalogu głównego repozytorium.
3.1.1. Kompilowanie z pliku rozwiązania (.sln)
W kodzie pamiętaj, aby wyłączyć projekty systemu Android i platformy UWP dla konfiguracji kompilacji przeznaczonych dla kompilacji systemu iOS: przejdź do mapowań konfiguracji rozwiązania i dla wszystkich mapowań przeznaczonych dla urządzeń iPhone i iPhoneSimulator, usuń zaznaczenie wszystkich projektów przeznaczonych dla innych platform. Ta zmiana zapewni, że po utworzeniu .sln nie podejmie próby skompilowania innych projektów. Istnieje więcej informacji o mapowaniu konfiguracji rozwiązań , które można przeczytać.
3.1.2. Kompilowanie z pliku projektu (.csproj/.fsproj)
Aby skompilować plik csproj/.fsproj , wszystkie przywołyzowane projekty (na przykład projekt PCL) muszą zawierać konfigurację o takiej samej nazwie jak projekt źródłowy systemu iOS. Dlatego jeśli uruchomisz konfigurację debugowania dla symulatora w usłudze App Center, projekt PCL musi mieć konfigurację Debug|iPhoneSimulator . W przypadku, gdy nie istnieją i aby zapobiec dalszym błędom, dodamy takie konfiguracje przed utworzeniem projektów. Te konfiguracje mają podstawowe ustawienia domyślne tylko dla debugowania i wydania.
3.2. Konfigurowanie
Wybierz konfigurację, z którą chcesz utworzyć. Konfiguracje są wykrywane automatycznie w zależności od pliku źródłowego wybranego w poprzednim kroku.
3.3. Wersja mono
Usługa App Center umożliwia korzystanie z różnych środowisk Mono dołączonych do odpowiedniego zestawu SDK platformy Xamarin.iOS dla kompilacji w celu zachowania zgodności z poprzednimi wersjami podczas wydawania obsługi nowych funkcji. Domyślną konfiguracją mono dla nowej gałęzi będzie najnowsza stabilna. Możesz użyć jednego z poprzednich środowisk Mono do tworzenia starszych wersji platform lub bibliotek. Po wybraniu innej wersji mono zobaczysz wersję zestawu SDK platformy Xamarin.iOS, która jest dołączona do niego. Aby śledzić aktualizacje wersji zestawu Xamarin SDK, możesz przeczytać wpisy w blogu wydania platformy Xamarin.
3.3.1. Wersja platformy .NET
Właściwa wersja platformy .NET zostanie wybrana automatycznie na podstawie wersji platformy Xamarin.iOS używanej do kompilacji i nie można jej zastąpić. Mapowanie platformy Xamarin.iOS można wyświetlić na platformie .NET używanej przez nasze usługi w poniższej tabeli:
Xamarin.iOS | .NET |
---|---|
13.20 | 3.1.401 |
14,0 | 3.1.401 |
14,2 | 3.1.401 |
14,4 | 3.1.401 |
14.6 | 5.0.100 |
14,8 | 5.0.100 |
14.10 | 5.0.100 |
14.14 | 5.0.100 |
14.16 | 5.0.100 |
14.20 | 5.0.100 |
15 | 5.0.100 |
15,2 | 5.0.100 |
15,4 | 5.0.100 |
15,6 | 5.0.100 |
15.8 | 5.0.100 |
15.10 | 5.0.100 |
15.12 | 5.0.100 |
16.0 | 5.0.100 |
16.0 (.NET 6) | 6.0.405 |
16.1 | 6.0.405 |
16,2 | 6.0.405 |
3.4. Wersja programu Xcode
Obecnie obsługiwane wersje platformy Xamarin wymagają środowiska Xcode 11.7 lub nowszego
3.5. Wyzwalacze kompilacji
Domyślnie nowa kompilacja jest wyzwalana za każdym razem, gdy deweloper wypycha do skonfigurowanej gałęzi. Jeśli wolisz ręcznie wyzwolić nową kompilację, możesz zmienić to ustawienie w okienku konfiguracji.
3.6. Kompilacja symulatora
Kompilacje symulatora można uruchamiać tylko w symulatorach i nie można ich zainstalować na urządzeniu, ale kompilacje są ukończone szybciej niż kompilacje urządzeń. Jeśli kompilacja nie jest kompilacją symulatora, musisz przekazać pliki podpisywania kodu w następnym kroku.
3.7. Numer kompilacji przyrostowej
Po włączeniu w CFBundleVersion
pliku Info.plist aplikacji automatycznie zwiększa się dla każdej kompilacji. Zmiana jest wykonywana przed kompilacją i nie zostanie zatwierdzona w repozytorium.
3.8. Podpisywanie kodu
Pomyślna kompilacja urządzenia spowoduje utworzenie pliku IPA. Aby zainstalować kompilację na urządzeniu, należy ją podpisać przy użyciu prawidłowego profilu aprowizacji i certyfikatu. Aby podpisać kompilacje utworzone z gałęzi, włącz podpisywanie kodu w okienku konfiguracji i przekaż profil aprowizacji () oraz prawidłowy certyfikat (.mobileprovision
.p12
) wraz z hasłem dla certyfikatu. Więcej informacji na temat podpisywania kodu i aprowizacji urządzeń aplikacji platformy Xamarin dla systemu iOS można uzyskać w dokumentacji platformy Xamarin.
Aplikacje z rozszerzeniami aplikacji lub systemu watchOS wymagają podpisania dodatkowego profilu aprowizacji dla każdego rozszerzenia.
Uwaga
Podczas uruchamiania nuget restore
w projektach zawierających aplikacje Xamarin watchOS występuje istniejący problem.
Utworzenie aplikacji systemu watchOS w usłudze App Center bez obejścia spowoduje wystąpienie błędu:
Project <project> is not compatible with xamarinios10 (Xamarin.iOS,Version=v1.0) / win-x86. Project <project> supports: xamarinwatchos10 (Xamarin.WatchOS,Version=v1.0)
.
Aby tworzyć aplikacje systemu watchOS w usłudze App Center, wymagane jest obejście problemu. W projekcie zawierającym system iOS, który odwołuje się do aplikacji do obejrzenia, należy uwzględnić dodatkowy wiersz:
<ReferenceOutputAssembly>False</ReferenceOutputAssembly>
Przykładowa dokumentacja aplikacji WatchApp z obejściem:
<ProjectReference Include="..\MyWatchApp\MyWatchApp.csproj">
<Project>{59EB034F-3D29-43A5-B89F-124879504771}</Project>
<Name>MyWatchApp</Name>
<IsWatchApp>True</IsWatchApp>
<ReferenceOutputAssembly>False</ReferenceOutputAssembly>
</ProjectReference>
3.9. Uruchamianie pomyślnej kompilacji na rzeczywistym urządzeniu
Użyj nowo utworzonego pliku ipa, aby sprawdzić, czy aplikacja zostanie uruchomiona na rzeczywistym urządzeniu. Uruchamianie testowania dodaje około 10 minut do czasu kompilacji. Warto zapoznać się z bardziej kompleksowym przewodnikiem dotyczącym testowania kompilacji
3.10. Przywracanie nuGet
Jeśli plik NuGet.config jest zaewidencjonowany dla repozytorium i znajduje się obok .sln lub poziomu głównego repozytorium, centrum aplikacji przywraca prywatne źródła danych NuGet po dodaniu, jak pokazano w poniższym przykładzie. Poświadczenia można bezpiecznie dodać przy użyciu zmiennych środowiskowych:
<?xml version="1.0" encoding="utf-8"?>
<configuration>
<packageSources>
<add key="nuget" value="https://api.nuget.org/v3/index.json" />
<add key="MyGet" value="https://www.myget.org/F/MyUsername/api/v2/index.json" />
<add key="MyAuthNuget" value="https://nuget.example.com/v2/index.json" />
</packageSources>
<activePackageSource>
<add key="All" value="(Aggregate source)" />
</activePackageSource>
<packageSourceCredentials>
<MyAuthNuget>
<add key="Username" value="$USER_VARIABLE" />
<add key="ClearTextPassword" value="$PASSWORD_VARIABLE" />
</MyAuthNuget>
</packageSourceCredentials>
</configuration>
Jeśli masz złożone konfiguracje i potrzebujesz więcej informacji, zapoznaj się z tematem Konfigurowanie zachowania narzędzia NuGet.
3.11. Dystrybuowanie do grupy dystrybucyjnej
Można skonfigurować każdą pomyślną kompilację z gałęzi, która ma być dystrybuowana do wcześniej utworzonej grupy dystrybucyjnej. Nową grupę dystrybucyjną można dodać z sekcji Dystrybucja. Zawsze istnieje domyślna grupa dystrybucyjna o nazwie "Współpracownicy", która obejmuje wszystkich użytkowników, którzy mają dostęp do aplikacji.
Po zapisaniu konfiguracji zostanie automatycznie uruchomiona nowa kompilacja.
4. Wyniki kompilacji
Po wyzwoleniu kompilacji może ona znajdować się w następujących stanach:
- queued — kompilacja znajduje się w kolejce oczekującej na zwolnienie zasobów.
- building — kompilacja jest uruchomiona i wykonuje wstępnie zdefiniowane zadania.
- succeeded — kompilacja została ukończona pomyślnie.
- failed — kompilacja została zatrzymana z powodu błędu. Aby rozwiązać problemy, możesz pobrać i sprawdzić dziennik kompilacji.
- canceled — kompilacja została anulowana przez akcję użytkownika lub upłynął limit czasu.
4.1. Dzienniki kompilacji
W przypadku ukończonej kompilacji (zakończonej powodzeniem lub niepowodzeniem) pobierz dzienniki, aby dowiedzieć się więcej na temat sposobu działania kompilacji. Usługa App Center udostępnia archiwum z następującymi plikami:
|-- 1_build.txt (this is the general build log)
|-- build (this folder contains a separate log file for each build step)
|-- <build-step-1> (e.g. 2_Get Sources.txt)
|-- <build-step-2> (e.g. 3_Pod install.txt)
|--
|-- <build-step-n> (e.g. n_Post Job Cleanup.txt)
Dzienniki specyficzne dla kroków kompilacji (znajdujące się w build/
katalogu archiwum) są przydatne do rozwiązywania problemów i zrozumienia, w jakim kroku i dlaczego kompilacja nie powiodła się.
4.2. Aplikacja (.ipa
lub .app
)
Jest .ipa
to plik archiwum aplikacji systemu iOS, który zawiera aplikację systemu iOS. Jeśli kompilacja została poprawnie podpisana, .ipa
można ją zainstalować na rzeczywistym urządzeniu odpowiadającym profilowi aprowizacji używanemu podczas podpisywania. Więcej szczegółowych informacji na temat podpisywania i dystrybucji kodu można znaleźć w Centrum aplikacji.
Jeśli aplikacja jest kompilacją symulatora, możesz uruchomić .app
plik w symulatorze, ale nie można go używać na rzeczywistym urządzeniu.
4.3. Pliki symboli (.dsym)
Pliki symboli są generowane tylko dla kompilacji urządzenia. Pliki .dsym zawierają symbole debugowania dla aplikacji.
- Jeśli wcześniej zintegrowano zestaw SDK centrum aplikacji w aplikacji z włączonym modułem raportowania awarii, usługa raportowania awarii wymaga tego
.dsym
pliku dla kompilacji do wyświetlania raportów awarii możliwych do odczytania przez człowieka (symboliczne). - Jeśli wcześniej zintegrowano inny zestaw SDK na potrzeby raportowania awarii w aplikacji (na przykład zestaw SDK usługi HockeyApp), odpowiednia usługa wymaga
.dsym
pliku do wyświetlania raportów awarii możliwych do odczytania przez człowieka.