Я работаю над приложением Android для своего исследования и работаю с OAuth (библиотекой указателей), чтобы получить доступ к пользовательским данным из веб-службы, которая также является частью процесса разработки.Я могу пройти через общие шаги OAuth, и я использую Uri (для обратного вызова приложения), и могу перейти к шагу, на котором я вызываю браузер устройств, выбираю для проверки мое приложение, и следующий шаг - SUPPOSEDперенаправить браузер НАЗАД в приложение ....
Вместо этого я получаю ошибку, которая выглядит примерно так: «у вас нет разрешения на открытие:
appSchema: // appName? authorizationSensitiveInfo ... "приложения после '?'являются oauth_token и oauth_verifier из службы (мы можем предположить, что все шаги до тех пор, пока перенаправление не будет «правильным»).
Возможные проблемы лежат в пределах appSchema://appName
.насколько я понимаю, это URL-адрес перенаправления, который говорит Uri использовать браузер телефона, чтобы найти мое приложение и вызвать метод onResume ().Откуда берутся значения для appSchema://appName
(определенные в манифесте? Если да, то где?).
Почему проблема с разрешением?Должен ли я установить разрешения для моего Uri для доступа к моему приложению?Я заблудился ... если вам нужны фрагменты кода, чтобы помочь мне, пожалуйста, ответьте, я не включил никакого кода, потому что это больше похоже на концепцию, которую я только что пропустил ... Я сейчас не на своей машине, но могу предоставитькод, если это сделает вещи проще для понимания.На самом деле бьется мне в голову здесь ...
В ОТВЕТ НА БОЛЬШОЙ ОТВЕТ ЗДЕСЬ, КАК Я ОБРАЩАЮСЬ НА РЕЗЮМЕ
protected void onResume() {
super.onResume();
Uri uri = this.getIntent().getData();
if (uri != null && uri.toString().startsWith(CALLBACK_URL)) {
Log.d("StepGreenM", uri.toString());
String verifier = uri.getQueryParameter(OAuth.OAUTH_VERIFIER);
Log.d("StepGreenM", verifier);
try {
provider.retrieveAccessToken(consumer, verifier);
TOKEN = consumer.getToken();
REQUEST_SECRET = consumer.getTokenSecret();
Log.d("StepGreenM", TOKEN);
Log.d("StepGreenM", REQUEST_SECRET);
} catch (OAuthMessageSignerException e) {
e.printStackTrace();
} catch (OAuthNotAuthorizedException e) {
e.printStackTrace();
} catch (OAuthExpectationFailedException e) {
e.printStackTrace();
} catch (OAuthCommunicationException e) {
e.printStackTrace();
}
}
uri = getIntent().getData();
if (uri != null && CALLBACK_URI.getScheme().equals(uri.getScheme())) {
String token = settings.getString(HomeScreen.REQUEST_TOKEN, null);
String secret = settings.getString(HomeScreen.REQUEST_SECRET, null);
Intent i = new Intent(Intent.ACTION_VIEW); // Intent to go to the action view
try {
if(!(token == null || secret == null)) {
consumer.setTokenWithSecret(token, secret);
}
String otoken = uri.getQueryParameter(OAuth.OAUTH_TOKEN);
String verifier = uri.getQueryParameter(OAuth.OAUTH_VERIFIER);
// We send out and save the request token, but the secret is not the same as the verifier
// Apparently, the verifier is decoded to get the secret, which is then compared - crafty
// This is a sanity check which should never fail - hence the assertion
Assert.assertEquals(otoken, consumer.getToken());
// This is the moment of truth - we could throw here
provider.retrieveAccessToken(consumer, verifier);
// Now we can retrieve the goodies
token = consumer.getToken();
secret = consumer.getTokenSecret();
//Save it to a settings file
HomeScreen.saveAuthInformation(settings, token, secret);
// Clear the request stuff, now that we have the real thing
HomeScreen.saveRequestInformation(settings, null, null);
i.putExtra(USER_TOKEN, token);
i.putExtra(CONSUMER_SECRET, secret);
//GO TO APPLICATION
} catch (OAuthMessageSignerException e) {
e.printStackTrace();
} catch (OAuthNotAuthorizedException e) {
e.printStackTrace();
} catch (OAuthExpectationFailedException e) {
e.printStackTrace();
} catch (OAuthCommunicationException e) {
e.printStackTrace();
} finally {
startActivity(i); // we either authenticated and have the extras or not, but are going to the action view
this.setContentView(R.layout.indivaction);
finish();
}
}
}
Не уверен, что на самом деле делает эторазваливаются ... но, как я уже сказал, сила закрывается при вызове этого метода.Я знаю, что он проходит через перенаправление, потому что я использую httpSniffer для проверки сообщений на сервер и с сервера ...