Izinkan PWA yang diinstal menangani URL untuk pengalaman yang lebih terintegrasi.
Apa yang dimaksud dengan PWA sebagai Pengendali URL?
Bayangkan Anda sedang melakukan chat dengan teman menggunakan aplikasi pesan instan seperti Message di macOS
dan Anda sedang membicarakan musik. Selanjutnya, bayangkan Anda berdua telah menginstal PWA music.example.com
di perangkat Anda. Jika ingin membagikan lagu favorit kepada teman untuk dinikmati, Anda dapat mengirim
deep link seperti https://music.example.com/rick-astley/never-gonna-give-you-up
kepada mereka. Karena link ini
cukup panjang, developer music.example.com
mungkin telah memutuskan untuk menambahkan link
singkat tambahan ke setiap jalur, seperti, misalnya, https://🎵.example.com/r-a/n-g-g-y-u
.
PWA sebagai Pengendali URL memungkinkan aplikasi seperti music.example.com
mendaftarkan dirinya sebagai pengendali URL untuk
URL yang cocok dengan pola seperti https://music.example.com
, https://*.music.example.com
, atau
https://🎵.example.com
, sehingga
link dari luar PWA, misalnya, dari aplikasi pesan instan atau klien
email, terbuka di PWA yang diinstal, bukan di tab browser.
PWA sebagai Pengendali URL terdiri dari dua tambahan:
- Anggota manifes aplikasi web
"url_handlers"
. - Format file
web-app-origin-association
untuk memvalidasi pengaitan URL dalam dan di luar cakupan.
Kasus penggunaan yang disarankan untuk PWA sebagai Pengendali URL
Contoh situs yang dapat menggunakan API ini meliputi:
- Situs streaming musik atau video sehingga link lagu atau link playlist terbuka di pengalaman pemutar aplikasi.
- Pembaca berita atau RSS sehingga situs yang diikuti atau di-subscribe akan terbuka dalam mode pembaca aplikasi.
Cara menggunakan PWA sebagai Pengendali URL
Mengaktifkan melalui about://flags
Untuk bereksperimen dengan PWA sebagai Pengendali URL secara lokal, tanpa token uji coba origin, aktifkan
tanda #enable-desktop-pwas-url-handling
di about://flags
.
Anggota manifes aplikasi web "url_handlers"
Untuk mengaitkan PWA yang diinstal dengan pola URL, pola ini harus ditentukan dalam manifes
aplikasi web. Hal ini terjadi melalui anggota "url_handlers"
. Fungsi ini menerima array objek dengan properti origin
, yang merupakan string
wajib yang merupakan pola untuk mencocokkan asal. Pola
ini diizinkan untuk memiliki awalan karakter pengganti (*
) guna menyertakan beberapa subdomain (seperti
https://*.example.com
). URL yang cocok dengan origin ini dapat ditangani oleh aplikasi web ini. Skema ini
selalu diasumsikan sebagai https://
, tetapi perlu disebutkan secara eksplisit.
Cuplikan manifes aplikasi web di bawah menunjukkan cara contoh PWA musik dari paragraf
pengantar dapat menyiapkannya. Entri kedua dengan karakter pengganti ("https://*.music.example.com"
) memastikan
aplikasi juga diaktifkan untuk https://www.music.example.com
atau potensi contoh lain seperti
https://marketing-activity.music.example.com
.
{
"url_handlers": [
{
"origin": "https://music.example.com"
},
{
"origin": "https://*.music.example.com"
},
{
"origin": "https://🎵.example.com"
}
]
}
File web-app-origin-association
Karena PWA berada di origin (music.example.com
) yang berbeda dengan beberapa URL yang perlu ditangani (misalnya, https://🎵.example.com
), aplikasi harus memverifikasi kepemilikan asal lain ini. Hal ini
terjadi dalam file web-app-origin-association
yang dihosting di origin lain.
File ini harus berisi JSON yang valid. Struktur tingkat teratas adalah objek, dengan anggota bernama
"web_apps"
. Anggota ini adalah array objek dan setiap objek mewakili entri untuk aplikasi web
unik. Setiap objek berisi:
Kolom | Deskripsi | Jenis | Default |
---|---|---|---|
"manifest" |
(Wajib diisi) String URL manifes aplikasi web PWA terkait | string |
T/A |
"details" |
(Opsional) Objek yang berisi array pola URL yang disertakan dan dikecualikan | object |
T/A |
Setiap objek "details"
berisi:
Kolom | Deskripsi | Jenis | Default |
---|---|---|---|
"paths" |
(Opsional) Array string jalur yang diizinkan | string[] |
[] |
"exclude_paths" |
(Opsional) Array string jalur yang tidak diizinkan | string[] |
[] |
Contoh file web-app-origin-association
untuk contoh PWA musik dari atas diberikan di bawah. URL ini
akan dihosting di origin 🎵.example.com
dan membuat pengaitan dengan
PWA music.example.com
, yang diidentifikasi oleh URL manifes aplikasi web-nya.
{
"web_apps": [
{
"manifest": "https://music.example.com/manifest.json",
"details": {
"paths": ["/*"],
"exclude_paths": ["/internal/*"]
}
}
]
}
Kapan URL cocok?
PWA cocok dengan URL untuk penanganan jika kedua kondisi berikut terpenuhi:
- URL cocok dengan salah satu string asal di
"url_handlers"
. - Browser dapat memvalidasi melalui file
web-app-origin-association
masing-masing bahwa setiap asal setuju untuk mengizinkan aplikasi ini menangani URL tersebut.
Terkait penemuan file web-app-origin-association
Agar browser dapat menemukan file web-app-origin-association
, developer harus
menempatkan file web-app-origin-association
di
folder /.well-known/
di root aplikasi.
Agar berfungsi, nama file harus persis web-app-origin-association
.
Demo
Untuk menguji PWA sebagai Pengendali URL, pastikan untuk menetapkan flag browser seperti
yang diuraikan di atas, lalu instal PWA di
https://mandymsft.github.io/pwa/. Dengan melihat
manifes aplikasi web, Anda dapat melihat bahwa aplikasi tersebut
menangani URL dengan pola URL berikut: https://mandymsft.github.io
dan
https://luhuangmsft.github.io
. Karena yang terakhir berada di origin yang berbeda (luhuangmsft.github.io
)
dari PWA, PWA di mandymsft.github.io
perlu membuktikan kepemilikan, yang dilakukan melalui
file web-app-origin-association
yang dihosting di
https://luhuangmsft.github.io/.well-known/web-app-origin-association.
Untuk menguji apakah fitur ini benar-benar berfungsi, kirim pesan pengujian kepada diri Anda sendiri menggunakan aplikasi pesan instan
pilihan Anda atau email yang dilihat di program email yang tidak berbasis web seperti Mail di macOS. Email
atau pesan teks harus berisi salah satu link https://mandymsft.github.io
atau
https://luhuangmsft.github.io
. Keduanya akan terbuka di PWA yang diinstal.
Keamanan dan izin
Tim Chromium mendesain dan menerapkan PWA sebagai Pengendali URL menggunakan prinsip inti yang ditentukan dalam Mengontrol Akses ke Fitur Platform Web yang Efisien, termasuk kontrol pengguna, transparansi, dan ergonomi.
Kontrol pengguna
Jika lebih dari satu PWA terdaftar sebagai pengendali URL untuk pola URL tertentu, pengguna akan diminta untuk memilih PWA yang ingin mereka gunakan untuk menangani pola tersebut—jika ada. Navigasi yang dimulai di tab browser tidak ditangani oleh proposal ini, yang secara eksplisit ditujukan untuk navigasi yang dimulai di luar browser.
Transparansi
Jika validasi pengaitan yang diperlukan tidak dapat berhasil diselesaikan selama penginstalan PWA karena alasan apa pun, browser tidak akan mendaftarkan aplikasi sebagai pengendali URL aktif untuk URL yang terpengaruh. Pengendali URL, jika tidak diterapkan dengan benar, dapat digunakan untuk membajak traffic untuk situs. Itulah sebabnya mekanisme pengaitan aplikasi adalah bagian penting dari skema ini.
Aplikasi khusus platform sudah dapat menggunakan API sistem operasi untuk menghitung aplikasi
yang diinstal di sistem pengguna. Misalnya, aplikasi di Windows dapat menggunakan
FindAppUriHandlersAsync
API untuk menghitung pengendali URL. Jika PWA terdaftar sebagai pengendali URL tingkat OS di Windows, kehadirannya
akan terlihat oleh aplikasi lain.
Persistensi izin
Origin dapat mengubah pengaitan dengan PWA kapan saja. Browser akan secara rutin mencoba memvalidasi ulang pengaitan aplikasi web yang diinstal. Jika pendaftaran pengendali URL gagal memvalidasi ulang karena data pengaitan telah berubah atau tidak lagi tersedia, browser akan menghapus pendaftaran.
Masukan
Tim Chromium ingin mengetahui pengalaman Anda dengan PWA sebagai Pengendali URL.
Ceritakan kepada kami tentang desain API
Apakah ada sesuatu tentang API yang tidak berfungsi seperti yang Anda harapkan? Atau apakah ada metode atau properti yang tidak ada yang Anda perlukan untuk menerapkan ide Anda? Ada pertanyaan atau komentar tentang model keamanan? Ajukan masalah spesifikasi di repo GitHub yang sesuai, atau tambahkan pendapat Anda ke masalah yang ada.
Melaporkan masalah terkait penerapan
Apakah Anda menemukan bug pada penerapan Chromium? Atau apakah implementasinya berbeda dengan spesifikasi?
Laporkan bug di new.crbug.com. Pastikan untuk menyertakan detail sebanyak mungkin,
petunjuk sederhana untuk mereproduksi, dan masukkan UI>Browser>WebAppInstalls
di kotak
Components. Glitch sangat cocok untuk membagikan rekaman ulang yang cepat dan mudah.
Menampilkan dukungan untuk API
Apakah Anda berencana menggunakan PWA sebagai Pengendali URL? Dukungan publik Anda membantu tim Chromium memprioritaskan fitur dan menunjukkan kepada vendor browser lain betapa pentingnya mendukungnya.
Kirim tweet ke @ChromiumDev menggunakan hashtag
#URLHandlers
dan beri tahu
kami tempat dan cara Anda menggunakannya.
Link bermanfaat
- Penjelasan publik
- Demo | Sumber demo
- Bug pelacakan Chromium
- Entri ChromeStatus.com
- Komponen Blink:
UI>Browser>WebAppInstalls
- TAG Review
- Dokumentasi Microsoft
Ucapan terima kasih
PWA sebagai Pengendali URL ditentukan dan diimplementasikan oleh Lu Huang dan Mandy Chen dari tim Microsoft Edge. Artikel ini ditinjau oleh Joe Medley. Gambar hero oleh Bryson Hammer di Unsplash.