далее выбираем Standalone-приложения, так-как именно оно предназначено для компьютеров и смартфонов. Вводим имя нашего приложения и нажимаем Подключить приложения. После этого вам на мобильный телефон придет сообщения с кодом который нужный для подтверждения регистрации приложения.
После удачной проверки вы перейдете на страницу редактирования приложения, она имеет примерно вот такой вид:
Из этой страницы нам нужно будет ID приложения, можете его где то сохранить для дальнейшей работы с ним.
Так, пол дела сделано, теперь переходим к авторизации.
Переходим на вот эту страницу где описано как должна проходить авторизация. Теперь переходим непосредственно к кодингу, для этого запустите Visual Studio и создайте новый проект на основе BlankApp.
Авторизация будем делать с помощью протокола OAuth 2.0 для этого перейдем на страницу MainPage.xaml.cs и создадим новый метод OAuthVk() который будет делать авторизацию через WebAuthenticationBroker, что это такое — это специальный класс который запускает стандартное окно в котором открывается ссылка для авторизации. После вводи данных в окно авторизации брокер завершает свою работу и передает результат о том прошла авторизация успешно или нет.
Вот код нашего метода:
public static async void OAuthVk() { const string vkUri = "https://oauth.vk.com/authorize?client_id=3881112&scope=9999999&" + "redirect_uri=http://oauth.vk.com/blank.html&display=touch&response_type=token"; Uri requestUri = new Uri(vkUri); Uri callbackUri = new Uri("http://oauth.vk.com/blank.html"); WebAuthenticationResult result = await WebAuthenticationBroker.AuthenticateAsync( WebAuthenticationOptions.None, requestUri, callbackUri); switch (result.ResponseStatus) { case WebAuthenticationStatus.ErrorHttp: MessageDialog dialogError = new MessageDialog("Не удалось открыть страницу сервиса\n" + "Попробуйте войти в приложения позже!", "Ошибка"); dialogError.ShowAsync(); break; case WebAuthenticationStatus.Success: string responseString = result.ResponseData; MessageDialog dialogSuccess = new MessageDialog(responseString); dialogSuccess.ShowAsync(); break; } }
Теперь немножко о том что я написал. Первая строка vkUri — адрес открытия диалогового окна OAuth 2.0, его берем отсюда. В строке пишет client_id — передаем id нашего приложения, scope — права доступа приложения которые берутся отсюда, я написал 9999999 это доступ ко всему, при котором access_token не меняет своего значения, это для того чтоб каждый раз не проходить авторизацию, а брать сразу сохраненный access_token и user_id, и использовать их для вызова API, но об этом потом в отдельном посте. После этого мы вызываем метод AuthenticateAsync для выполнения авторизации и результат записываем в WebAuthenticationResult. Уже после этого, если запустить приложения, мы увидим окно авторизации:
Далее через оператор switch проверяем результат выполнения авторизации и проделываем соответственные действия. При ошибке сети выводим сообщения об ошибке, при удачной авторизации выводим сообщения в котором будет указан access_token и user_id. Ответ сервера будет примерно такой:
REDIRECT_URI#access_token= 533bacf01e11f55b536a565b57531ad114461ae8736d6506a3&expires_in=86400&user_id=8492
Все что нам теперь нужно сделать это достать со строки access_token и user_id для дальнейшего их использования. Для этого вместо сообщения об успешной авторизации напишем следующий код:
char[] separators = { '=', '&' }; string[] responseContent = responseString.Split(separators); string accessToken = responseContent[1]; int userId = Int32.Parse(responseContent[5]); MessageDialog dialogSuccess = new MessageDialog("access_token = "+accessToken+ "\nuser_id = "+userId); dialogSuccess.ShowAsync();
Теперь при успешной авторизации мы выведем сообщения в котором будет отображаться только access_tokeb и user_id.
Вот и все, токен и id мы получили можно вызывать любые API.
P.S. Если вам интересно то в следующих постах я буду рассматривать самые интересный и сложные API функции, потому что большинство из них вызываются одинаково.
Удачи в ПРОграммировании.
ссылка на оригинал статьи http://habrahabr.ru/post/201074/
Добавить комментарий