Google API. Интерфейс ClientLogin для DelphiИсточник: webdelphi
Источник: Webdelphi Сегодня наконец-то умудрился загрузить code.google.com, что не может не радовать. Оказывается у моего провайдера периодически происходят какие-то косяки в оборудовании и, что самое интересное, только Google глючит - остальные адреса работают…Странный глюк, но сегодня не об этом. Сегодня я расскажу про модуль, реализующий интерфейс ClientLogin. Этот интерфейс используется в Google API для аутентификации пользователей, использующих установленные приложения. Т.е. по сути этот интерфейс - основа для работы с различными API от Google из своих приложений Delphi, например доступ к Календарю Google, Analytics и т.д. В начале о том, что дает нам использование ClientLogin. Самое главное - это получение маркера Auth, который действует в течение некоторого промежутка времени (в зависимости от используемой службы) и на который будет ссылаться наше будущее приложение, чтобы получить доступ к управлению данными. Интерфейс использует стандартную систему защиты - Captcha, поэтому надо будет предусмотреть её загрузку и отправку данных ответа на сервер. Интерфейс НЕ используется для добавления и удаления служб и сервисов в аккаунт пользователя, т.е. вы не сможете использовать Auth, например, для добавления сервиса Google Analytics в свой аккаунт, но управлять уже подключенным сервисом - сможете. Теперь о том, как получить этот самый маркер Auth. Для этого необходимо отправить запрос методом POST на адрес https://www.google.com/accounts/ClientLogin и проанализировать ответ сервера. Как видите, нам придётся иметь дело опять с HTTPS. Параметры запроса следующие: accountType - тип аккаунта, для которого выполняется аутентификация. Может принимать значения: GOOGLE (выполнить аутентификацию аккаунта Google) Если мы изначально не знаем с каким типом аккаунта будем иметь дело - то лучше использовать HOSTED_OR_GOOGLE. Email - адрес электронной почты пользователя. Passwd - пароль пользователя. service - имя службы Google, к которой вы запрашиваете доступ. Каждой из служб, использующих службу аутентификации, присвоено имя. Например, с Календарем Google связано имя " cl ", с Google Analytics - " analytics " и т.д. Если изначально неизвестно имя службы, то можно использовать универсальное имя " xapi ". source - Короткая строка, идентифицирующая ваше приложение и применяемая для ведения журнала. Эта строка должна иметь следующий формат: logintoken - Маркер, представляющий конкретное значение CAPTCHA. Google присылает этот маркер и URL изображения CAPTCHA в ответе о неудачном входе с кодом ошибки "CaptchaRequired". logincaptcha - Строка, указанная пользователем в качестве ответа на тест CAPTCHA. Все перечисленные параметры должны содержаться в запросе. После отправки запроса нам придёт ответ, который может содержать: 1. В случае успешной аутентификации - код 200 и 3 строки: SID, LSID и Auth . Первые два маркера в настоящее время зарезервированы и не используются. 2. В случае ошибки нам возвращается код 403 и короткое сообщение (код) об ошибке 3. В случае необходимости ввода каптчи - код ошибки "CaptchaRequired", URL Captcha и параметр logintoken. Таким образом, от нас требуется не так уж и много - отправить запрос, проанализировать ответ и, если необходимо, получить каптчу и отправить ответ серверу. Теперь, что касается модуля Delphi. Модуль GoogleLogin не использует в работе ни Synapse, ни Indy - только WinInet. Отправка данных на сервер осуществляется в следующей функции:
На выходе имеем строку, содержащую ответ серверу. Привожу код именно этой функции, т.к. она Вам может пригодиться не только для работы с Google, но и, например, для авторизации ВКонтакте - главное передать верные параметры на вход. В модуле определен следующий класс:
При работе с классом следует учитывать, что изменение в процессе работы свойств Email, Password и Source ведет к обнулению всех данных об аутентификации. То есть, если вы меняете одно из этих свойств или все сразу, то после этого надо обязательно выполнить метод Login для получения нового значения Auth. Работа с классом элементарна, поэтому не вижу причин расписывать каждое поле, свойство и метод в отдельности, а покажу простой пример его использования. Например, можно авторизоваться так:
Метод LastResultText вернет вам сообщение об успешной аутентификации, либо текст, содержащий описание ошибки. А параметры запроса будут следующими: service=xapi source=Noname-MyCompany-1.0 accountType=HOSTED_OR_GOOGLE Можно изменить любые из свойств и перелогиниться. А если Google попросит ввести каптчу, то узнать об этом можно, например так:
и после ввода пользователем ответа, отправить новые запрос на аутентификацию таким образом:
В этом модуле я не стал реализовывать загрузку каптчи т.к. по сути это действие должно выполняться в готовом приложении - надо будет не только загрузить, но и где-то показать картинку с кодом. Хотя, если потребуется в будущем, можно будет реализовать загрузку в простой TBitmap и потом из него уже выводить куда угодно. Но это пока в планах. Сам модуль и пример работы с ним Вы можете скачать здесь. |