במסמך הזה מתוארים תהליך לפיתוח מערכת לבדיקת כתובות לטיפול במגוון תשובות מ-Address Validation API. במאמר מוסבר איך לפתח את הלוגיקה כדי להשתמש בתשובה בצורה נכונה, איך לבדוק אותות אחרים מה-API, ומתי ואיך לבקש מהלקוחות מידע נוסף.
באופן כללי, התגובה מה-API קובעת את הדרכים הבאות שבהן המערכת צריכה לטפל בכתובת:
- תיקון – האיכות של הכתובת נמוכה. כדאי לבקש מידע נוסף.
- אישור – הכתובת באיכות גבוהה, אבל יש בה שינויים מכתובת הקלט. יכול להיות שתוצג בקשה לאישור.
- אישור – הכתובת באיכות גבוהה. אפשר לאשר את הכתובת שצוינה.
מטרת המפתח
המסמך הזה יעזור לכם לשנות את המערכת כדי לנתח בצורה הטובה ביותר את התשובה מה-API ולהחליט מהן הפעולות הבאות שצריך לבצע עם הכתובות שסופקו. פסאודוקוד הבא מדגים תהליך אפשרי.
if (the API response indicates significant problems in the address)
FIX - prompt the user to fix the address
else if (the API response indicates less significant problems in the address)
CONFIRM - confirm with the user that the address is correct
else
ACCEPT - continue with the address returned by the API.
הלוגיקה המדויקת תלויה בנסיבות שלכם – מידע נוסף זמין במדריך להטמעה. אפשר גם להשתמש בהטמעה של הלוגיקה הזו בקוד פתוח, שנמצאת בספריית הרכיבים המורחבת.
סקירה כללית של תהליך העבודה
בטבלה הבאה מפורטות שתי פעולות שאפשר לבצע במערכת:
- תהליך העבודה שבו צריך להשתמש, בהתאם להתנהגות של תיקון, אישור וקבלה.
- האות הראשון לבדיקה מהתגובה. האותות המתוארים כאן מגיעים מהנכס
verdict
, והם לא האותות היחידים שאנחנו בודקים, אבל הם מספקים אינדיקטור ראשוני לגבי איכות הכתובת. לכל סוג התנהגות יש קטע במסמך הזה שמתאר אותות נוספים שיכול להיות שצריך לבדוק.
התנהגות המערכת | |||
---|---|---|---|
תיקון הכתובת |
התשובה מה-
|
||
אישור הכתובת |
התשובה מ-
|
||
אישור הכתובת |
התשובה של Address Validation API מציינת כתובת באיכות מעולה.
|
הדרכה בנושא הטמעה
כשאתם מתכננים את התגובה של המערכת לאותות מ-Address Validation API, ההמלצות הבאות יכולות לעזור לכם ליצור מודל תגובה יעיל יותר. עם זאת, אלה רק המלצות, לכן חשוב לזכור שההטמעה צריכה להתאים למודל העסקי שלכם.
הנחיות | פרטים | |
---|---|---|
רמת סיכון |
כשאתם מקבלים החלטה לגבי הצורך לבקש תיקונים או לאשר את הכתובת כפי שהיא מופיעה, חשוב להביא בחשבון את רמת הסובלנות שלכם. |
Address Validation API מחזיר מגוון אותות שאפשר לשלב עם רמת הסיכון כדי לבצע אופטימיזציה של תהליך האימות. לדוגמה, אם מספר הרחוב של כתובת מסוימת לא אושר, עדיין תוכלו לאשר אותה. לעומת זאת, אם אופן הפעולה של העסק שלכם מחייב דיוק רב יותר בכתובת, תוכלו לבקש מהמשתמש להזין אותה. דוגמה שיכולה להיכלל בכל אחת מהקטגוריות האלה מופיעה בקטע מספר רחוב לא מאומת מחוץ לארה"ב בקטע קבלת כתובת – דוגמאות. |
אישור כתובות |
מומלץ לאפשר למערכת לקבל את הערך המקורי אם הלקוח לא מגיב להנחיות. |
במקרים כאלה, יכול להיות שהלקוח הזין כתובת שלא רשומה במערכת, למשל של בניין חדש. |
שליחת משוב |
כשמפעילים מחדש בקשת אימות כתובת, אפשר גם לשלוח בקשה לנקודת הקצה |
כך Google תדע איך טיפלתם בסופו של דבר בתשובה הסופית. טיפול בכתובות מעודכנות |
תיקון כתובת
צריך לתקן כתובת אם בתוצאות מצוין בבירור שלא ניתן למסור אליה חבילה. לאחר מכן, המערכת תוכל לבקש מהלקוח לספק את המידע הנדרש, ואז תוכלו להפעיל מחדש את תהליך העבודה כדי לקבל כתובת למשלוח.
תיקון האותות
ממשק Address Validation API מספק מספר אותות כדי להודיע לכם אם צריך לתקן כתובת.
1. רמת פירוט האימות ורכיבים חסרים
שני האותות האלה מספקים את האינדיקציה הטובה ביותר לכתובת בעייתית:
- בכל פעם ששדה
validationGranularity
הואOTHER
, המערכת צריכה לבדוק את האותות של רכיבי הכתובת כדי לקבל מידע נוסף על המיקום שבו השגיאה התרחשה ועל הדרך לתקן אותה. - בכל פעם שאובייקט
address
שמעובד לאחר מכן מחזיר שדהmissingComponentTypes
, המערכת צריכה לבדוק אם הרכיב הזה קיים. רכיבים חסרים גם הופכים את הכתובת לחלקית ולא ניתנת למסירה.
2. אותות אחרים
ב-Address Validation API יש גם אותות אחרים שעוזרים לאבחן בעיות ספציפיות:
רכיבים חשודים | אם הערך של enum של רמת האישור של רכיב הוא UNCOMFIRMED_AND_SUSPICIOUS , סביר להניח שהרכיב שגוי.
|
---|---|
רכיב לא פתור | unresolvedToken הוא חלק מהקלט שלא מזוהה כחלק תקין של כתובת. |
3. אותות של כתובות בארה"ב
שדות מסוימים שחלים רק על כתובות בארה"ב מספקים אות שימושי לכך שהכתובת לא ניתנת למשלוח וצריכה תיקון. בכתובת שצריך לתקן, יופיעו הפרטים הבאים:
dpvConfirmation
|
N , D או ריק.
|
---|
פרטים על dpvConfirmation
זמינים במאמר טיפול בכתובות בארה"ב.
אישור כתובת
מאשרים כתובת כשהתוצאה מציינת ש-Address Validation API הסיק או ביצע שינויים ברכיבי הכתובת כדי ליצור כתובת מאומתת. במקרים כאלה, יש לכם כתובת למשלוח אבל אתם רוצים לוודא שהכתובת שהתקבלה היא הכתובת שבה הלקוח התכוון לשלוח את ההזמנה.
כדי לספק ללקוח את ההנחיה הנכונה, הלוגיקה תזהה את הרכיבים שסומנו על ידי השירות כדי לקבוע איזו פעולה או תג ה-API הוחלו על הרכיב, כמו inferred
, replaced
או spellCorrected
.
מידע נוסף זמין במאמר AddressComponent.
אישור האותות
ב-Address Validation API יש כמה אותות שמאפשרים לכם לדעת אם צריך לאשר כתובת.
1. רמת הפירוט של האימות
הערך של validationGranularity
יכול להיות ROUTE
או יותר, אבל הערכים 'PREMISE' או 'SUBPREMISE' מספקים אות חזק יותר לגבי יכולת המסירה.
2. אותות אחרים
כשמחליטים לאשר את הכתובת עם הלקוח, התוצאה כוללת גם את הפרטים הבאים שיעזרו לכם לקבוע אילו רכיבים לבדוק:
נתונים משוערים | כשהערך בשדה hasInferredComponents הוא true , זה אומר שה-API מילא מידע שצבר מרכיבים אחרים של הכתובת.
|
---|---|
הנתונים החלופיים | כשהשדה hasReplacedComponents הוא true , ה-API מחליף את הנתונים שהוזנו בנתונים שהוא סבר שהם יהפכו את הכתובת לתקינה.
|
3. אותות של כתובות בארה"ב
שדות מסוימים שחלים רק על כתובות בארה"ב מציינים שצריך לאמת את הפרטים עם הלקוח. אחת מהאפשרויות הבאות מתקיימת:
dpvConfirmation
|
S
פרטים על |
---|---|
תגובה לכתובת | מכיל את השדה missingComponentType עם הערך subpremise .
|
אישור כתובת
מאשרים כתובת כשהתוצאה מספקת רמת ודאות גבוהה שהכתובת ניתנת למשלוח ואפשר להשתמש בה בלי אינטראקציה נוספת עם הלקוח בתהליך במורד הזרם.
אישור אותות
ממשק Address Validation API מספק מספר אותות כדי להודיע לכם אם צריך לאשר כתובת.
1. רמת הפירוט של האימות
הערך של validationGranularity
יכול להיות PREMISE
או גבוה יותר, אבל במקרים מסוימים הערך ROUTE
עדיין מציין כתובת שאפשר לשלוח אליה חבילות.
2. אותות אחרים
בנוסף, פסיקה לגבי כתובת באיכות גבוהה צריכה לכלול את הפרטים הבאים:
- אין נתונים שהוחלפו. במקרה הזה,
hasReplacedComponents: FALSE
. - אין רכיבים משוערים. במקרה הזה,
hasInferredComponents: FALSE
.
3. אותות של כתובות בארה"ב
שדות מסוימים שחלים רק על כתובות בארה"ב מציינים כתובת באיכות גבוהה שאפשר לשלוח אליה חבילות. כתובת בארה"ב שעומדת בדרישות צריכה לכלול את הפרטים הבאים:
dpvConfirmation
|
Y
פרטים על |
---|