Google Safe Browsing v5, v4 (खास तौर पर, v4 Update API) से ज़्यादा बेहतर है. इसकी वजह यह है कि इसमें डेटा को अपडेट करने की फ़्रीक्वेंसी ज़्यादा है और यह ज़्यादा डेटा को कवर करता है. सुरक्षा, क्लाइंट के बनाए गए लोकल डेटाबेस पर काफ़ी हद तक निर्भर करती है. इसलिए, लोकल डेटाबेस को अपडेट करने में होने वाली देरी और लोकल डेटाबेस का साइज़, सुरक्षा से जुड़ी समस्याओं की मुख्य वजह है. v4 में, क्लाइंट को थ्रेट लिस्ट का सबसे नया वर्शन पाने में आम तौर पर 20 से 50 मिनट लगते हैं. माफ़ करें, फ़िशिंग अटैक तेज़ी से फैलते हैं: साल 2021 तक, हमला करने वाली 60% साइटें 10 मिनट से कम समय तक लाइव रहती हैं. हमारे विश्लेषण से पता चला है कि इस तरह के पुराने डेटा की वजह से, फ़िशिंग से सुरक्षा की सुविधा करीब 25 से 30% तक काम नहीं करती. इसके अलावा, कुछ डिवाइसों में Google की सुरक्षित ब्राउज़िंग की थ्रेट लिस्ट को मैनेज करने की सुविधा नहीं होती. ये लिस्ट समय के साथ बड़ी होती जाती हैं.
अगर फ़िलहाल v4 Update API का इस्तेमाल किया जा रहा है, तो v4 से v5 पर आसानी से माइग्रेट किया जा सकता है. इसके लिए, स्थानीय डेटाबेस को रीसेट या मिटाने की ज़रूरत नहीं है. इस सेक्शन में, ऐसा करने का तरीका बताया गया है.
बदलावों की सूची को बदलना
V4 में, सूचियों की पहचान थ्रेट टाइप, प्लैटफ़ॉर्म टाइप, और थ्रेट एंट्री टाइप के टपल से की जाती है. हालांकि, v5 में सूचियों की पहचान सिर्फ़ नाम से की जाती है. इससे, एक ही तरह के खतरे की जानकारी को कई v5 सूचियों के साथ शेयर करने की सुविधा मिलती है. पांचवें वर्शन में, प्लैटफ़ॉर्म टाइप और थ्रेट एंट्री टाइप हटा दिए गए हैं.
वर्शन 4 में, सूचियां डाउनलोड करने के लिए threatListUpdates.fetch method का इस्तेमाल किया जाता था. v5 में, hashLists.batchGet method पर स्विच किया जाएगा.
अनुरोध में ये बदलाव किए जाने चाहिए:
- v4
ClientInfoऑब्जेक्ट को पूरी तरह से हटा दें. क्लाइंट की पहचान के लिए, किसी खास फ़ील्ड का इस्तेमाल करने के बजाय, सिर्फ़ User-Agent हेडर का इस्तेमाल करें. इस हेडर में क्लाइंट की पहचान देने के लिए, कोई तय फ़ॉर्मैट नहीं है. हालांकि, हमारा सुझाव है कि इसमें सिर्फ़ ओरिजनल क्लाइंट आईडी और क्लाइंट वर्शन शामिल करें. इन दोनों को स्पेस या स्लैश से अलग करें. - हर v4
ListUpdateRequestऑब्जेक्ट के लिए: * उपलब्ध सूचियों में जाकर, उससे जुड़े v5 की सूची का नाम ढूंढें और v5 के अनुरोध में वह नाम डालें.threat_entry_typeयाplatform_typeजैसे गैर-ज़रूरी फ़ील्ड हटाएं.- वर्शन 4 में मौजूद
stateफ़ील्ड, वर्शन 5 में मौजूदversionsफ़ील्ड के साथ सीधे तौर पर काम करता है. वर्शन 4 मेंstateफ़ील्ड का इस्तेमाल करके सर्वर को भेजी जाने वाली बाइट स्ट्रिंग को, वर्शन 5 मेंversionsफ़ील्ड का इस्तेमाल करके आसानी से भेजा जा सकता है. - v4 की शर्तों के लिए, v5 में
SizeConstraintsनाम का आसान वर्शन इस्तेमाल किया जाता है.regionजैसे अतिरिक्त फ़ील्ड हटा दिए जाने चाहिए.
जवाब में ये बदलाव किए जाने चाहिए:
- v4 enum
ResponseTypeकोpartial_updateनाम के बूलियन फ़ील्ड से बदल दिया गया है. minimum_wait_durationफ़ील्ड की वैल्यू अब शून्य हो सकती है या इसे छोड़ा जा सकता है. अगर ऐसा होता है, तो क्लाइंट से तुरंत दूसरा अनुरोध करने के लिए कहा जाता है. ऐसा सिर्फ़ तब होता है, जब क्लाइंटSizeConstraintsमें, डेटाबेस के ज़्यादा से ज़्यादा साइज़ की तुलना में अपडेट के ज़्यादा से ज़्यादा साइज़ पर कम पाबंदी लगाता है.- राइस-गोलोम्ब कोडिंग का इस्तेमाल करके कोड में बदले गए हैश को डिकोड करने के लिए, दो मुख्य बदलाव करने होते हैं:
- एंडियननेस और सॉर्टिंग: v4 में, दिखाए गए हैश को लिटिल-एंडियन वैल्यू के तौर पर सॉर्ट किया गया था. पांचवें वर्शन में, इन्हें बिग-एंडियन वैल्यू माना जाता है. बाइट स्ट्रिंग को लेक्सिकोग्राफ़िक तरीके से क्रम से लगाने का मतलब है कि बिग-एंडियन वैल्यू को संख्या के हिसाब से क्रम से लगाना. इसलिए, क्लाइंट को अब क्रम से लगाने का कोई खास चरण पूरा करने की ज़रूरत नहीं है. अगर आपने कस्टम लिटिल-एंडियन सॉर्टिंग को लागू किया है, तो उसे हटाया जा सकता है. जैसे, Chromium v4 में लागू की गई सॉर्टिंग.
- वैरिएबल हैश की लंबाई: डिकोडिंग एल्गोरिदम को अपडेट किया जाना चाहिए, ताकि वह
HashList.compressed_additionsफ़ील्ड में दिखाई गई अलग-अलग हैश की लंबाई के साथ काम कर सके. ऐसा न हो कि वह सिर्फ़ v4 में इस्तेमाल की गई चार बाइट वाली हैश की लंबाई के साथ काम करे. जवाब में दिखाए गए हैश की लंबाई,hashLists.listसे मिलेHashList.metadata.hash_lengthके आधार पर तय की जा सकती है. इसके अलावा, हैश की सूची का नामकरण भी, सूची से मिले हैश के अनुमानित साइज़ को दिखाता है. हैश की गई सूचियों के बारे में ज़्यादा जानने के लिए, लोकल डेटाबेस पेज देखें.
हैश की गई खोजों को बदला जा रहा है
v4 में, पूरे हैश पाने के लिए fullHashes.find method का इस्तेमाल किया जाता है. पांचवें वर्शन में, इससे मिलता-जुलता तरीका the hashes.search method है.
अनुरोध में ये बदलाव किए जाने चाहिए:
- कोड को इस तरह से स्ट्रक्चर करें कि सिर्फ़ ऐसे हैश प्रीफ़िक्स भेजे जाएं जिनकी लंबाई ठीक चार बाइट हो.
- v4
ClientInfoऑब्जेक्ट को पूरी तरह से हटा दें. क्लाइंट की पहचान के लिए, किसी खास फ़ील्ड का इस्तेमाल करने के बजाय, सिर्फ़ User-Agent हेडर का इस्तेमाल करें. इस हेडर में क्लाइंट की पहचान देने के लिए, कोई तय फ़ॉर्मैट नहीं है. हालांकि, हमारा सुझाव है कि इसमें सिर्फ़ ओरिजनल क्लाइंट आईडी और क्लाइंट वर्शन शामिल करें. इन दोनों को स्पेस या स्लैश से अलग करें. client_statesफ़ील्ड हटाएं. अब इसकी ज़रूरत नहीं है.- अब
threat_typesऔर मिलते-जुलते फ़ील्ड शामिल करने की ज़रूरत नहीं है.
जवाब में ये बदलाव किए जाने चाहिए:
minimum_wait_durationफ़ील्ड को हटा दिया गया है. क्लाइंट, ज़रूरत के हिसाब से हमेशा नया अनुरोध जारी कर सकता है.- v4
ThreatMatchऑब्जेक्ट कोFullHashऑब्जेक्ट में बदल दिया गया है. - कैशिंग को आसान बना दिया गया है. अब कैश मेमोरी को सिर्फ़ एक अवधि के लिए सेव किया जा सकता है. कैश मेमोरी के साथ इंटरैक्ट करने के लिए, ऊपर दी गई प्रोसेस देखें.