عندما يختار العملاء استخدام الإصدار 5 من "التصفّح الآمن" من Google في وضع الوقت الفعلي، سيحتفظ العملاء في قاعدة البيانات المحلية بما يلي: (1) ذاكرة تخزين مؤقت عالمية للمواقع الإلكترونية التي يُرجّح أن تكون غير ضارة، ويتم تنسيقها كتجزئات SHA256 لتعبيرات لاحقة المضيف/بادئة المسار لعنوان URL، (2) مجموعة من قوائم التهديدات، ويتم تنسيقها كبادئات تجزئة SHA256 لتعبيرات لاحقة المضيف/بادئة المسار لعنوان URL. الفكرة الأساسية هي أنّه عندما يريد العميل التحقّق من عنوان URL معيّن، يتم إجراء عملية تحقّق محلية باستخدام "ذاكرة التخزين المؤقت العامة". في حال اجتياز عملية التحقّق هذه، يتم إجراء عملية تحقّق من قوائم التهديدات المحلية. وفي ما عدا ذلك، يواصل العميل عملية التحقّق من التجزئة في الوقت الفعلي كما هو موضّح أدناه.
بالإضافة إلى قاعدة البيانات المحلية، سيحتفظ العميل بذاكرة تخزين مؤقت محلية. ولا يلزم أن تكون ذاكرة التخزين المؤقت المحلية هذه في مساحة تخزين ثابتة، ويمكن محوها في حال نقص الذاكرة.
يمكنك الاطّلاع أدناه على مواصفات تفصيلية للإجراء.
إجراء التحقّق من عنوان URL في الوقت الفعلي
يستقبل هذا الإجراء عنوان URL واحدًا u ويعرض SAFE أو UNSAFE أو UNSURE. إذا عرضت SAFE، يعني ذلك أنّ ميزة "التصفّح الآمن من Google" تعتبر عنوان URL آمنًا. إذا عرضت UNSAFE، يعني ذلك أنّ خدمة "التصفّح الآمن" من Google تعتبر عنوان URL غير آمن على الأرجح، ويجب اتّخاذ الإجراء المناسب، مثل عرض تحذير للمستخدم النهائي أو نقل رسالة تم تلقّيها إلى مجلد الرسائل غير المرغوب فيها أو طلب تأكيد إضافي من المستخدم قبل المتابعة. إذا عرضت القيمة UNSURE، يجب اتّباع إجراءات التحقّق المحلية التالية بعد ذلك.
- لنفترض أنّ
expressionsهي قائمة بتعبيرات اللاحقة/البادئة التي تم إنشاؤها بواسطة عنوان URLu. - لنفترض أنّ
expressionHashesهي قائمة، حيث تكون العناصر عبارة عن تجزئات SHA256 لكل تعبير فيexpressions. - لكل
hashمنexpressionHashes:- إذا كان يمكن العثور على
hashفي ذاكرة التخزين المؤقت العامة، أرجِعUNSURE.
- إذا كان يمكن العثور على
- لنفترض أنّ
expressionHashPrefixesهي قائمة، حيث تكون العناصر هي أول 4 بايتات من كل قيمة تجزئة فيexpressionHashes. - لكل
expressionHashPrefixمنexpressionHashPrefixes:- ابحث عن
expressionHashPrefixفي ذاكرة التخزين المؤقت المحلية. - في حال العثور على الإدخال المخزّن مؤقتًا:
- تحديد ما إذا كان الوقت الحالي أكبر من وقت انتهاء الصلاحية
- إذا كانت القيمة أكبر:
- أزِل الإدخال الذي تم العثور عليه في ذاكرة التخزين المؤقت من ذاكرة التخزين المؤقت المحلية.
- مواصلة التكرار الحلقي
- إذا لم يكن أكبر:
- إزالة
expressionHashPrefixالمحدّدة منexpressionHashPrefixes - تحقَّق ممّا إذا كان التجزئة الكاملة المقابلة ضمن
expressionHashesمتوفّرة في الإدخال المخزّن مؤقتًا. - في حال العثور على تطابق، أرجِع القيمة
UNSAFE. - إذا لم يتم العثور على السمة، استمر في التكرار.
- إزالة
- إذا لم يتم العثور على الإدخال المخزّن مؤقتًا، استمر في التكرار.
- ابحث عن
- أرسِل
expressionHashPrefixesإلى خادم الإصدار 5 من "التصفّح الآمن من Google" باستخدام RPC SearchHashes أو طريقة REST hashes.search. إذا حدث خطأ (بما في ذلك أخطاء الشبكة وأخطاء HTTP وما إلى ذلك)، يجب عرضUNSURE. بخلاف ذلك، يجب أن تكون الاستجابة هيresponseالتي تم تلقّيها من خادم "التصفّح الآمن"، وهي عبارة عن قائمة بتجزئات كاملة بالإضافة إلى بعض المعلومات المساعدة التي تحدّد طبيعة التهديد (الهندسة الاجتماعية أو البرامج الضارة أو غير ذلك)، فضلاً عن وقت انتهاء صلاحية ذاكرة التخزين المؤقتexpiration. - لكل
fullHashمنresponse:- أدرِج
fullHashفي ذاكرة التخزين المؤقت المحلية، بالإضافة إلىexpiration.
- أدرِج
- لكل
fullHashمنresponse:- لنفترض أنّ
isFoundهي نتيجة العثور علىfullHashفيexpressionHashes. - إذا كانت قيمة
isFoundهي False، استمر في التكرار. - إذا كانت
isFoundصحيحة، يتم عرضUNSAFE.
- لنفترض أنّ
- Return
SAFE
في حين يحدّد هذا البروتوكول وقت إرسال العميل expressionHashPrefixes إلى الخادم، لا يحدّد هذا البروتوكول عمدًا كيفية إرسالها بالضبط. على سبيل المثال، من المقبول أن يرسل العميل كل expressionHashPrefixes في طلب واحد، ومن المقبول أيضًا أن يرسل العميل كل بادئة فردية في expressionHashPrefixes إلى الخادم في طلبات منفصلة (ربما بالتوازي). من المقبول أيضًا أن يرسل العميل بادئات تجزئة غير ذات صلة أو تم إنشاؤها عشوائيًا مع بادئات التجزئة في expressionHashPrefixes، طالما أنّ عدد بادئات التجزئة المُرسَلة في طلب واحد لا يتجاوز 30.