מדריך לשילוב

כדי להגדיר פעילות אינטרנט מהימנה, המפתחים לא צריכים לכתוב קוד Java, אבל נדרש Android Studio. המדריך הזה נוצר באמצעות Android Studio 3.3. כאן מוסבר איך להתקין אותו.

יצירת פרויקט של Trusted Web Activity

כשמשתמשים ב-Trusted Web Activities, הפרויקט חייב לטרגט ל-API 16 ואילך.

פותחים את Android Studio ולוחצים על Start a new Android Studio project (התחלת פרויקט חדש ב-Android Studio).

ב-Android Studio תופיע בקשה לבחור סוג פעילות. מאחר ש-Trusted Web Activities משתמשת בפעילות שסופקה על ידי ספריית התמיכה, בוחרים באפשרות Add No Activity ולוחצים על Next.

בשלב הבא, האשף יבקש להגדיר את הפרויקט. הנה תיאור קצר של כל שדה:

  • שם: השם שישמש את האפליקציה ב-Android Launcher.
  • שם החבילה: מזהה ייחודי של אפליקציות ל-Android בחנות Play ובמכשירי Android. בתיעוד מפורט מידע נוסף על הדרישות והשיטות המומלצות ליצירת שמות חבילות לאפליקציות ל-Android.
  • מיקום השמירה: המיקום במערכת הקבצים שבו Android Studio תיצור את הפרויקט.
  • שפה: לא צריך לכתוב קוד Java או Kotlin בפרויקט. בוחרים ב-Java כברירת מחדל.
  • רמת API מינימלית: כדי להשתמש ב-Support Library נדרשת לפחות רמת API 16. בוחרים ב-API 16 וכל גרסה ואילך.

משאירים את התיבות הנותרות לא מסומנות, כי לא נשתמש באפליקציות ללא התקנה או ב-artifacts של AndroidX, ולוחצים על Finish.

הורדת ספריית התמיכה של Trusted Web Activity

כדי להגדיר את הספרייה Trusted Web Activity בפרויקט, צריך לערוך את קובץ ה-build של האפליקציה. מחפשים את הקטע Gradle Scripts בProject Navigator. יש שני קבצים שנקראים build.gradle, ויכול להיות שזה קצת מבלבל. התיאורים בסוגריים עוזרים לזהות את הקובץ הנכון.

הקובץ שאנחנו מחפשים הוא זה עם המודול Module לצד השם שלו.

בספריית Trusted Web Activities נעשה שימוש בתכונות של Java 8, והשינוי הראשון מאפשר את השימוש ב-Java 8. מוסיפים קטע compileOptions לתחתית הקטע android, כפי שמתואר בהמשך:

android {
        ...
    compileOptions {
       sourceCompatibility JavaVersion.VERSION_1_8
       targetCompatibility JavaVersion.VERSION_1_8
    }
}

בשלב הבא נוסיף לפרויקט את ספריית התמיכה בפעילות מהימנה באינטרנט. מוסיפים יחסי תלות חדשים לקטע dependencies:

dependencies {
    implementation 'com.google.androidbrowserhelper:androidbrowserhelper:2.2.0'
}

ב-Android Studio תוצג בקשה לסנכרן את הפרויקט שוב. לוחצים על הקישור סנכרון עכשיו ומבצעים סנכרון.

הפעלת הפעילות Trusted Web

כדי להגדיר את הפעילות המאומתת באינטרנט, עורכים את Android App Manifest.

ב-Project Navigator, מרחיבים את הקטע app ואז את הקטע manifests ולוחצים לחיצה כפולה על AndroidManifest.xml כדי לפתוח את הקובץ.

מכיוון שביקשנו מ-Android Studio לא להוסיף פעילות לפרויקט בזמן היצירה שלו, המניפסט ריק ומכיל רק את תג האפליקציה.

כדי להוסיף את פעילות האינטרנט המהימנה, מוסיפים תג activity לתג application:

