Когда клиенты выбирают использование Google Safe Browsing v5 в режиме реального времени без необходимости хранения данных в памяти, им не требуется поддерживать какую-либо постоянную локальную базу данных. Однако от клиента по-прежнему ожидается наличие локального кэша. Такой локальный кэш не обязательно должен храниться в постоянном хранилище и может быть очищен в случае нехватки памяти.
Всякий раз, когда клиент хочет проверить определенный URL-адрес, он всегда подключается к серверу для выполнения проверки. Этот режим аналогичен тому, что могут реализовывать клиенты API Lookup версии 4.
По сравнению с режимом реального времени, этот режим может потреблять больше сетевой полосы пропускания, но может быть более подходящим, если клиенту неудобно поддерживать постоянное локальное состояние.
Процедура проверки URL-адреса в реальном времени без локальной базы данных
Эта процедура принимает один URL-адрес u и возвращает SAFE или UNSAFE .
- Пусть
expressionsэто список выражений суффикса/префикса, сгенерированных URL-адресомu. - Пусть
expressionHashesсписок, элементы которого представляют собой хеши SHA256 каждого выражения изexpressions. - Пусть
expressionHashPrefixes— список, элементы которого представляют собой первые 4 байта каждого хеша изexpressionHashes. - Для каждого
expressionHashPrefixизexpressionHashPrefixes:- Найдите
expressionHashPrefixв локальном кэше. - Если кэшированная запись найдена:
- Определите, превышает ли текущее время время его истечения.
- Если оно больше:
- Удалите найденную запись из локального кэша.
- Продолжайте цикл.
- Если оно не больше:
- Удалите этот конкретный
expressionHashPrefixизexpressionHashPrefixes. - Проверьте, найден ли соответствующий полный хеш в
expressionHashesв кэшированной записи. - Если обнаружено, вернуть
UNSAFE. - Если не найдено, продолжить цикл.
- Удалите этот конкретный
- Если кэшированная запись не найдена, продолжите цикл.
- Найдите
- Отправьте
expressionHashPrefixesна сервер Google Safe Browsing v5, используя RPC SearchHashes или REST-метод hashes.search . Если произошла ошибка (включая сетевые ошибки, ошибки HTTP и т. д.), вернитеSAFE. В противном случае, пусть response будетresponse, полученным от сервера SB, который представляет собой список полных хешей вместе с некоторой вспомогательной информацией, определяющей характер угрозы (социальная инженерия, вредоносное ПО и т. д.), а также время истечения срока действия кэшаexpiration. - Для каждого
fullHashresponse:- Вставить
fullHashв локальный кэш вместе сexpiration.
- Вставить
- Для каждого
fullHashresponse:- Пусть
isFound— результат поискаfullHashвexpressionHashes. - Если
isFoundравно False, продолжайте цикл. - Если
isFoundравно True, вернутьUNSAFE.
- Пусть
- Верните
SAFE.
Как и в режиме реального времени , эта процедура не определяет точно, как отправлять префиксы хешей на сервер. Например, клиенту допустимо отправлять все expressionHashPrefixes в одном запросе, а также отправлять каждый отдельный префикс из expressionHashPrefixes на сервер в отдельных запросах (возможно, параллельно). Также допустимо отправлять клиенту несвязанные или случайно сгенерированные префиксы хешей вместе с префиксами хешей из expressionHashPrefixes , при условии, что количество префиксов хешей, отправляемых в одном запросе, не превышает 30.