เมื่อลิงก์ที่คลิกหรือคําขอแบบเป็นโปรแกรมเรียกใช้ Intent URI ของเว็บ ระบบ Android จะพยายามดําเนินการต่อไปนี้ทีละรายการตามลําดับจนกว่าคําขอจะสําเร็จ
- เปิดแอปที่ผู้ใช้ต้องการซึ่งจัดการ URI ได้ หากมีการกำหนดไว้
- เปิดแอปเดียวที่พร้อมใช้งานซึ่งจัดการ URI ได้
- อนุญาตให้ผู้ใช้เลือกแอปจากกล่องโต้ตอบ
ทำตามขั้นตอนด้านล่างเพื่อสร้างและทดสอบลิงก์ไปยังเนื้อหา นอกจากนี้ คุณยังใช้ App Links Assistant ใน Android Studio เพื่อเพิ่ม Android App Link ได้ด้วย
หมายเหตุ: ตั้งแต่ Android 12 (API ระดับ 31) เป็นต้นไป อินเทนต์ของเว็บทั่วไปจะแก้ไขเป็นกิจกรรมในแอปก็ต่อเมื่อแอปได้รับอนุมัติสำหรับโดเมนที่เฉพาะเจาะจงซึ่งมีอยู่ในอินเทนต์ของเว็บนั้น หากแอปไม่ได้รับอนุมัติสำหรับโดเมนดังกล่าว อินเทนต์ของเว็บจะแก้ไขแอปเบราว์เซอร์เริ่มต้นของผู้ใช้แทน
เพิ่มตัวกรอง Intent สําหรับลิงก์ขาเข้า
หากต้องการสร้างลิงก์ไปยังเนื้อหาแอป ให้เพิ่มตัวกรอง Intent ที่มีองค์ประกอบและค่าแอตทริบิวต์ต่อไปนี้ในไฟล์ Manifest
<action>
- ระบุการดำเนินการผ่าน Intent ของ
ACTION_VIEW
เพื่อให้เข้าถึงตัวกรอง Intent ได้จาก Google Search <data>
- เพิ่มแท็ก
<data>
อย่างน้อย 1 รายการ โดยแต่ละแท็กจะแสดงรูปแบบ URI ที่แก้ไขเป็นกิจกรรม แท็ก<data>
ต้องมีแอตทริบิวต์android:scheme
เป็นอย่างน้อยคุณสามารถเพิ่มแอตทริบิวต์เพิ่มเติมเพื่อปรับแต่งประเภท URI ที่กิจกรรมยอมรับได้ ตัวอย่างเช่น คุณอาจมีกิจกรรมหลายรายการที่ยอมรับ URI ที่คล้ายกัน แต่แตกต่างกันไปตามชื่อเส้นทาง ในกรณีนี้ ให้ใช้แอตทริบิวต์
android:path
หรือตัวแปรpathPattern
หรือpathPrefix
เพื่อแยกความแตกต่างของกิจกรรมที่ระบบควรเปิดสำหรับเส้นทาง URI ที่แตกต่างกัน <category>
- รวมหมวดหมู่
BROWSABLE
จำเป็นต้องมีเพื่อให้เข้าถึงตัวกรอง Intent จากเว็บเบราว์เซอร์ได้ หากไม่มีแอตทริบิวต์นี้ การคลิกลิงก์ในเบราว์เซอร์จะไม่สามารถแก้ไขแอปของคุณได้รวมถึงหมวดหมู่
DEFAULT
ด้วย ซึ่งจะช่วยให้แอปตอบสนองต่อ Intent ที่ไม่ชัดได้ หากไม่มีแอตทริบิวต์นี้ กิจกรรมจะเริ่มได้ก็ต่อเมื่อ Intent ระบุชื่อคอมโพเนนต์แอปของคุณเท่านั้น
ข้อมูลโค้ด XML ต่อไปนี้แสดงวิธีระบุตัวกรอง Intent ในไฟล์ Manifest สำหรับการทำ Deep Link 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 2 รายการนี้แตกต่างกันตรงองค์ประกอบ <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
แต่จริงๆ แล้วรองรับทั้ง 2 รายการดังกล่าว รวมถึง app://www.example.com
และ https://open.my.app
ข้อควรระวัง: หากกิจกรรมหลายรายการมีตัวกรอง Intent ที่แก้ไขเป็น Android App Link ที่ยืนยันแล้วเดียวกัน เราไม่รับประกันว่ากิจกรรมใดจะจัดการลิงก์ดังกล่าว
เมื่อเพิ่มตัวกรอง Intent ที่มี URI สําหรับเนื้อหากิจกรรมลงในไฟล์ Manifest ของแอปแล้ว Android จะกําหนดเส้นทาง Intent
ที่มี URI ที่ตรงกันไปยังแอปของคุณได้เมื่อรันไทม์
ดูข้อมูลเพิ่มเติมเกี่ยวกับการกำหนดตัวกรอง Intent ได้ที่อนุญาตให้แอปอื่นๆ เริ่มกิจกรรมของคุณ
อ่านข้อมูลจาก Intent ที่เข้ามา
เมื่อระบบเริ่มกิจกรรมผ่านตัวกรอง 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(); }
ทําตามแนวทางปฏิบัติแนะนำต่อไปนี้เพื่อปรับปรุงประสบการณ์ของผู้ใช้
- Deep Link ควรนำผู้ใช้ไปยังเนื้อหาโดยตรง โดยไม่มีข้อความแจ้ง หน้าคั่นระหว่างหน้า หรือการลงชื่อเข้าใช้ ตรวจสอบว่าผู้ใช้ดูเนื้อหาแอปได้แม้ว่าจะไม่เคยเปิดแอปพลิเคชันมาก่อน คุณแสดงข้อความแจ้งให้ผู้ใช้ทราบเกี่ยวกับการโต้ตอบครั้งต่อๆ ไปหรือเมื่อผู้ใช้เปิดแอปจาก Launcher ได้
- ทำตามคำแนะนำด้านการออกแบบที่อธิบายไว้ในการไปยังส่วนต่างๆ ด้วยปุ่มย้อนกลับและขึ้นเพื่อให้แอปตรงกับความต้องการของผู้ใช้สำหรับการไปยังส่วนต่างๆ ย้อนกลับหลังจากที่เข้าสู่แอปผ่าน Deep Link
ทดสอบ Deep Link
คุณสามารถใช้ Android Debug Bridge กับเครื่องมือตัวจัดการกิจกรรม (am) เพื่อทดสอบว่า URI ของตัวกรอง Intent ที่คุณระบุไว้สําหรับการทำ Deep Link นำไปยังกิจกรรมของแอปที่ถูกต้อง คุณสามารถเรียกใช้คำสั่ง 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
การประกาศไฟล์ Manifest และตัวแฮนเดิล Intent ที่คุณตั้งค่าไว้ด้านบนจะกำหนดการเชื่อมต่อระหว่างแอปกับเว็บไซต์และสิ่งที่ต้องทำกับลิงก์ขาเข้า อย่างไรก็ตาม คุณต้องขอให้ระบบยืนยันการเชื่อมต่อนี้ด้วยเพื่อให้ระบบถือว่าแอปของคุณเป็นตัวแฮนเดิลเริ่มต้นสำหรับชุด URI บทเรียนถัดไปจะอธิบายวิธีใช้การยืนยันนี้
ดูแหล่งข้อมูลต่อไปนี้เพื่อดูข้อมูลเพิ่มเติมเกี่ยวกับ Intent และ App Link
- Intent และตัวกรอง Intent
- อนุญาตให้แอปอื่นๆ เริ่มกิจกรรมของคุณ
- เพิ่ม Android App Link ด้วย Android Studio