<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    package="com.example.twa.myapplication">

    <application
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:roundIcon="@mipmap/ic_launcher_round"
        android:supportsRtl="true"
        android:theme="@style/AppTheme"
        tools:ignore="GoogleAppIndexingWarning">
        <activity
            android:name="com.google.androidbrowserhelper.trusted.LauncherActivity">

           <!-- Edit android:value to change the url opened by the Trusted Web Activity -->
           <meta-data
               android:name="android.support.customtabs.trusted.DEFAULT_URL"
               android:value="https://airhorner.com" />

           <!-- This intent-filter adds the Trusted Web Activity to the Android Launcher -->
           <intent-filter>
               <action android:name="android.intent.action.MAIN" />
               <category android:name="android.intent.category.LAUNCHER" />
           </intent-filter>

           <!--
             This intent-filter allows the Trusted Web Activity to handle Intents to open
             airhorner.com.
           -->
           <intent-filter>
               <action android:name="android.intent.action.VIEW"/>
               <category android:name="android.intent.category.DEFAULT" />
               <category android:name="android.intent.category.BROWSABLE"/>

               <!-- Edit android:host to handle links to the target URL-->
               <data
                 android:scheme="https"
                 android:host="airhorner.com"/>
           </intent-filter>
        </activity>
    </application>
</manifest>

התגים שנוספו לקובץ ה-XML הם Android App Manifest רגילים. יש שני פרטי מידע רלוונטיים להקשר של 'פעילויות אינטרנט מהימנות':

  1. התג meta-data מציין ל-Trusted Web Activity איזו כתובת URL צריך לפתוח. משנים את המאפיין android:value בכתובת ה-URL של אפליקציית ה-PWA שרוצים לפתוח. בדוגמה הזו, זהו https://airhorner.com.
  2. התג intent-filter השני מאפשר ל-Trusted Web Activity ליירט כוונות (Intents) של Android שפותחות את https://airhorner.com. המאפיין android:host בתוך התג data חייב להפנות לדומיין שנפתח על ידי Trusted Web Activity.

בקטע הבא נסביר איך להגדיר Digital Asset Links כדי לאמת את הקשר בין האתר לאפליקציה ולהסיר את סרגל כתובות ה-URL.

הסרת סרגל כתובות ה-URL

כדי להסיר את סרגל כתובות ה-URL, צריך ליצור שיוך בין אפליקציית Android לבין האתר בפעילות באינטרנט מהימנה.

השיוך הזה נוצר באמצעות Digital Asset Links, וצריך ליצור אותו בשני הכיוונים: קישור מהאפליקציה לאתר וקישור מהאתר לאפליקציה.

אפשר להגדיר את האפליקציה לאימות אתר ולהגדיר את Chrome לדלג על האימות באתר ולעבור לאימות האפליקציה, למטרות ניפוי באגים.

פותחים את קובץ המשאבים של המחרוזות app > res > values > strings.xml ומוסיפים את ההצהרה הבאה של Digital Asset Links:

<resources>
    <string name="app_name">AirHorner Trusted Web Activity</string>
    <string name="asset_statements">
        [{
            \"relation\": [\"delegate_permission/common.handle_all_urls\"],
            \"target\": {
                \"namespace\": \"web\",
                \"site\": \"https://airhorner.com\"}
        }]
    </string>
</resources>

משנים את התוכן של המאפיין site כך שיתאים לסכימה ולדומיין שנפתחים על ידי Trusted Web Activity.

חוזרים לקובץ Android App Manifest, ‏ AndroidManifest.xml, ומקשרים להצהרה על ידי הוספת תג meta-data חדש, אבל הפעם כצאצא של התג application:

<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.twa.myapplication">

    <application
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:roundIcon="@mipmap/ic_launcher_round"
        android:supportsRtl="true"
        android:theme="@style/AppTheme">

        <meta-data
            android:name="asset_statements"
            android:resource="@string/asset_statements" />

        <activity>
            ...
        </activity>

    </application>
</manifest>

עכשיו יצרנו קשר בין האפליקציה ל-Android לאתר. מומלץ לנפות באגים בחלק הזה של הקשר בלי ליצור את האימות של האתר לאפליקציה.

כך בודקים את זה במכשיר פיתוח:

הפעלה של מצב ניפוי באגים

  1. פותחים את Chrome במכשיר הפיתוח, עוברים אל chrome://flags, מחפשים את הפריט Enable command line on non-rooted devices ומשנים אותו ל-ENABLED. לאחר מכן מפעילים מחדש את הדפדפן.
  2. לאחר מכן, באפליקציית הטרמינל של מערכת ההפעלה, משתמשים ב-Android Debug Bridge (שמתקינים עם Android Studio) ומריצים את הפקודה הבאה:
adb shell "echo '_ --disable-digital-asset-link-verification-for-url=\"https://airhorner.com\"' > /data/local/tmp/chrome-command-line"

סוגרים את Chrome ופותחים מחדש את האפליקציה מ-Android Studio. האפליקציה אמורה להופיע עכשיו במסך מלא.

