من بين التحسينات المهمة في الإصدار 5 من ميزة "التصفّح الآمن من Google" مقارنةً بالإصدار 4 (وتحديدًا واجهة برمجة التطبيقات Update API للإصدار 4) هو حداثة البيانات وتغطيتها. وبما أنّ الحماية تعتمد بشكل كبير على قاعدة البيانات المحلية التي يديرها العميل، فإنّ التأخير وحجم تحديث قاعدة البيانات المحلية هما السببان الرئيسيان في عدم اكتمال عملية الحماية. في الإصدار 4، يستغرق العميل العادي من 20 إلى 50 دقيقة للحصول على أحدث إصدار من قوائم التهديدات. تنتشر هجمات التصيّد الاحتيالي بسرعة: اعتبارًا من عام 2021، تبلغ مدة عرض 60% من المواقع الإلكترونية التي تُجري هجمات أقل من 10 دقائق. يُظهر تحليلنا أنّ ما يتراوح بين 25 و30% من حالات عدم توفّر الحماية من التصيّد الاحتيالي يرجع إلى عدم حداثة هذه البيانات. بالإضافة إلى ذلك، لا تتوفّر في بعض الأجهزة إمكانات لإدارة قوائم التهديدات الكاملة في ميزة "التصفّح الآمن" من Google، والتي تستمر في التزايد بمرور الوقت.
إذا كنت تستخدِم حاليًا v4 Update API، يتوفّر مسار نقل سلس من الإصدار 4 إلى الإصدار 5 بدون الحاجة إلى إعادة ضبط قاعدة البيانات المحلية أو محوها. يوضّح هذا القسم كيفية إجراء ذلك.
تحويل تعديلات القائمة
على عكس الإصدار 4، حيث يتم تحديد القوائم من خلال مجموعة من نوع التهديد ونوع النظام الأساسي ونوع إدخال التهديد، يتم تحديد القوائم في الإصدار 5 ببساطة حسب الاسم. ويوفّر ذلك مرونة عندما تتشارك قوائم متعددة من الإصدار 5 نوع التهديد نفسه. تمّت إزالة أنواع الأنظمة الأساسية وأنواع إدخالات التهديدات في الإصدار 5.
في الإصدار 4، يمكن استخدام طريقة threatListUpdates.fetch لتنزيل القوائم. في الإصدار 5، يمكن التبديل إلى طريقة hashLists.batchGet.
يجب إجراء التغييرات التالية على الطلب:
- أزِل عنصر v4
ClientInfo
بالكامل. بدلاً من تقديم معرّف العميل باستخدام حقل مخصّص، ما عليك سوى استخدام عنوان User-Agent المعروف. على الرغم من عدم توفّر تنسيق محدّد لتقديم معرّف العميل في هذا العنوان، نقترح ببساطة تضمين معرّف العميل الأصلي وإصدار العميل مفصولَين بحرف مسافة أو حرف واصلة. - لكل عنصر
ListUpdateRequest
من الإصدار 4: * ابحث عن اسم القائمة المطابق للإصدار 5 في الجدول أعلاه وأدخِل هذا الاسم في طلب الإصدار 5.- أزِل الحقول غير الضرورية، مثل
threat_entry_type
أوplatform_type
. - حقل
state
في الإصدار 4 متوافق مباشرةً مع حقلversions
في الإصدار 5. سلسلة البايتات نفسها التي سيتم إرسالها إلى الخادم باستخدام الحقلstate
في الإصدار 4 يمكن إرسالها ببساطة في الإصدار 5 باستخدام الحقلversions
. - بالنسبة إلى قيود الإصدار 4، يستخدم الإصدار 5 نسخة مبسطة تُعرف باسم
SizeConstraints
. يجب حذف الحقول الإضافية، مثلregion
.
- أزِل الحقول غير الضرورية، مثل
يجب إجراء التغييرات التالية على الردّ:
- يتم استبدال قائمة القيم المحدّدة
ResponseType
في الإصدار 4 ببساطة بحقل منطقي باسمpartial_update
. - يمكن الآن أن يكون الحقل
minimum_wait_duration
صفرًا أو محذوفًا. إذا كان الأمر كذلك، يُطلب من العميل تقديم طلب آخر على الفور. ولا يحدث ذلك إلا عندما يحدّد العميل فيSizeConstraints
قيدًا أصغر على الحد الأقصى لحجم التعديل مقارنةً بالحد الأقصى لحجم قاعدة البيانات. - يجب تعديل خوارزمية فك ترميز Rice للأعداد الصحيحة 32 بت. يكمن الاختلاف في أنّ البيانات المشفَّرة يتم تشفيرها بترتيب مختلف للبتّات. في كل من الإصدار 4 والإصدار 5، يتم ترتيب بادئات التجزئة ذات الـ 32 بت أبجديًا. ولكن في الإصدار 4، يتم التعامل مع هذه البادئات على أنّها تنسيق little endian عند الترتيب، في حين أنّه في الإصدار 5، يتم التعامل مع هذه البادئات على أنّها تنسيق big endian عند الترتيب. وهذا يعني أنّ العميل لا يحتاج إلى إجراء أي ترتيب، لأنّ الترتيب الأبجدي مطابق للترتيب الرقمي باستخدام تنسيق big endian. يمكنك العثور على مثال على هذا النوع من الطلبات في عملية تنفيذ الإصدار 4 من Chromium هنا. ويمكن إزالة هذا الترتيب.
- يجب تنفيذ خوارزمية فك ترميز Rice لأطوال التجزئة الأخرى أيضًا.
تحويل عمليات البحث عن الرموز المجزّأة
في الإصدار 4، يمكن استخدام طريقة fullHashes.find للحصول على التجزئات الكاملة. الطريقة المقابلة في الإصدار 5 هي طريقة hashes.search.
يجب إجراء التغييرات التالية على الطلب:
- يجب تنسيق الرمز لإرسال بادئات التجزئة التي يبلغ طولها 4 بايت بالضبط فقط.
- أزِل عناصر
ClientInfo
من الإصدار 4 بالكامل. بدلاً من تقديم معرّف العميل باستخدام حقل مخصّص، ما عليك سوى استخدام عنوان User-Agent المعروف. على الرغم من عدم توفّر تنسيق محدّد لتقديم معرّف العميل في هذا العنوان، نقترح ببساطة تضمين معرّف العميل الأصلي وإصدار العميل مفصولَين بحرف مسافة أو حرف واصلة. - أزِل حقل
client_states
. لم تعُد هذه الخطوة ضرورية. - لم يعُد من الضروري تضمين
threat_types
والحقول المشابهة.
يجب إجراء التغييرات التالية على الردّ:
- تمت إزالة حقل
minimum_wait_duration
. يمكن للعميل في أي وقت تقديم طلب جديد حسب الحاجة. - تم تبسيط كائن
ThreatMatch
في الإصدار 4 إلى كائنFullHash
. - تم تبسيط ميزة التخزين المؤقت لتصبح مدة تخزين مؤقت واحدة. اطّلِع على الإجراءات أعلاه للتفاعل مع ذاكرة التخزين المؤقت.