Ошибка неверного формата кода подтверждения при использовании писца OAuth в Android - PullRequest
1 голос
/ 03 февраля 2012

Я использую scribe Библиотека oAuth для реализации входа в Facebook oAuth, используя
это пример

Я установил www.example.com (действительный адрес) в URL сайта и в мобильном веб-URL. в настройках приложения facebook

вот мой код в Android

OAuthService service = new ServiceBuilder()
                                        .provider(FacebookApi.class)
                                        .apiKey(apiKey)
                                        .apiSecret(apiSecret)
                                        .callback("http://www.example.com/")
                                        .build();
          Scanner in = new Scanner(System.in);

          System.out.println("=== " + NETWORK_NAME + "'s OAuth Workflow ===");
          System.out.println();

          // Obtain the Authorization URL
          System.out.println("Fetching the Authorization URL...");
          String authorizationUrl = service.getAuthorizationUrl(EMPTY_TOKEN);
          System.out.println("Got the Authorization URL!");
          System.out.println("Now go and authorize Scribe here:");
          System.out.println(authorizationUrl);
          System.out.println("And paste the authorization code here");
          System.out.print(">>");
          String val = new String();
          if(in.hasNextLine())
           val = in.nextLine();
          System.out.println("VALUE"+val);
          Verifier verifier = new Verifier(val);
          System.out.println();

          // Trade the Request Token and Verfier for the Access Token
          System.out.println("Trading the Request Token for an Access Token...");
          Token accessToken = service.getAccessToken(EMPTY_TOKEN, verifier);
          System.out.println("Got the Access Token!");
          System.out.println("(if your curious it looks like this: " + accessToken + " )");
          System.out.println();

но я получаю следующую ошибку

Caused by: org.scribe.exceptions.OAuthException: Response body is incorrect. Can't extract a token from this: '{"error":{"message":"Invalid verification code format.","type":"OAuthException"}}'

Logcat

: === Facebook's OAuth Workflow === : Fetching the Authorization URL... : Got the Authorization URL! : Now go and authorize Scribe here: : https://www.facebook.com/dialog/oauth?client_id=XXXXXXXXXXXX&redirect_uri=http%3A%2F%2Fwww.example.com%2F : And paste the authorization code here : >>VALUE  Trading the Request Token for an Access Token... GC_FOR_MALLOC freed 5523 objects / 320760 bytes in 81ms AndroidRuntime(541): Shutting down VM : threadid=1: thread exiting with uncaught exception (group=0x4001d800)  FATAL EXCEPTION: main  java.lang.RuntimeException: Unable to start activity ComponentInfo{com.commauth/com.commauth.CommonAuthActivity}: org.scribe.exceptions.OAuthException: Response body is incorrect. Can't extract a token from this: '{"error":{"message":"Invalid verification code format.","type":"OAuthException"}}'
     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2663)
     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2679)
     at android.app.ActivityThread.access$2300(ActivityThread.java:125)
     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2033)
     at android.os.Handler.dispatchMessage(Handler.java:99)
     at android.os.Looper.loop(Looper.java:123)
     at android.app.ActivityThread.main(ActivityThread.java:4627)
     at java.lang.reflect.Method.invokeNative(Native Method)
     at java.lang.reflect.Method.invoke(Method.java:521)
     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
     at dalvik.system.NativeStart.main(Native Method)  Caused by: org.scribe.exceptions.OAuthException: Response body is incorrect. Can't extract a token from this: '{"error":{"message":"Invalid verification code format.","type":"OAuthException"}}'
     at org.scribe.extractors.TokenExtractor20Impl.extract(TokenExtractor20Impl.java:33)
     at org.scribe.oauth.OAuth20ServiceImpl.getAccessToken(OAuth20ServiceImpl.java:37)
     at com.commauth.CommonAuthActivity.onCreate(CommonAuthActivity.java:57)
     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2627)
     ... 11 more

ЕСЛИ я запускаю это как отдельную программу, то он запрашивает у меня код авторизации но я действительно не знаю, что туда поставить.

здесь, в строке кода

Scanner in = new Scanner(System.in);
Verifier verifier = new Verifier(in.nextLine());
System.out.println();

Ответы [ 2 ]

3 голосов
/ 28 июля 2012

Попробуйте добавить косую черту в конце вашего URL обратного вызова. Я потратил несколько часов на устранение неполадок в этом! Благодаря этому сообщению я нашел ответ!

0 голосов
/ 06 февраля 2012

У меня была такая же проблема, и фактически я просто вижу, что код, который я вводил, был неправильным Когда я копировал его с адреса навигатора, он не копировал весь код (слишком большой?). Поэтому дважды проверьте, является ли код хорошим.

...