כדי ליצור את השיוך, המפתח צריך לאסוף מהאפליקציה שני פרטי מידע:

  • שם החבילה: המידע הראשון הוא שם החבילה של האפליקציה. זהו אותו שם חבילה שנוצר כשיצרתם את האפליקציה. אפשר למצוא אותו גם במודול build.gradle, בקטע Gradle Scripts‏ > build.gradle (Module: app), והוא הערך של המאפיין applicationId.
  • טביעת אצבע SHA-256: כדי להעלות אפליקציות ל-Android לחנות Play, עליהן להיות חתומות. אותו החתימה משמש ליצירת החיבור בין האתר לאפליקציה באמצעות טביעת האצבע SHA-256 של מפתח ההעלאה.

במסמכי התיעוד של Android מוסבר בפירוט איך ליצור מפתח באמצעות Android Studio. חשוב לשים לב לנתיב, לכתובת החלופית ולסיסמאות של מאגר המפתחות, כי תצטרכו אותם בשלב הבא.

מחלצים את טביעת האצבע מסוג SHA-256 באמצעות keytool, באמצעות הפקודה הבאה:

keytool -list -v -keystore [path] -alias [alias] -storepass [password] -keypass [password]

הערך של טביעת האצבע מסוג SHA-256 מודפס בקטע טביעות אצבע של אישורים. דוגמה לפלט:

keytool -list -v -keystore ./mykeystore.ks -alias test -storepass password -keypass password

Alias name: key0
Creation date: 28 Jan 2019
Entry type: PrivateKeyEntry
Certificate chain length: 1
Certificate[1]:
Owner: CN=Test Test, OU=Test, O=Test, L=London, ST=London, C=GB
Issuer: CN=Test Test, OU=Test, O=Test, L=London, ST=London, C=GB
Serial number: ea67d3d
Valid from: Mon Jan 28 14:58:00 GMT 2019 until: Fri Jan 22 14:58:00 GMT 2044
Certificate fingerprints:
   SHA1: 38:03:D6:95:91:7C:9C:EE:4A:A0:58:43:A7:43:A5:D2:76:52:EF:9B
   SHA256: F5:08:9F:8A:D4:C8:4A:15:6D:0A:B1:3F:61:96:BE:C7:87:8C:DE:05:59:92:B2:A3:2D:05:05:A5:62:A5:2F:34
Signature algorithm name: SHA256withRSA
Subject Public Key Algorithm: 2048-bit RSA key
Version: 3

אחרי שמקבלים את שני קטעי המידע, עוברים אל הכלי ליצירת קישורי asset, ממלאים את השדות ולוחצים על Generate Statement (יצירת הצהרה). מעתיקים את ההצהרה שנוצרה ומציגים אותה מהדומיין שלכם, מכתובת ה-URL /.well-known/assetlinks.json.

יצירת סמל

כשאתם יוצרים פרויקט חדש ב-Android Studio, הוא מגיע עם סמל ברירת מחדל. כמפתחים, כדאי ליצור סמל משלכם כדי להבדיל את האפליקציה שלכם מאחרות במרכז האפליקציות של Android.

Android Studio מכיל את Image Asset Studio, שמספק את הכלים הדרושים ליצירת הסמלים המתאימים לכל רזולוציה ולצורכי האפליקציה שלכם.

ב-Android Studio, עוברים אל File > New > Image Asset, בוחרים באפשרות Launcher Icons (Adaptative and Legacy) ופועלים לפי השלבים במדריך כדי ליצור סמל מותאם אישית לאפליקציה.

יצירת קובץ APK חתום

אחרי שמוסיפים את הקובץ assetlinks לדומיין ומגדירים את התג asset_statements באפליקציה ל-Android, השלב הבא הוא יצירת אפליקציה חתומה. שוב, יש תיעוד נרחב לגבי השלבים האלה.

אפשר להתקין את קובץ ה-APK של הפלט במכשיר בדיקה באמצעות adb:

adb install app-release.apk

אם שלב האימות נכשל, אפשר לבדוק אם יש הודעות שגיאה באמצעות Android Debug Bridge, מהמסוף של מערכת ההפעלה כשמכשיר הבדיקה מחובר.

adb logcat | grep -e OriginVerifier -e digital_asset_links

עכשיו, אחרי שיצרתם את קובץ ה-APK להעלאה, אתם יכולים להעלות את האפליקציה לחנות Play.

הוספת מסך פתיחה

החל מגרסה 75 של Chrome, יש תמיכה במסכי הפתיחה בפעילויות Trusted Web. כדי להגדיר את מסך הפתיחה, מוסיפים כמה קובצי תמונות והגדרות חדשים לפרויקט.

