Для клиентов, отличных от Gmail, Gmail поддерживает стандартные протоколы IMAP, POP и SMTP. Серверы Gmail IMAP, POP и SMTP были расширены для поддержки авторизации через стандартный протокол OAuth 2.0.
Протокол
IMAP, POP и SMTP используют стандартный уровень простой аутентификации и безопасности (SASL) с использованием встроенных команд IMAP AUTHENTICATE
, POP AUTH
и SMTP AUTH
для аутентификации пользователей. Механизм SASL XOAUTH2 позволяет клиентам предоставлять учетные данные OAuth 2.0 для аутентификации. Документация протокола SASL XOAUTH2 очень подробно описывает механизм SASL XOAUTH2, а также доступны библиотеки и примеры , реализующие этот протокол.
Для входящих подключений к серверу IMAP по адресу imap.gmail.com:993
и POP-серверу по адресу pop.gmail.com:995
требуется SSL. Исходящий SMTP-сервер smtp.gmail.com
поддерживает TLS. Если ваш клиент начинается с обычного текста, перед вводом команды STARTTLS используйте порт 465
(для SSL) или порт 587
(для TLS).
Ограничения на длину сеанса
Сеансы Gmail POP ограничены примерно 7 днями. Сеансы Gmail IMAP ограничены примерно 24 часами. Если сеанс был аутентифицирован с использованием учетных данных OAuth, он ограничен периодом действия используемого токена доступа (обычно 1 час). Сеанс в этом контексте представляет собой одно непрерывное TCP-соединение .
По истечении времени и истечении срока действия сеанса Gmail закрывает соединение с сообщением о том, что срок действия сеанса истек. После этого клиент может повторно подключиться, снова пройти аутентификацию и продолжить. При использовании OAuth убедитесь, что используемый токен доступа действителен (если вы попытаетесь использовать токен доступа старше 1 часа, он может быть недействительным).
Библиотеки и образцы
Доступ к почте с использованием IMAP или POP и отправка почты с использованием SMTP часто для удобства выполняются с использованием существующих библиотек IMAP и SMTP. Поскольку эти библиотеки поддерживают простой уровень аутентификации и безопасности (SASL) , они должны быть совместимы с механизмом SASL XOAUTH2, поддерживаемым Gmail.
В дополнение к документации по протоколу SASL XOAUTH2 вы также можете прочитать Использование OAuth 2.0 для доступа к Google API для получения дополнительной информации о реализации клиента OAuth 2.0.
На странице «Библиотеки и примеры» представлены примеры кода на различных популярных языках с использованием механизма SASL XOAUTH2 с IMAP или SMTP.