ما خطاها را به دستههای کلی زیر دستهبندی کردهایم:
- احراز هویت
- قابل امتحان مجدد
- اعتبار سنجی
- مرتبط با همگام سازی
اگرچه این دستهبندیها همه خطاهای احتمالی را در بر نمیگیرند، و برخی ممکن است در بیش از یک دسته قرار گیرند، با این وجود میتوانند به عنوان نقطه شروعی برای ساختاردهی مدیریت خطای برنامه شما باشند. برای جزئیات بیشتر در مورد خطاهای خاص به منابع زیر مراجعه کنید:
- Common Errors جزئیات بیشتری در مورد یک خطای خاص ارائه می دهد.
- google.rpc.Status برای جزئیات مربوط به مدل خطای منطقی مورد استفاده توسط API.
خطاهای احراز هویت
احراز هویت به این اشاره دارد که آیا کاربر به برنامه شما اجازه دسترسی به Google Ads از طرف او را داده است یا خیر. احراز هویت از طریق اعتبارنامه های تولید شده توسط جریان OAuth2 مدیریت می شود.
رایجترین دلیلی که خطای احراز هویت از عواملی خارج از کنترل شما ایجاد میشود این است که کاربر احراز هویت شده مجوزی را که به برنامه شما برای اقدام از جانب خود داده است، لغو کرده است. برای مثال، اگر برنامه شما حسابهای Google Ads جداگانه را برای مشتریان مستقل مدیریت کند و هنگام مدیریت حساب آن مشتری، بهصورت جداگانه بهعنوان هر مشتری احراز هویت میکند، مشتری میتواند در هر زمانی دسترسی برنامه شما را لغو کند. بسته به زمانی که دسترسی شما لغو شده است، API ممکن است مستقیماً یک خطای AuthenticationError.OAUTH_TOKEN_REVOKED
برگرداند، یا اشیاء اعتبار داخلی در کتابخانههای سرویس گیرنده ممکن است یک استثنا لغو نشانه ایجاد کنند. در هر صورت، اگر برنامه شما یک رابط کاربری برای مشتریان شما دارد، میتواند از آنها بخواهد که جریان OAuth2 را مجدداً راهاندازی کنند تا مجوز برنامه شما برای اقدام از طرف آنها دوباره برقرار شود.
خطاهای قابل امتحان مجدد
برخی از خطاها، مانند TRANSIENT_ERROR
یا INTERNAL_ERROR
، می تواند نشان دهنده یک مشکل موقتی باشد که ممکن است با تلاش مجدد درخواست پس از یک مکث کوتاه برطرف شود.
برای درخواستهای آغاز شده توسط کاربر، یک استراتژی این است که فوراً یک خطا را در رابط کاربری خود نشان دهید و به کاربر گزینهای برای شروع مجدد امتحان بدهید. از طرف دیگر، برنامه شما میتواند ابتدا بهطور خودکار درخواست را مجدداً امتحان کند، تنها پس از رسیدن به حداکثر تعداد تلاشهای مجدد یا کل زمان انتظار کاربر، خطا را در رابط کاربری فاش میکند.
برای درخواستهایی که در قسمت پشتی شروع میشوند، برنامه شما باید بهطور خودکار درخواست را تا حداکثر تعداد تکرار مجدد امتحان کند.
وقتی درخواستها را دوباره امتحان میکنید، از یک خطمشی عقبنشینی نمایی استفاده کنید. برای مثال، اگر ابتدا 5 ثانیه قبل از اولین تلاش مجدد مکث کنید، می توانید 10 ثانیه بعد از دومین و 20 ثانیه بعد از تلاش مجدد سوم مکث کنید. عقب نشینی نمایی کمک می کند تا مطمئن شوید که API را خیلی تهاجمی فراخوانی نمی کنید.
خطاهای اعتبارسنجی
خطاهای اعتبارسنجی نشان می دهد که ورودی یک عملیات قابل قبول نیست. به عنوان مثال، PolicyViolationError
، DateError
، DateRangeError
، StringLengthError
، و UrlFieldError
.
خطاهای اعتبارسنجی معمولاً در درخواستهای آغاز شده توسط کاربر رخ میدهد، جایی که کاربر ورودی نامعتبری را وارد کرده است. در این موارد، شما باید یک پیغام خطای مناسب را بر اساس خطای API خاصی که دریافت کرده اید به کاربر ارائه دهید. همچنین میتوانید قبل از برقراری تماس API، ورودی کاربر را برای اشتباهات رایج تأیید کنید، برنامهتان را پاسخگوتر کنید و استفاده از API را کارآمدتر کنید. برای درخواستهای پشتیبان، برنامه شما میتواند عملیات ناموفق را به صفی اضافه کند تا اپراتور انسانی آن را بررسی کند.
خطاهای مرتبط با همگام سازی
بسیاری از برنامه های Google Ads یک پایگاه داده محلی برای ذخیره اشیاء Google Ads خود دارند. یکی از چالشهای این رویکرد این است که پایگاه داده محلی ممکن است با اشیاء واقعی در Google Ads هماهنگ نباشد. به عنوان مثال، یک کاربر ممکن است یک گروه تبلیغاتی را مستقیماً در Google Ads حذف کند، اما برنامه و پایگاه داده محلی از این تغییر بیاطلاع هستند و به صدور فراخوانهای API ادامه میدهند که گویی گروه تبلیغاتی وجود دارد. این مشکلات همگامسازی میتواند به صورت خطاهای مختلفی مانند DUPLICATE_CAMPAIGN_NAME
، DUPLICATE_ADGROUP_NAME
، AD_NOT_UNDER_ADGROUP
، CANNOT_OPERATE_ON_REMOVED_ADGROUPAD
، و بسیاری دیگر ظاهر شود.
برای درخواستهای آغاز شده توسط کاربر، یک استراتژی این است که کاربر را در مورد مشکل احتمالی همگامسازی آگاه کنید، فوراً کاری را راهاندازی کنید که کلاس مربوطه از اشیاء Google Ads را بازیابی میکند و پایگاه داده محلی را بهروزرسانی میکند، سپس از کاربر میخواهد رابط کاربری را بهروزرسانی کند.
برای درخواستهای بکاند، برخی از خطاها اطلاعات کافی برای برنامه شما فراهم میکنند تا بهطور خودکار و تدریجی پایگاه داده محلی شما را تصحیح کند. برای مثال، CANNOT_OPERATE_ON_REMOVED_ADGROUPAD
باید باعث شود برنامه شما آن تبلیغ را به عنوان حذف شده در پایگاه داده محلی شما علامت گذاری کند. خطاهایی که نمیتوانید به این روش مدیریت کنید، میتواند باعث شود برنامه شما کار همگامسازی کاملتری را راهاندازی کند یا به صفی برای بازبینی اپراتور انسانی اضافه شود.