יצירה של קישורי עומק

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

במדריך הזה מוסבר איך קישורי עומק עובדים ואיך ליצור ולבדוק קישורי עומק לתוכן שלכם.

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

איך פועלים קישורי עומק

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

בזמן הריצה, כשהמשתמש מקיש על קישור, מערכת Android מפעילה intent ומנסה להפנות אותו לאפליקציה. מכיוון שכמה אפליקציות יכולות להצהיר על מסנני intent שתואמים ל-URI נתון, מערכת Android מבצעת את הפעולות הבאות, בסדר הזה, כדי להפנות את ה-intent:

  1. אם הוגדרה אפליקציית ברירת מחדל למשתמש שיכולה לטפל ב-URI, היא תיפתח.
  2. פותחים את האפליקציה היחידה שזמינה לטיפול ב-URI.
  3. המשתמש יכול לבחור אפליקציה מתיבת דו-שיח להסרת עמימות.

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

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

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

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

סוגים של קישורי עומק

יש שלושה סוגים של קישורי עומק שאפשר לתמוך בהם ב-Android:

  • קישורי עומק בהתאמה אישית: אלה קישורי עומק שמשתמשים בסכימת URI בהתאמה אישית (למשל example://products/123) כדי להעביר משתמש ישירות לחלק ספציפי בתוכן בתוך אפליקציה. הם שימושיים לניווט פנימי או לקישורים ממקורות שאתם שולטים בהם, אבל הם לא קישורים רגילים לאתרים, והם עדיין יכולים להפעיל את תיבת הדו-שיח לבחירת אפליקציה אם אפליקציה אחרת רושמת את אותה סכימה בהתאמה אישית.
  • קישורים לאתרים: אלה קישורי עומק שמשתמשים בסכמות הרגילות http ו-https. הם מגוונים יותר כי הם כתובות אתרים רגילות, אבל ב-Android 12 ואילך הם כמעט תמיד יפעילו את תיבת הדו-שיח לבחירת אפליקציה, כלומר סביר להניח שהם יטופלו על ידי דפדפן האינטרנט של המשתמש כברירת מחדל, במקום להיות מנותבים לאפליקציה שלכם.
  • קישורי עומק לאפליקציות: קישורי אינטרנט מאומתים שזמינים מגרסה Android 6.0 (רמת API‏ 23). באמצעות תהליך שיוך אתרים, אתם יכולים להוכיח למערכת Android שאתם הבעלים של הדומיין. אחרי האימות, המערכת מנתבת אוטומטית קישורים לדומיין הזה ישירות לאפליקציה, בלי להציג את תיבת הדו-שיח לבחירת אתר. כך אפשר ליצור חוויה חלקה ואמינה למשתמשים.

הוספת מסנני Intent לקישורים נכנסים

כדי ליצור קישור לתוכן באפליקציה, מוסיפים למניפסט מסנן Intent שמכיל את הרכיבים הבאים ואת ערכי המאפיינים הבאים:

<action>

מציינים את פעולת ה-Intent‏ ACTION_VIEW כדי שאפשר יהיה להגיע למסנן ה-Intent מחיפוש Google.

<data>

מוסיפים תג <data> אחד או יותר, שכל אחד מהם מייצג פורמט URI שמוביל לפעילות. לפחות, התג <data> צריך לכלול את המאפיין android:scheme.

אפשר להוסיף עוד מאפיינים כדי לדייק עוד יותר את סוג ה-URI שהפעילות מקבלת. לדוגמה, יכול להיות שיש לכם כמה פעילויות שמקבלות כתובות URI דומות, אבל שונות בנתיב. במקרה כזה, צריך להשתמש במאפיין android:path או בוריאציות שלו pathPattern או pathPrefix כדי להבחין בין הפעילויות שהמערכת צריכה לפתוח עבור נתיבי URI שונים.

<category>

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

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

קטע ה-XML הבא מראה איך אפשר לציין מסנן Intent במניפסט לקישורי עומק. כתובות ה-URI‏ "example://gizmos" ו-"http://www.example.com/gizmos" מפנות לפעילות הזו.

<activity
    android:name="com.example.android.GizmosActivity"
    android:label="@string/title_gizmos" >
    <intent-filter android:label="@string/filter_view_http_gizmos">
        <action android:name="android.intent.action.VIEW" />
        <category android:name="android.intent.category.DEFAULT" />
        <category android:name="android.intent.category.BROWSABLE" />
        <!-- Accepts URIs that begin with "http://www.example.com/gizmos" -->
        <data android:scheme="http"
              android:host="www.example.com"
              android:pathPrefix="/gizmos" />
        <!-- note that the leading "/" is required for pathPrefix-->
    </intent-filter>
    <intent-filter android:label="@string/filter_view_example_gizmos">
        <action android:name="android.intent.action.VIEW" />
        <category android:name="android.intent.category.DEFAULT" />
        <category android:name="android.intent.category.BROWSABLE" />
        <!-- Accepts URIs that begin with "example://gizmos" -->
        <data android:scheme="example"
              android:host="gizmos" />
    </intent-filter>
</activity>

שימו לב ששני מסנני Intent שונים רק באלמנט <data>. למרות שאפשר לכלול כמה אלמנטים <data> באותו מסנן, חשוב ליצור מסננים נפרדים כשרוצים להצהיר על כתובות URL ייחודיות (כמו שילוב ספציפי של scheme ו-host), כי כמה אלמנטים <data> באותו מסנן Intent בעצם מתמזגים כדי להתייחס לכל הווריאציות של המאפיינים המשולבים שלהם. לדוגמה:

<intent-filter>
  ...
  <data android:scheme="https" android:host="www.example.com" />
  <data android:scheme="app" android:host="open.my.app" />
</intent-filter>

יכול להיות שנדמה שהתכונה הזו תומכת רק ב-https://www.example.com וב-app://open.my.app. אבל בפועל הוא תומך בשני אלה, בנוסף לאלה: app://www.example.com ו-https://open.my.app.

אחרי שמוסיפים למניפסט של האפליקציה מסנני Intent עם מזהי URI של תוכן פעילות, מערכת Android יכולה לנתב כל Intent עם מזהי URI תואמים לאפליקציה בזמן הריצה.

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

קריאת נתונים מכוונות נכנסות

אחרי שהמערכת מתחילה את הפעילות באמצעות מסנן Intent, אפשר להשתמש בנתונים שסופקו על ידי Intent כדי לקבוע מה צריך לעבד. צריך להפעיל את השיטות getData() ו-getAction() כדי לאחזר את הנתונים ואת הפעולה שמשויכים ל-Intent הנכנס. אפשר להפעיל את השיטות האלה בכל שלב במחזור החיים של הפעילות, אבל בדרך כלל כדאי לעשות את זה במהלך קריאות חוזרות מוקדמות כמו onCreate() או onStart.

בקטע הקוד הבא אפשר לראות איך מאחזרים נתונים מ-Intent:

Kotlin

override fun onCreate(savedInstanceState: Bundle?) {
    super.onCreate(savedInstanceState)
    setContentView(R.layout.main)

    val action: String? = intent?.action
    val data: Uri? = intent?.data
}

Java

@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);

    Intent intent = getIntent();
    String action = intent.getAction();
    Uri data = intent.getData();
}

כדי לשפר את חוויית המשתמש, כדאי לפעול לפי השיטות המומלצות הבאות:

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

בדיקה של קישורי העומק

אתם יכולים להשתמש בממשק הגישור של Android‏ (ADB) עם הכלי לניהול פעילויות (am) כדי לבדוק שכתובות ה-URI של מסנן ה-Intent שציינתם לקישורי עומק מפנות לפעילות הנכונה באפליקציה. אתם יכולים להריץ את פקודת ה-adb במכשיר או באמולטור.

התחביר הכללי לבדיקת URI של מסנן Intent באמצעות adb הוא:

$ adb shell am start
        -W -a android.intent.action.VIEW
        -d <URI> <PACKAGE>

לדוגמה, הפקודה הבאה מנסה להציג פעילות של אפליקציית יעד שמשויכת ל-URI שצוין.

$ adb shell am start
        -W -a android.intent.action.VIEW
        -d "example://gizmos" com.example.android

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

מידע נוסף על כוונות וקישורים לאפליקציות זמין במקורות המידע הבאים: