Payment Handler API به ارائهدهندگان پرداخت اجازه میدهد تا تجربه پرداخت سفارشی خود را همراه با API درخواست پرداخت برای بازرگانان در دسترس قرار دهند. هنگامی که Payment Request API از طریق سازنده new PaymentRequest()
مقداردهی اولیه میشود، بیصدا یک رویداد canmakepayment
با مبدأ تاجر و دادههای دلخواه را برای یک سرویسکار ثبتشده برای Payment Handler API اجرا میکند. این ارتباط متقاطع به ژست کاربر نیاز ندارد و هیچ رابط کاربری را نشان نمی دهد.
کروم قرار است فیلدهای شناسایی را از رویداد canmakepayment
حذف کند و نسخه آزمایشی اصلی را از Chrome 108 آغاز کند.
اطلاعات موجود در این صفحه فقط برای ارائه دهندگان برنامه پرداخت که از Payment Handler API استفاده می کنند، اعمال می شود. اگر از آن استفاده نمی کنید، می توانید این دستورالعمل ها را نادیده بگیرید.
چه چیزی در حال تغییر است؟
هنگامی که یک تاجر new PaymentRequest()
را فراخوانی می کند، یک سرویس دهنده ثبت نام شده یک رویداد canmakepayment
( CanMakePaymentEvent
) را دریافت می کند که حاوی اطلاعات زیر است:
-
topOrigin
-
paymentRequestOrigin
-
methodData
-
modifiers
اینها حذف خواهند شد و کارمند خدمات به سادگی رویداد canmakepayment
را بدون هیچ گونه اطلاعات اضافی دریافت خواهد کرد.
تشخیص ویژگی
برای تشخیص اینکه آیا رویداد canmakepayment
در کد سرویس کارگر تغییر کرده است یا خیر، ویژگیهای مربوطه را مانند این بررسی کنید:
self.addEventListener(e => {
if (e.paymentRequestOrigin) {...}
if (e.topOrigin) {...}
if (e.methodData && e.methodData.length > 0) {...}
if (e.modifiers && e.modifiers.length > 0) {...}
...
});
تغییر را به صورت محلی امتحان کنید
برای فعال کردن تغییر به صورت محلی برای اهداف توسعه:
- از Chrome 108، 109 یا 110 استفاده کنید.
-
chrome://flags/#clear-identity-in-can-make-payment
در نوار URL وارد کنید. - پرچم را فعال کنید
- Chrome را دوباره راه اندازی کنید.
با فعال کردن پرچم، فیلدهای هویت در رویداد canmakepayment
خالی میشوند (و Android IS_READY_TO_PAY
Intent ).
تغییر در تولید را فعال کنید
همچنین میتوانید تغییر در تولید را برای اهداف آزمایشی قبل از اینکه واقعاً در Chrome فرود بیاید، فعال کنید. به این مکانیسم آزمایش مبدأ می گویند.
آزمایشهای مبدأ به شما امکان میدهد ویژگیهای جدید را امتحان کنید و در مورد قابلیت استفاده، کاربردی بودن و کارایی آنها به جامعه استانداردهای وب بازخورد بدهید. برای اطلاعات بیشتر، به راهنمای آزمایشی مبدا برای توسعه دهندگان وب مراجعه کنید. برای ثبت نام در این یا دیگر آزمایش اولیه، از صفحه ثبت نام دیدن کنید.
برای ثبت آزمایش اولیه:
- یک نشانه برای مبدا خود درخواست کنید .
- توکن را با استفاده از سرآیند
Origin-Trial
HTTP به فایل جاوا اسکریپت Service Worker خود اضافه کنید. تنظیم هدرهای HTTP نیاز به دسترسی به پیکربندی سرور شما دارد. هدر پاسخ به دست آمده باید چیزی شبیه به این باشد:
Origin-Trial: Auw/tjTQ2eJQ911wiMHi1Bb7i71...
برای مشاهده نشانه آزمایشی اولیه در فایل Service Worker، از DevTools یا دستور curl
مانند زیر استفاده کنید:
$ curl --head <Service Worker JS file URL> | grep -i origin-trial
origin-trial: Auw/tjTQ2eJQ911wiMHi1Bb7i71...
پس از Chrome 111، فیلدهای هویت را مجدداً به صورت محلی فعال کنید
اگر از Chrome 111 یا جدیدتر استفاده میکنید، فیلدهای هویت در رویداد canmakepayment
خالی میمانند. برای فعال کردن مجدد فیلدها به صورت محلی، می توانید موارد زیر را انجام دهید:
- از Chrome 111 یا جدیدتر استفاده کنید.
-
chrome://flags/#add-identity-in-can-make-payment
در نوار URL وارد کنید. - پرچم را فعال کنید
- Chrome را دوباره راه اندازی کنید.
مراحل بعدی
این تغییر برنامهریزی شده است که بهطور پیشفرض از Chrome 111 فعال شود. میتوانید آزمایش را از امروز شروع کنید تا برای تغییر در زمان راهاندازی آماده شوید.