חשוב לעדכן את הדפדפן ל-Chrome 75 ואילך ולהשתמש בגרסה האחרונה של Trusted Web Activity Support Library.

יצירת התמונות של מסך הפתיחה

למכשירי Android יכולים להיות גדלי מסך ודחיסות פיקסלים שונים. כדי להבטיח שתמונת הרקע תיראה טוב בכל המכשירים, תצטרכו ליצור את התמונה לכל צפיפות פיקסלים.

הסבר מלא על פיקסלים שאינם תלויים במסך (dp או dip) חורג מהיקף המאמר הזה, אבל דוגמה אחת היא יצירת תמונה בגודל 320x320dp, שמייצגת ריבוע בגודל 2x2 אינץ' במסך של מכשיר בכל צפיפות, ושווה ערך ל-320x320 פיקסלים בצפיפות mdpi.

על סמך הנתונים האלה, אנחנו יכולים להסיק את הגדלים הנדרשים לדחיסות פיקסלים אחרות. בהמשך מופיעה רשימה של צפיפות הפיקסלים, המכפיל שחלה על הגודל הבסיסי (320x320dp), הגודל שנוצר בפיקסלים והמיקום שבו צריך להוסיף את התמונה בפרויקט ב-Android Studio.

צפיפות מכפיל גודל מיקום הפרויקט
mdpi (baseline) 1.0x 320x320 פיקסלים /res/drawable-mdpi/
ldpi 0.75x 240x240 פיקסלים /res/drawable-ldpi/
hdpi 1.5x 480x480 פיקסלים /res/drawable-hdpi/
xhdpi 2.0x 640x640 פיקסלים /res/drawable-xhdpi/
xxhdpi 3.0x 960x960 פיקסלים /res/drawable-xxhdpi/
xxxhdpi 4.0x 1,280x1,280 פיקסלים /res/drawable-xxxhdpi/

עדכון האפליקציה

אחרי שיצרתם את התמונות של מסך הפתיחה, הגיע הזמן להוסיף את ההגדרות הנדרשות לפרויקט.

קודם מוסיפים content-provider למניפסט של Android‏ (AndroidManifest.xml).

<application>
    ...
    <provider
        android:name="androidx.core.content.FileProvider"
        android:authorities="com.example.twa.myapplication.fileprovider"
        android:grantUriPermissions="true"
        android:exported="false">
        <meta-data
            android:name="android.support.FILE_PROVIDER_PATHS"
            android:resource="@xml/filepaths" />
    </provider>
</application>

לאחר מכן, מוסיפים את המשאב res/xml/filepaths.xml ומציינים את הנתיב למסך הפתיחה של TWA:

<paths>
    <files-path path="twa_splash/" name="twa_splash" />
</paths>

לסיום, מוסיפים את meta-tags ל-Android Manifest כדי להתאים אישית את LauncherActivity:

<activity android:name="com.google.androidbrowserhelper.trusted.LauncherActivity">
    ...
    <meta-data android:name="android.support.customtabs.trusted.SPLASH_IMAGE_DRAWABLE"
               android:resource="@drawable/splash"/>
    <meta-data android:name="android.support.customtabs.trusted.SPLASH_SCREEN_BACKGROUND_COLOR"
               android:resource="@color/colorPrimary"/>
    <meta-data android:name="android.support.customtabs.trusted.SPLASH_SCREEN_FADE_OUT_DURATION"
               android:value="300"/>
    <meta-data android:name="android.support.customtabs.trusted.FILE_PROVIDER_AUTHORITY"
               android:value="com.example.twa.myapplication.fileprovider"/>
    ...
</activity>

חשוב לוודא שהערך של התג android.support.customtabs.trusted.FILE_PROVIDER_AUTHORITY תואם לערך המוגדר של המאפיין android:authorities בתוך התג provider.

הפיכת LauncherActivity לשקופה

בנוסף, כדי למנוע הצגת מסך לבן לפני האנימציה, צריך להגדיר ל-LauncherActivity עיצוב שקוף:

<application>
    ...
    <activity android:name="com.google.androidbrowserhelper.trusted.LauncherActivity"
              android:theme="@android:style/Theme.Translucent.NoTitleBar">
    ...
    </activity>
</application>

אנחנו סקרנים לראות מה המפתחים ייצרו באמצעות Trusted Web Activities. כדי לשלוח משוב, אפשר לפנות אלינו בכתובת ‎@ChromiumDev.