بیانیه ها در یک لیست بیانیه کدگذاری شده با JSON در یک مکان شناخته شده در یک اصل میزبانی می شوند، همانطور که توسط Asset Links Specification تعریف شده است. یک لیست عبارات حاوی یک یا چند عبارت است و یک اصل می تواند تنها یک لیست بیانیه داشته باشد.
نحو فهرست بیانیه
دستور لیست بیانیه را ببینید.
مکان لیست بیانیه
لیست بیانیه در یک مکان شناخته شده میزبانی می شود که بستگی به نوع مدیر (وب سایت یا برنامه ای که بیانیه ها را ارائه می دهد) دارد.
لیست های بیانیه وب سایت
در یک وب سایت، لیست بیانیه یک فایل متنی است که در آدرس زیر قرار دارد:
scheme :// domain /.well-known/assetlinks.json
به نقطه در نام پوشه .well-known توجه کنید.
هر پاسخی از سرور علاوه بر HTTP 200
به عنوان یک خطا تلقی می شود و منجر به یک لیست خالی می شود. برای HTTPS، هر اتصال بدون زنجیره گواهی که میتواند با لیست ریشه مورد اعتماد تأیید شود، منجر به یک فهرست خالی میشود.
مثال
در اینجا یک لیست نمونه بیانیه در یک وب سایت آمده است: http://example.digitalassetlinks.org/.well-known/assetlinks.json
لیست بیانیه برنامه اندروید
در یک برنامه اندروید، فهرست بیانیه یک قطعه JSON با نحو مشابه فایل بیانیه وبسایت است، اما در فایل strings.xml جاسازی شده و همانطور که در ادامه نشان داده شده است در مانیفست ارجاع داده میشود.
در AndroidManifest.xml:
<manifest> <application> ... <meta-data android:name="asset_statements" android:resource="@string/asset_statements" /> ... </application> </manifest>
در res/values/strings.xml:
<resources> ... <string name="asset_statements"> ... statement list ... </string> </resources>
مثال
در اینجا یک نمونه قطعه res/values/strings.xml برای یک برنامه Android است که از اشتراکگذاری موقعیت مکانی با برنامه پشتیبانی میکند (یک ویژگی Android در حال حاضر پشتیبانی نمیشود):
<resources> ... <string name="asset_statements"> [{ \"relation\": [\"delegate_permission/common.share_location\"], \"target\": { \"namespace\": \"web\", \"site\": \"https://example.com\" } }] </string> </resources>
مطابقت با یک هدف
هر جمله در مورد یک هدف است. هنگامی که یک بیانیه را مصرف می کنید، باید هدف را در یک بیانیه در برابر یک موجودیت واقعی مطابقت دهید. اگر هدف بیانیه با موجودیت مطابقت داشته باشد، بیانیه اعمال می شود. در اینجا قوانینی برای تعیین اینکه آیا یک هدف با یک موجودیت معین مطابقت دارد یا خیر وجود دارد:
اهداف وب سایت
برای یک وب سایت، طرح سایت، میزبان و پورت باید دقیقاً مطابقت داشته باشند. پورت های پیش فرض برای HTTP و HTTPS (به ترتیب 80 و 443) به طور ضمنی در نظر گرفته شده اند. اگر هدف عبارت http://www.example.com:80 را توصیف کند، وب سایت http://www.example.com مطابقت در نظر گرفته می شود.
مثال
با توجه به عبارت زیر target
"target": { "namespace": "web", "site": "https://www.google.com" }
URI های زیر مطابقت خواهند داشت:
- https://www.google.com/
- https://www.google.com:443/
- https://www.google.com/foo
- https://www.google.com/foo?bar
- https://www.google.com/foo#bar
- https://user@password:www.google.com/
URL های زیر مطابقت ندارند :
- http://www.google.com/ ( طرح اشتباه )
- https://google.com/ ( نام میزبان مطابقت ندارد )
- https://www.google.com:444/ ( پورت مطابقت ندارد )
اهداف برنامه
برای یک برنامه، هش گواهی و نام بسته هدف باید دقیقاً با برنامه مطابقت داشته باشد.