मकसद
डेवलपर के तौर पर, अक्सर आपको ऐसे डेटासेट के साथ काम करना पड़ता है जिनमें ग्राहकों के पते शामिल होते हैं. ये पते अच्छी क्वालिटी के नहीं हो सकते. आपको यह पक्का करना होगा कि पते सही हों, ताकि ग्राहक आईडी की पुष्टि करने से लेकर डिलीवरी वगैरह के लिए इस्तेमाल किए जा सकें.
पते की पुष्टि करने वाला एपीआई, Google Maps Platform का एक प्रॉडक्ट है. इसका इस्तेमाल, पते की पुष्टि करने के लिए किया जा सकता है. हालांकि, यह एक बार में सिर्फ़ एक पता प्रोसेस करता है. इस दस्तावेज़ में, हम अलग-अलग स्थितियों में, एक साथ कई पतों की पुष्टि करने की सुविधा का इस्तेमाल करने का तरीका देखेंगे. इन स्थितियों में, एपीआई टेस्टिंग से लेकर, एक बार और बार-बार पते की पुष्टि करना शामिल है.
उपयोग के उदाहरण
अब हम उन इस्तेमाल के उदाहरणों को समझेंगे जहां ज़्यादा संख्या में पते की पुष्टि करना काम का है.
टेस्ट करना
आपको अक्सर हजारों पतों का इस्तेमाल करके, पते की पुष्टि करने वाले एपीआई की जांच करनी होती है. हो सकता है कि आपके पास कॉमा लगाकर अलग की गई वैल्यू वाली फ़ाइल में पते हों और आपको पतों की क्वालिटी की पुष्टि करनी हो.
पतों की एक बार की जाने वाली पुष्टि
पते की पुष्टि करने वाले एपीआई को शामिल करते समय, आपको उपयोगकर्ता के डेटाबेस के मुकाबले अपने मौजूदा पते के डेटाबेस की पुष्टि करनी है.
पतों की बार-बार पुष्टि करना
कई मामलों में, पतों की बार-बार पुष्टि करना ज़रूरी होता है:
- आपने दिन भर में कैप्चर की गई जानकारी के पतों की पुष्टि करने के लिए, शायद शेड्यूल किए गए जॉब बनाए हों. उदाहरण के लिए, ग्राहक के साइन अप, ऑर्डर की जानकारी, डिलीवरी के शेड्यूल से.
- आपको अलग-अलग विभागों के पते वाले डेटा डंप मिल सकते हैं. उदाहरण के लिए, बिक्री से लेकर मार्केटिंग तक. ईमेल पते पाने वाला नया विभाग, अक्सर उन्हें इस्तेमाल करने से पहले उनकी पुष्टि करना चाहता है.
- सर्वे या अलग-अलग प्रमोशन के दौरान पते इकट्ठा किए जा सकते हैं. इसके बाद, ऑनलाइन सिस्टम में अपडेट किया जा सकता है. आपको सिस्टम में पते डालते समय, उनकी पुष्टि करनी है कि वे सही हैं.
तकनीकी जानकारी
इस दस्तावेज़ के लिए, हम यह मानते हैं कि:
- आपने पते की पुष्टि करने वाले एपीआई को, ग्राहक के डेटाबेस (यानी ग्राहक की जानकारी वाले डेटाबेस) से पते के साथ कॉल किया है
- अपने डेटाबेस में, हर पते के लिए मान्य होने के फ़्लैग को कैश मेमोरी में सेव किया जा सकता है.
- जब कोई ग्राहक लॉग इन करता है, तो पते की पुष्टि करने वाले एपीआई से पुष्टि के फ़्लैग वापस लाए जाते हैं.
प्रोडक्शन के लिए कैश मेमोरी
पते की पुष्टि करने वाले एपीआई का इस्तेमाल करते समय, अक्सर एपीआई कॉल के रिस्पॉन्स के कुछ हिस्से को कैश मेमोरी में सेव करना होता है. हमारी सेवा की शर्तों के मुताबिक, यह तय किया गया है कि कौनसा डेटा कैश मेमोरी में सेव किया जा सकता है. हालांकि, Address Validation API से कैश मेमोरी में सेव किया जाने वाला डेटा, उपयोगकर्ता के खाते के हिसाब से सेव किया जाना चाहिए. इसका मतलब है कि डेटाबेस में, पते या पते के मेटाडेटा को उपयोगकर्ता के ईमेल पते या किसी अन्य प्राइमरी आईडी के हिसाब से कैश मेमोरी में सेव किया जाना चाहिए.
पते की पुष्टि करने के लिए, बड़े पैमाने पर इस्तेमाल किए जाने वाले उदाहरण के लिए, डेटा कैश मेमोरी में सेव करने की सुविधा, सेक्शन 11.3 में बताई गई, पते की पुष्टि करने वाले एपीआई की सेवा से जुड़ी शर्तों के मुताबिक होनी चाहिए. इस जानकारी के आधार पर, यह तय किया जा सकता है कि किसी उपयोगकर्ता का पता अमान्य है या नहीं. ऐसा होने पर, आपके ऐप्लिकेशन के साथ अगले इंटरैक्शन के दौरान, उपयोगकर्ता से सही पता देने के लिए कहा जाएगा.
- AddressComponent ऑब्जेक्ट का डेटा
confirmationLevel
inferred
spellCorrected
replaced
unexpected
अगर आपको असली पते की कोई जानकारी कैश मेमोरी में सेव करनी है, तो उस डेटा को सिर्फ़ उपयोगकर्ता की सहमति के साथ कैश मेमोरी में सेव किया जाना चाहिए. इससे यह पक्का होता है कि उपयोगकर्ता को पता है कि कोई सेवा उसका पता क्यों सेव कर रही है और वह अपना पता शेयर करने की शर्तों से सहमत है.
उपयोगकर्ता की सहमति का एक उदाहरण, चेकआउट पेज पर ई-कॉमर्स पते के फ़ॉर्म के साथ सीधे तौर पर इंटरैक्ट करना होगा. हम समझते हैं कि पैकेज शिप करने के लिए, आप पते को कैश मेमोरी में सेव करेंगे और उसे प्रोसेस करेंगे.
उपयोगकर्ता की सहमति लेकर, जवाब में मौजूद formattedAddress
और अन्य मुख्य कॉम्पोनेंट को कैश मेमोरी में सेव किया जा सकता है. हालांकि, हेडलेस स्थिति में, उपयोगकर्ता सहमति नहीं दे सकता, क्योंकि पते की पुष्टि बैकएंड से की जा रही है. इसलिए, इस हेडलेस स्थिति में बहुत सीमित जानकारी को कैश मेमोरी में सेव किया जा सकता है.
जवाब को समझना
अगर पते की पुष्टि करने वाले एपीआई के जवाब में ये मार्कर शामिल हैं, तो आपको भरोसा हो सकता है कि इनपुट किया गया पता, डिलीवर किया जा सकने लायक है:
- Verdict ऑब्जेक्ट में
addressComplete
मार्करtrue
है, - Verdict ऑब्जेक्ट में मौजूद
validationGranularity
,PREMISE
याSUB_PREMISE
है - किसी भी AddressComponent को इनमें से किसी के तौर पर मार्क नहीं किया गया है:
Inferred
(ध्यान दें: inferred=true
ऐसा तब हो सकता है जबaddressComplete=true
)spellCorrected
replaced
unexpected
, और
confirmationLevel
: AddressComponent पर पुष्टि करने का लेवलCONFIRMED
याUNCONFIRMED_BUT_PLAUSIBLE
पर सेट है
अगर एपीआई रिस्पॉन्स में ऊपर दिए गए मार्कर नहीं हैं, तो हो सकता है कि इनपुट पता खराब क्वालिटी का हो. इसकी जानकारी देने के लिए, अपने डेटाबेस में फ़्लैग को कैश मेमोरी में सेव किया जा सकता है. कैश मेमोरी में सेव किए गए फ़्लैग से पता चलता है कि पते की क्वालिटी खराब है. वहीं, ज़्यादा जानकारी वाले फ़्लैग, जैसे कि वर्तनी ठीक की गई है, से पता चलता है कि पते की क्वालिटी से जुड़ी समस्या किस तरह की है. अगर किसी ग्राहक के इंटरैक्शन के दौरान, उसके दिए गए पते को खराब क्वालिटी के तौर पर फ़्लैग किया गया है, तो मौजूदा पते के साथ पता पुष्टि करने वाले एपीआई को कॉल किया जा सकता है. Address Validation API, सही किया गया पता दिखाएगा. इसे यूज़र इंटरफ़ेस (यूआई) प्रॉम्प्ट का इस्तेमाल करके दिखाया जा सकता है. जब ग्राहक फ़ॉर्मैट किए गए पते को स्वीकार कर लेता है, तो रिस्पॉन्स से ये चीज़ें कैश मेमोरी में सेव की जा सकती हैं:
formattedAddress
postalAddress
addressComponent componentNames
याUspsData standardizedAddress
पते की पुष्टि करने के लिए हेडलेस तरीके का इस्तेमाल करना
ऊपर दी गई बातचीत के आधार पर:
- कारोबार से जुड़ी वजहों से, Address Validation API के जवाब के कुछ हिस्से को कैश मेमोरी में सेव करना ज़रूरी होता है.
- हालांकि, Google Maps Platform की सेवा की शर्तों के मुताबिक, यह तय किया जाता है कि किस डेटा को कैश मेमोरी में सेव किया जा सकता है.
अगले सेक्शन में, हम सेवा की शर्तों का पालन करने और एक साथ कई पतों की पुष्टि करने की दो चरणों वाली प्रोसेस के बारे में बताएंगे.
पहला चरण:
पहले चरण में, हम देखेंगे कि किसी मौजूदा डेटा पाइपलाइन से, पते की पुष्टि करने वाली बड़ी डेटा स्क्रिप्ट को कैसे लागू किया जा सकता है. इस प्रोसेस की मदद से, सेवा की शर्तों के मुताबिक, पते की पुष्टि करने वाले एपीआई के रिस्पॉन्स से कुछ फ़ील्ड को स्टोर किया जा सकता है.
डायग्राम A: इस डायग्राम में दिखाया गया है कि ज़्यादा पते की पुष्टि करने के लॉजिक की मदद से, डेटा पाइपलाइन को कैसे बेहतर बनाया जा सकता है.
सेवा की शर्तों के मुताबिक, addressComponent
से इस डेटा को कैश मेमोरी में सेव किया जा सकता है:
confirmationLevel
inferred
spellCorrected
replaced
unexpected
इसलिए, लागू करने के इस चरण के दौरान, हम User-ID के लिए ऊपर बताए गए फ़ील्ड को कैश मेमोरी में सेव करेंगे.
ज़्यादा जानकारी के लिए, असल डेटा स्ट्रक्चर के बारे में जानकारी देखें.
दूसरा चरण:
पहले चरण में, हमें सुझाव मिला था कि इनपुट डेटासेट में मौजूद कुछ पते अच्छी क्वालिटी के नहीं हो सकते. अगले चरण में, हम इन फ़्लैग किए गए पतों को उपयोगकर्ता को दिखाएंगे और सेव किए गए पते को ठीक करने के लिए उनकी सहमति लेंगे.
डायग्राम B: इस डायग्राम में दिखाया गया है कि उपयोगकर्ता की सहमति वाले फ़्लो का एंड-टू-एंड इंटिग्रेशन कैसा दिख सकता है:
- जब उपयोगकर्ता लॉग इन करता है, तो सबसे पहले देखें कि आपने अपने सिस्टम में पुष्टि करने वाले किसी फ़्लैग को कैश मेमोरी में सेव किया है या नहीं.
- अगर कोई फ़्लैग है, तो आपको उपयोगकर्ता को यूज़र इंटरफ़ेस (यूआई) दिखाना चाहिए, ताकि वह अपना पता ठीक कर सके और उसे अपडेट कर सके.
- अपडेट किए गए या कैश मेमोरी में सेव किए गए पते के साथ, Address Validation API को फिर से कॉल किया जा सकता है. साथ ही, पुष्टि करने के लिए उपयोगकर्ता को सही पता दिखाया जा सकता है.
- अगर पता अच्छी क्वालिटी का है, तो Address Validation API,
formattedAddress
दिखाता है. - अगर सुधार किए गए हैं, तो उपयोगकर्ता को वह पता दिखाया जा सकता है या कोई सुधार न होने पर, चुपचाप स्वीकार किया जा सकता है.
- उपयोगकर्ता के स्वीकार करने के बाद,
formattedAddress
को डेटाबेस में कैश मेमोरी में सेव किया जा सकता है.
नतीजा
एक साथ कई पतों की पुष्टि करने की सुविधा का इस्तेमाल, कई ऐप्लिकेशन में किया जाता है. इस दस्तावेज़ में, Google Maps Platform की सेवा की शर्तों के मुताबिक, इस तरह के समाधान को लागू करने के तरीके के बारे में कुछ स्थितियों और डिज़ाइन पैटर्न के बारे में बताया गया है.
हमने GitHub पर, ओपन सोर्स लाइब्रेरी के तौर पर, एक ऐसा रेफ़रंस लागू किया है जिससे एक साथ कई पतों की पुष्टि की जा सकती है. ज़्यादा पतों की पुष्टि करने की सुविधा का इस्तेमाल तुरंत शुरू करने के लिए, इसे देखें. अलग-अलग स्थितियों में लाइब्रेरी का इस्तेमाल करने के तरीके के डिज़ाइन पैटर्न के बारे में जानने के लिए, लेख पढ़ें.
अगले चरण
भरोसेमंद पतों की मदद से चेकआउट, डिलीवरी, और ऑपरेशंस को बेहतर बनाएं व्हाइट पेपर डाउनलोड करें और पते की पुष्टि करने की सुविधा की मदद से चेकआउट, डिलीवरी, और ऑपरेशंस को बेहतर बनाएं वेबिनार देखें.
इस बारे में और जानने के लिए, ये लेख पढ़ें:
- ज़्यादा पतों की पुष्टि करने की सुविधा के इस्तेमाल के उदाहरण
- GitHub पर Python लाइब्रेरी
- पते की पुष्टि करने की सुविधा का डेमो देखें
योगदानकर्ता
इस लेख को Google मैनेज करता है. इसे मूल रूप से इन लोगों ने लिखा था.
मुख्य लेखक:
हेनरिक वाल्व | समाधान इंजीनियर
थॉमस ऐंगलरेट | समाधान इंजीनियर
सार्थक गंगुली | समाधान इंजीनियर