在android中使用scribe OAuth无效的验证码格式错误

时间:2012-02-03 06:18:28

标签: android facebook oauth-2.0 scribe

我正在使用 scribe oAuth库来实施Facebook oAuth登录,使用
this示例

  

我在网站网址和移动网址中设置了www.example.com(有效的ur)   在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 个答案:

答案 0 :(得分:3)

尝试在回调网址的末尾添加斜杠。我花了几个小时进行故障排除!!!感谢this post我找到了答案!

答案 1 :(得分:0)

我有同样的问题,事实上,我只是看到我输入的代码不正确。当我从导航器地址复制它时,它没有复制整个代码(太大了?)。所以请仔细检查代码是否合适。