ওয়েব পেমেন্ট ব্যবহার করে একটি পেমেন্ট লেনদেন আপনার পেমেন্ট অ্যাপের আবিষ্কারের সাথে শুরু হয়। কীভাবে একটি অর্থপ্রদানের পদ্ধতি সেট আপ করতে হয় এবং ব্যবসায়ী এবং গ্রাহকদের অর্থপ্রদান করার জন্য আপনার অর্থপ্রদানের অ্যাপ প্রস্তুত করতে হয় তা জানুন।
পেমেন্ট রিকোয়েস্ট API-এর সাথে ব্যবহার করার জন্য, একটি পেমেন্ট অ্যাপ অবশ্যই পেমেন্ট পদ্ধতি শনাক্তকারীর সাথে যুক্ত হতে হবে। যে ব্যবসায়ীরা একটি পেমেন্ট অ্যাপের সাথে একীভূত করতে চান তারা পেমেন্ট পদ্ধতি শনাক্তকারী ব্যবহার করে ব্রাউজারে তা নির্দেশ করবে। এই নিবন্ধটি আলোচনা করে যে কীভাবে পেমেন্ট অ্যাপ আবিষ্কার কাজ করে এবং কীভাবে আপনার পেমেন্ট অ্যাপটিকে ব্রাউজার দ্বারা সঠিকভাবে আবিষ্কার ও আমন্ত্রণ জানানোর জন্য কনফিগার করা যায়।
আপনি যদি ওয়েব পেমেন্টের ধারণা বা পেমেন্ট অ্যাপের মাধ্যমে পেমেন্ট লেনদেন কীভাবে কাজ করে সে সম্পর্কে নতুন হয়ে থাকেন, তাহলে প্রথমে নিচের প্রবন্ধগুলি পড়ুন:
ব্রাউজার সমর্থন
ওয়েব পেমেন্ট প্রযুক্তির কয়েকটি ভিন্ন অংশ নিয়ে গঠিত এবং সমর্থন অবস্থা ব্রাউজারের উপর নির্ভর করে।
কিভাবে একটি ব্রাউজার একটি পেমেন্ট অ্যাপ আবিষ্কার করে
প্রতিটি অর্থপ্রদান অ্যাপ্লিকেশন নিম্নলিখিত প্রদান করতে হবে:
- URL-ভিত্তিক অর্থপ্রদানের পদ্ধতি শনাক্তকারী
- পেমেন্ট পদ্ধতি ম্যানিফেস্ট (যখন পেমেন্ট পদ্ধতি শনাক্তকারী তৃতীয় পক্ষের দ্বারা প্রদান করা হয় তখন ছাড়া)
- ওয়েব অ্যাপ ম্যানিফেস্ট
আবিষ্কার প্রক্রিয়া শুরু হয় যখন একজন বণিক লেনদেন শুরু করে:
- ব্রাউজার পেমেন্ট পদ্ধতি শনাক্তকারী URL-এ একটি অনুরোধ পাঠায় এবং পেমেন্ট পদ্ধতি ম্যানিফেস্ট আনে।
- ব্রাউজার পেমেন্ট পদ্ধতি ম্যানিফেস্ট থেকে ওয়েব অ্যাপ ম্যানিফেস্ট ইউআরএল নির্ধারণ করে এবং ওয়েব অ্যাপ ম্যানিফেস্ট আনে।
- ব্রাউজার ওয়েব অ্যাপ ম্যানিফেস্ট থেকে OS পেমেন্ট অ্যাপ বা ওয়েব-ভিত্তিক পেমেন্ট অ্যাপ লঞ্চ করবে কিনা তা নির্ধারণ করে।
পরবর্তী বিভাগগুলি বিস্তারিতভাবে ব্যাখ্যা করে যে কীভাবে আপনার নিজস্ব অর্থপ্রদানের পদ্ধতি সেট আপ করবেন যাতে ব্রাউজারগুলি এটি আবিষ্কার করতে পারে।
ধাপ 1: অর্থপ্রদানের পদ্ধতি শনাক্তকারী প্রদান করুন
একটি অর্থপ্রদান পদ্ধতি শনাক্তকারী একটি URL-ভিত্তিক স্ট্রিং। উদাহরণস্বরূপ, Google Pay-এর শনাক্তকারী হল https://google.com/pay
। পেমেন্ট অ্যাপ ডেভেলপাররা পেমেন্ট পদ্ধতি শনাক্তকারী হিসেবে যেকোনো ইউআরএল বেছে নিতে পারে যতক্ষণ না তাদের নিয়ন্ত্রণ থাকে এবং ইচ্ছাকৃত বিষয়বস্তু পরিবেশন করতে পারে। এই নিবন্ধে, আমরা https://bobbucks.dev/pay
পেমেন্ট পদ্ধতি শনাক্তকারী হিসেবে ব্যবহার করব।
কিভাবে ব্যবসায়ীরা পেমেন্ট পদ্ধতি শনাক্তকারী ব্যবহার করে
একটি PaymentRequest
অবজেক্ট পেমেন্ট পদ্ধতি শনাক্তকারীর একটি তালিকা দিয়ে তৈরি করা হয় যা পেমেন্ট অ্যাপগুলিকে শনাক্ত করে যেগুলি একজন ব্যবসায়ী গ্রহণ করার সিদ্ধান্ত নেন। অর্থপ্রদান পদ্ধতি শনাক্তকারী supportedMethods
সম্পত্তির জন্য একটি মান হিসাবে সেট করা হয়। যেমন:
[বণিক] অর্থপ্রদানের অনুরোধ করে:
const request = new PaymentRequest([{
supportedMethods: 'https://bobbucks.dev/pay'
}], {
total: {
label: 'total',
amount: { value: '10', currency: 'USD' }
}
});
ধাপ 2: পেমেন্ট পদ্ধতি ম্যানিফেস্ট পরিবেশন করুন
একটি পেমেন্ট পদ্ধতি ম্যানিফেস্ট হল একটি JSON ফাইল যা নির্ধারণ করে যে কোন পেমেন্ট অ্যাপ এই পেমেন্ট পদ্ধতি ব্যবহার করতে পারে।
পেমেন্ট পদ্ধতি ম্যানিফেস্ট প্রদান করুন
যখন একজন বণিক একটি পেমেন্ট লেনদেন শুরু করেন, ব্রাউজার পেমেন্ট পদ্ধতি শনাক্তকারী URL-এ একটি HTTP GET
অনুরোধ পাঠায় । সার্ভার পেমেন্ট পদ্ধতি ম্যানিফেস্ট বডির সাথে সাড়া দেয়।
একটি অর্থপ্রদানের পদ্ধতি ম্যানিফেস্টে দুটি ক্ষেত্র থাকে, default_applications
এবং supported_origins
।
সম্পত্তির নাম | বর্ণনা |
---|---|
default_applications (প্রয়োজনীয়) | ইউআরএলগুলির একটি অ্যারে যা ওয়েব অ্যাপের দিকে নির্দেশ করে যেখানে অর্থপ্রদানের অ্যাপগুলি হোস্ট করা হয়। (URL একটি আপেক্ষিক হতে পারে)। এই অ্যারেটি ডেভেলপমেন্ট ম্যানিফেস্ট, প্রোডাকশন ম্যানিফেস্ট ইত্যাদি উল্লেখ করবে বলে আশা করা হচ্ছে। |
supported_origins | ইউআরএলগুলির একটি অ্যারে যা মূলের দিকে নির্দেশ করে যা একই অর্থপ্রদানের পদ্ধতি প্রয়োগ করে তৃতীয় পক্ষের পেমেন্ট অ্যাপ হোস্ট করতে পারে। মনে রাখবেন যে একটি অর্থপ্রদানের পদ্ধতি একাধিক অর্থপ্রদান অ্যাপ দ্বারা প্রয়োগ করা যেতে পারে। |
একটি অর্থপ্রদানের পদ্ধতি ম্যানিফেস্ট ফাইল এইরকম হওয়া উচিত:
[পেমেন্ট হ্যান্ডলার] /payment-manifest.json:
{
"default_applications": ["https://bobbucks.dev/manifest.json"],
"supported_origins": [
"https://alicepay.friendsofalice.example"
]
}
ব্রাউজার যখন default_applications
ক্ষেত্রটি পড়ে, তখন এটি সমর্থিত অর্থপ্রদান অ্যাপের ওয়েব অ্যাপের লিঙ্কগুলির একটি তালিকা খুঁজে পায়।
ঐচ্ছিকভাবে অন্য অবস্থানে পেমেন্ট পদ্ধতি ম্যানিফেস্ট খুঁজতে ব্রাউজারটিকে রুট করুন
পেমেন্ট মেথড আইডেন্টিফায়ার ইউআরএল ঐচ্ছিকভাবে একটি Link
হেডার দিয়ে সাড়া দিতে পারে যা অন্য ইউআরএলে নির্দেশ করে যেখানে ব্রাউজার পেমেন্ট মেথড ম্যানিফেস্ট আনতে পারে। এটি উপযোগী হয় যখন একটি অর্থপ্রদানের পদ্ধতি ম্যানিফেস্ট একটি ভিন্ন সার্ভারে হোস্ট করা হয় বা যখন একটি তৃতীয় পক্ষ দ্বারা অর্থপ্রদানের অ্যাপ পরিবেশন করা হয়।
rel="payment-method-manifest"
অ্যাট্রিবিউট এবং পেমেন্ট মেথড ম্যানিফেস্ট ইউআরএল সহ একটি HTTP Link
হেডারের সাথে প্রতিক্রিয়া জানাতে অর্থপ্রদানের পদ্ধতি সার্ভার কনফিগার করুন।
উদাহরণস্বরূপ, যদি ম্যানিফেস্টটি https://bobbucks.dev/payment-manifest.json
এ থাকে, তাহলে প্রতিক্রিয়া শিরোনামে অন্তর্ভুক্ত থাকবে:
Link: <https://bobbucks.dev/payment-manifest.json>; rel="payment-method-manifest"
URL একটি সম্পূর্ণ-যোগ্য ডোমেন নাম বা একটি আপেক্ষিক পথ হতে পারে। একটি উদাহরণ দেখতে নেটওয়ার্ক ট্রাফিকের জন্য https://bobbucks.dev/pay/
পরিদর্শন করুন। আপনি একটি curl
কমান্ডও ব্যবহার করতে পারেন:
curl --include https://bobbucks.dev/pay
ধাপ 3: একটি ওয়েব অ্যাপ ম্যানিফেস্ট পরিবেশন করুন
একটি ওয়েব অ্যাপ ম্যানিফেস্ট ব্যবহার করা হয় একটি ওয়েব অ্যাপকে সংজ্ঞায়িত করার জন্য যেভাবে নাম প্রস্তাব করে। এটি একটি প্রগতিশীল ওয়েব অ্যাপ (PWA) সংজ্ঞায়িত করার জন্য একটি বহুল ব্যবহৃত ম্যানিফেস্ট ফাইল।
সাধারণ ওয়েব অ্যাপ ম্যানিফেস্ট দেখতে এইরকম হবে:
[পেমেন্ট হ্যান্ডলার] /manifest.json:
{
"name": "Pay with Bobpay",
"short_name": "Bobpay",
"description": "This is an example of the Payment Handler API.",
"icons": [
{
"src": "images/manifest/icon-192x192.png",
"sizes": "192x192",
"type": "image/png"
},
{
"src": "images/manifest/icon-512x512.png",
"sizes": "512x512",
"type": "image/png"
}
],
"serviceworker": {
"src": "service-worker.js",
"scope": "/",
"use_cache": false
},
"start_url": "/",
"display": "standalone",
"theme_color": "#3f51b5",
"background_color": "#3f51b5",
"related_applications": [
{
"platform": "play",
"id": "com.example.android.samplepay",
"min_version": "1",
"fingerprints": [
{
"type": "sha256_cert",
"value": "4C:FC:14:C6:97:DE:66:4E:66:97:50:C0:24:CE:5F:27:00:92:EE:F3:7F:18:B3:DA:77:66:84:CD:9D:E9:D2:CB"
}
]
}
]
}
একটি ওয়েব অ্যাপ ম্যানিফেস্টে বর্ণিত তথ্যও অর্থপ্রদানের অনুরোধ UI-তে একটি অর্থপ্রদানের অ্যাপ কীভাবে উপস্থিত হয় তা নির্ধারণ করতে ব্যবহৃত হয়।
সম্পত্তির নাম | বর্ণনা |
---|---|
name (প্রয়োজনীয়) | পেমেন্ট অ্যাপের নাম হিসেবে ব্যবহার করা হয়েছে। |
icons (প্রয়োজনীয়) | পেমেন্ট অ্যাপ আইকন হিসেবে ব্যবহার করা হয়। শুধুমাত্র Chrome এই আইকনগুলি ব্যবহার করে; অন্যান্য ব্রাউজারগুলি সেগুলিকে ফলব্যাক আইকন হিসাবে ব্যবহার করতে পারে যদি আপনি সেগুলিকে অর্থপ্রদানের উপকরণের অংশ হিসাবে নির্দিষ্ট না করেন৷ |
serviceworker | ওয়েব-ভিত্তিক অর্থপ্রদান অ্যাপ হিসাবে চালিত পরিষেবা কর্মী সনাক্ত করতে ব্যবহৃত হয়। |
serviceworker.src | যে URL থেকে পরিষেবা কর্মী স্ক্রিপ্ট ডাউনলোড করতে হবে৷ |
serviceworker.scope | একটি ইউআরএল প্রতিনিধিত্বকারী একটি স্ট্রিং যা একটি পরিষেবা কর্মীর নিবন্ধন সুযোগ সংজ্ঞায়িত করে। |
serviceworker.use_cache | যে URL থেকে পরিষেবা কর্মী স্ক্রিপ্ট ডাউনলোড করতে হবে৷ |
related_applications | OS-প্রদত্ত পেমেন্ট অ্যাপ হিসেবে কাজ করে এমন অ্যাপ শনাক্ত করতে ব্যবহৃত হয়। অ্যান্ড্রয়েড পেমেন্ট অ্যাপস ডেভেলপার গাইডে আরও বিস্তারিত জানুন। |
prefer_related_applications | একটি OS-প্রদত্ত পেমেন্ট অ্যাপ এবং একটি ওয়েব-ভিত্তিক পেমেন্ট অ্যাপ উভয়ই উপলব্ধ থাকলে কোন পেমেন্ট অ্যাপ চালু করা হবে তা নির্ধারণ করতে ব্যবহৃত হয়। |
ওয়েব অ্যাপ ম্যানিফেস্টের name
প্রপার্টি পেমেন্ট অ্যাপের নাম হিসেবে ব্যবহার করা হয়, icons
প্রোপার্টি পেমেন্ট অ্যাপ আইকন হিসেবে ব্যবহার করা হয়।
কোন পেমেন্ট অ্যাপ চালু করতে হবে তা কীভাবে Chrome নির্ধারণ করে
প্ল্যাটফর্ম-নির্দিষ্ট পেমেন্ট অ্যাপ চালু করা হচ্ছে
প্ল্যাটফর্ম-নির্দিষ্ট পেমেন্ট অ্যাপ চালু করতে, নিম্নলিখিত শর্ত পূরণ করতে হবে:
-
related_applications
ক্ষেত্রটি ওয়েব অ্যাপ ম্যানিফেস্টে নির্দিষ্ট করা হয়েছে এবং:- ইনস্টল করা অ্যাপের প্যাকেজ আইডি এবং স্বাক্ষর মেলে, যখন ওয়েব অ্যাপ ম্যানিফেস্টে ন্যূনতম সংস্করণ (
min_version
) ইনস্টল করা অ্যাপ্লিকেশনটির সংস্করণের চেয়ে কম বা সমান।
- ইনস্টল করা অ্যাপের প্যাকেজ আইডি এবং স্বাক্ষর মেলে, যখন ওয়েব অ্যাপ ম্যানিফেস্টে ন্যূনতম সংস্করণ (
-
prefer_related_applications
ক্ষেত্রটিtrue
। - প্ল্যাটফর্ম-নির্দিষ্ট পেমেন্ট অ্যাপ ইনস্টল করা আছে এবং এতে আছে:
-
org.chromium.action.PAY
এর একটি উদ্দেশ্য ফিল্টার। -
org.chromium.default_payment_method_name
সম্পত্তির মান হিসাবে নির্দিষ্ট করা একটি পেমেন্ট পদ্ধতি শনাক্তকারী৷
-
[পেমেন্ট হ্যান্ডলার] /manifest.json
"prefer_related_applications": true,
"related_applications": [{
"platform": "play",
"id": "xyz.bobpay.app",
"min_version": "1",
"fingerprints": [{
"type": "sha256_cert",
"value": "92:5A:39:05:C5:B9:EA:BC:71:48:5F:F2:05:0A:1E:57:5F:23:40:E9:E3:87:14:EC:6D:A2:04:21:E0:FD:3B:D1"
}]
}]
যদি ব্রাউজার নির্ধারণ করে থাকে যে প্ল্যাটফর্ম-নির্দিষ্ট অর্থপ্রদানের অ্যাপ উপলব্ধ আছে, তাহলে এখানে আবিষ্কারের প্রবাহ বন্ধ হয়ে যাবে। অন্যথায় এটি পরবর্তী ধাপে চলতে থাকবে -- ওয়েব-ভিত্তিক পেমেন্ট অ্যাপ চালু করা।
ওয়েব-ভিত্তিক পেমেন্ট অ্যাপ চালু করা হচ্ছে
ওয়েব-ভিত্তিক পেমেন্ট অ্যাপটি ওয়েব অ্যাপ ম্যানিফেস্টের serviceworker
ফিল্ডে উল্লেখ করা উচিত।
[পেমেন্ট হ্যান্ডলার] /manifest.json:
"serviceworker": {
"src": "payment-handler.js"
}
ব্রাউজারটি পরিষেবা কর্মীকে একটি paymentrequest
ইভেন্ট পাঠিয়ে ওয়েব-ভিত্তিক পেমেন্ট অ্যাপ চালু করে। পরিষেবা কর্মীকে আগে থেকে নিবন্ধন করতে হবে না। এটা ঠিক সময়ে নিবন্ধন করা যাবে .
বিশেষ অপ্টিমাইজেশন বোঝা
কিভাবে ব্রাউজার পেমেন্ট অনুরোধ UI এড়িয়ে যেতে পারে এবং সরাসরি একটি পেমেন্ট অ্যাপ চালু করতে পারে
Chrome-এ, যখন show()
পদ্ধতিতে PaymentRequest
কল করা হয়, তখন পেমেন্ট রিকোয়েস্ট API ব্রাউজার-প্রদত্ত UI প্রদর্শন করে যাকে "পেমেন্ট অনুরোধ UI" বলা হয়। এই UI ব্যবহারকারীদের একটি অর্থপ্রদানের অ্যাপ বেছে নিতে দেয়। পেমেন্ট রিকোয়েস্ট UI-তে Continue বাটন চাপার পর, নির্বাচিত পেমেন্ট অ্যাপটি চালু হয়।
পেমেন্ট অ্যাপ চালু করার আগে পেমেন্ট রিকোয়েস্ট UI দেখালে পেমেন্ট পূরণ করার জন্য ব্যবহারকারীর প্রয়োজনীয় ধাপের সংখ্যা বেড়ে যায়। প্রক্রিয়াটি অপ্টিমাইজ করার জন্য, ব্রাউজার সেই তথ্যের পূর্ণতা পেমেন্ট অ্যাপগুলিতে অর্পণ করতে পারে এবং show()
কল করার সময় পেমেন্ট অনুরোধ UI না দেখিয়ে সরাসরি একটি পেমেন্ট অ্যাপ চালু করতে পারে।
একটি পেমেন্ট অ্যাপ সরাসরি চালু করতে, নিম্নলিখিত শর্তগুলি অবশ্যই পূরণ করতে হবে:
-
show()
একটি ব্যবহারকারীর অঙ্গভঙ্গি দিয়ে ট্রিগার করা হয় (উদাহরণস্বরূপ, একটি মাউস ক্লিক)। - শুধুমাত্র একটি একক পেমেন্ট অ্যাপ আছে যা:
- অনুরোধকৃত অর্থপ্রদানের পদ্ধতি শনাক্তকারীকে সমর্থন করে।
একটি ওয়েব-ভিত্তিক পেমেন্ট অ্যাপ কখন নথিভুক্ত হয় জাস্ট-ইন-টাইম (JIT)?
পেমেন্ট অ্যাপ ওয়েবসাইটে ব্যবহারকারীর স্পষ্ট পূর্বে পরিদর্শন এবং পরিষেবা কর্মী নিবন্ধন না করেই ওয়েব-ভিত্তিক পেমেন্ট অ্যাপগুলি চালু করা যেতে পারে। যখন ব্যবহারকারী ওয়েব-ভিত্তিক পেমেন্ট অ্যাপের মাধ্যমে অর্থ প্রদান করতে চান তখন পরিষেবা কর্মী ঠিক সময়ে নিবন্ধিত হতে পারেন। নিবন্ধন সময়ের জন্য দুটি ভিন্নতা আছে:
- যদি ব্যবহারকারীকে অর্থপ্রদানের অনুরোধ UI দেখানো হয়, অ্যাপটি ঠিক সময়ে নিবন্ধিত হয় এবং ব্যবহারকারী যখন Continue-এ ক্লিক করে তখন চালু হয়।
- যদি অর্থপ্রদানের অনুরোধ UI বাদ দেওয়া হয়, পেমেন্ট অ্যাপটি ঠিক সময়ে নিবন্ধিত হয় এবং সরাসরি চালু হয়। একটি ঠিক সময়ে নিবন্ধিত অ্যাপ চালু করতে অর্থপ্রদানের অনুরোধ UI এড়িয়ে যাওয়ার জন্য একটি ব্যবহারকারীর অঙ্গভঙ্গি প্রয়োজন, যা ক্রস-অরিজিন পরিষেবা কর্মীদের অপ্রত্যাশিত নিবন্ধন রোধ করে৷
পরবর্তী পদক্ষেপ
এখন যেহেতু আপনার পেমেন্ট অ্যাপটি আবিষ্কারযোগ্য, একটি প্ল্যাটফর্ম-নির্দিষ্ট পেমেন্ট অ্যাপ এবং একটি ওয়েব-ভিত্তিক পেমেন্ট অ্যাপ কীভাবে বিকাশ করবেন তা শিখুন।