20

Android アプリを新しい Facebook 3.0 API と統合しようとしていますが、次の例外が発生します。

java.lang.RuntimeException: アクティビティを再開できません {dk.imu.konnekt/com.facebook.LoginActivity}: com.facebook.FacebookException: null 呼び出しパッケージで LoginActivity を呼び出すことはできません。これは、呼び出し元の launchMode が singleInstance である場合に発生する可能性があります。

私はこのエラーを検索しましたが、他の誰も問題を抱えていないようです。タブごとに TabHost と TabsGroupActivities を使用しているためだと思います。しかし、私はそれを解決する方法についての手がかりがありません。

関連するコードをここに追加しました。

public class MainTabActivity extends TabActivity {    
    public void onCreate(Bundle savedInstanteState){
        super.onCreate(savedInstanteState);
        setContentView(R.layout.tab_layout);
        TabHost tabHost = getTabHost();

        View shareTab = getLayoutInflater().inflate(R.layout.share_tab, null);
        tabHost.addTab(tabHost.newTabSpec("Share").setIndicator(shareTab)
        .setContent(new Intent(MainTabActivity.this, ShareGroupActivity.class)));

        ...
    }
}

-

public class ShareGroupActivity extends TabsGroupActivity {
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        startChildActivity("ShareActivity", new Intent(this, ShareActivity.class));
    }
}

-

public class ShareActivity extends BaseActivity {
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.share);

        testFacebookConnection();
    }

    public void testFacebookConnection(){
        Session session = new Session(this);
        Session.setActiveSession(session);
        SessionState state = session.getState();

        Settings.addLoggingBehavior(LoggingBehavior.INCLUDE_ACCESS_TOKENS);

        Session.StatusCallback statusCallback = 
            new Session.StatusCallback() {
            @Override
            public void call(Session session, SessionState state, Exception exception) {
                Toast.makeText(ShareActivity.this, "Facebook session status changed", Toast.LENGTH_SHORT).show(); 
            }
        };

        if (!session.isOpened() && !session.isClosed() && session.getState() != SessionState.OPENING) {
            OpenRequest open = new OpenRequest(this).setCallback(statusCallback);
            List<String> permission = new ArrayList<String>();
            permission.add("publish_actions");
            open.setPermissions(permission);
            session.openForPublish(open);
        } else {
            Session.openActiveSession(this, true, statusCallback);
        }
    }   

    @Override
    public void onActivityResult(int requestCode, int resultCode, Intent data) {
        super.onActivityResult(requestCode, resultCode, data);
        Session.getActiveSession().onActivityResult(this, requestCode, resultCode, data);
    }
}

それを解決する方法の手がかりはありますか?

1 つのスタック トレースを更新します。

致命的な例外: main java.lang.RuntimeException: アクティビティを再開できません {dk.imu.konnekt/com.facebook.LoginActivity}: com.facebook.FacebookException: null 呼び出しパッケージで LoginActivity を呼び出すことはできません。これは、呼び出し元の launchMode が singleInstance である場合に発生する可能性があります。android.app.ActivityThread.performResumeActivity(ActivityThread.java:2812) で android.app.ActivityThread.handleResumeActivity(ActivityThread.java:2851) で android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2234) で android.app. ActivityThread.access$600(ActivityThread.java:139) で android.app.ActivityThread$H.handleMessage(ActivityThread.java:1261) で android.os.Handler.dispatchMessage(Handler.java:99) android.os.Looper.loop (Looper.java:154) android.app.ActivityThread.main(ActivityThread.java:4945) で java.lang.reflect.Method で。java.lang.reflect.Method.invoke(Method.java:511) の invokeNative(ネイティブ メソッド) com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784) の com.android.internal. os.ZygoteInit.main(ZygoteInit.java:551) at dalvik.system.NativeStart.main(Native Method) 原因: com.facebook.FacebookException: null 呼び出しパッケージで LoginActivity を呼び出すことはできません。これは、呼び出し元の launchMode が singleInstance である場合に発生する可能性があります。com.facebook.LoginActivity.onResume(LoginActivity.java:110) で android.app.Instrumentation.callActivityOnResume(Instrumentation.java:1236) で android.app.Activity.performResume(Activity.java:4613) で android.app. ActivityThread.performResumeActivity(ActivityThread.java:2796) ... 12 もっと見る os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551) at dalvik.system.NativeStart.main(Native Method) 原因: com. facebook.FacebookException: null 呼び出しパッケージで LoginActivity を呼び出すことはできません。これは、呼び出し元の launchMode が singleInstance である場合に発生する可能性があります。com.facebook.LoginActivity.onResume(LoginActivity.java:110) で android.app.Instrumentation.callActivityOnResume(Instrumentation.java:1236) で android.app.Activity.performResume(Activity.java:4613) で android.app. ActivityThread.performResumeActivity(ActivityThread.java:2796) ... 12 もっと見る os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551) at dalvik.system.NativeStart.main(Native Method) 原因: com. facebook.FacebookException: null 呼び出しパッケージで LoginActivity を呼び出すことはできません。これは、呼び出し元の launchMode が singleInstance である場合に発生する可能性があります。com.facebook.LoginActivity.onResume(LoginActivity.java:110) で android.app.Instrumentation.callActivityOnResume(Instrumentation.java:1236) で android.app.Activity.performResume(Activity.java:4613) で android.app. ActivityThread.performResumeActivity(ActivityThread.java:2796) ... 12 もっと見る FacebookException: null 呼び出しパッケージで LoginActivity を呼び出すことはできません。これは、呼び出し元の launchMode が singleInstance である場合に発生する可能性があります。com.facebook.LoginActivity.onResume(LoginActivity.java:110) で android.app.Instrumentation.callActivityOnResume(Instrumentation.java:1236) で android.app.Activity.performResume(Activity.java:4613) で android.app. ActivityThread.performResumeActivity(ActivityThread.java:2796) ... 12 もっと見る FacebookException: null 呼び出しパッケージで LoginActivity を呼び出すことはできません。これは、呼び出し元の launchMode が singleInstance である場合に発生する可能性があります。com.facebook.LoginActivity.onResume(LoginActivity.java:110) で android.app.Instrumentation.callActivityOnResume(Instrumentation.java:1236) で android.app.Activity.performResume(Activity.java:4613) で android.app. ActivityThread.performResumeActivity(ActivityThread.java:2796) ... 12 もっと見る

更新 2: コードを調べたところ、startChildActivity の実装が見つかりました。

public void startChildActivity(String Id, Intent intent) {     
   Window window = getLocalActivityManager().startActivity(Id,intent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP));
   if (window != null) {
       mIdList.add(Id);
       setContentView(window.getDecorView()); 
   }    
}

フラグ FLAG_ACTIVITY_CLEAR_TOP を使用します。削除しようとしましたが、結果に変化はありませんでした。

更新 3:

https://github.com/facebook/facebook-android-sdk/blob/master/facebook/src/com/facebook/LoginActivity.java

Facebookコードは使用します

callingPackage = getCallingPackage();

if (callingPackage == null) {
       throw new FacebookException(NULL_CALLING_PKG_ERROR_MSG);
}

http://developer.android.com/reference/android/app/Activity.html#getCallingPackage()

このメソッドには次の注意事項があります。

呼び出し元のアクティビティが結果を予期していない場合 (つまり、要求コードを含む startActivityForResult(Intent, int) フォームを使用しなかった場合)、呼び出し元のパッケージは null になります。

メソッド startChildActivity では、ActivityGroup を拡張する TabsGroupActivity で getLocalActivityManager().startActivity を使用して、タブ アクティビティを処理します。 http://developer.android.com/reference/android/app/LocalActivityManager.html#startActivity(java.lang.String, android.content.Intent)

この方法は、メモに記載されていることではありません。結果を期待せず、startActivityForResult メソッドを使用しません。このメソッドは、singleinstance launchmode に似たものも保証します。このメソッドの実装をどのように変更すれば、Facebook で動作するようになりますか?

4

4 に答える 4

7

私は自分の問題を見つけることができました。設定していないのに

android:launchMode="singleTask"

私のLoginActivityには

android:noHistory="true"

その例外が発生します。ユーザーがログイン後の最初のアクティビティで戻るボタンを押してログイン画面に戻ることができないようにするため、noHistory を true に設定しました。今、私は別の解決策を見つける必要があります。

于 2013-03-28T15:55:33.473 に答える
5

何度も検索した結果、タブで LocalActivityManager を使用して ActivityForResult を開始する方法がないように思われることがわかりました。

そのため、画面全体を埋めるアクティビティが必要になることを受け入れることになりました。アクティビティは、ネットワーク接続が良好な場合に 1 秒程度しか表示されません。エラー時に再公開オプションを使用して作成しました。

公開アクティビティを開始:

Intent intent = new Intent(this, FacebookShareActivity.class);
intent.putExtra(Constants.FACEBOOK_MESSAGE, shareMessage.getMessage());
startActivityForResult(intent, 1);

Facebook 共有アクティビティ コード - ユーザー ウォールへの公開:

public class FacebookShareActivity extends Activity {
    String message;

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.facebook_publishing);

        message = getIntent().getExtras().getString(Constants.FACEBOOK_MESSAGE);
        createFacebookConnection();
    }

    public void republishButton_Click(View view){
        setVisibilityForRepublishButton(false);
        createFacebookConnection();
    }

    public void createFacebookConnection() {
        Session session = new Session(this);
        Session.setActiveSession(session);

        Settings.addLoggingBehavior(LoggingBehavior.INCLUDE_ACCESS_TOKENS);

        Session.StatusCallback statusCallback = new Session.StatusCallback() {
            @Override
            public void call(Session session, SessionState state, Exception exception) {
                String message = "Facebook session status changed - " + session.getState() + " - Exception: " + exception;
                //Toast.makeText(FacebookShareActivity.this, message, Toast.LENGTH_SHORT).show();
                Log.w("Facebook test", message);

                if (session.isOpened() || session.getPermissions().contains("publish_actions")) {
                    publishToWall();
                } else if (session.isOpened()) {
                    OpenRequest open = new OpenRequest(FacebookShareActivity.this).setCallback(this);
                    List<String> permission = new ArrayList<String>();
                    permission.add("publish_actions");
                    open.setPermissions(permission);
                    Log.w("Facebook test", "Open for publish");
                    session.openForPublish(open);
                }
            }
        };

        if (!session.isOpened() && !session.isClosed() && session.getState() != SessionState.OPENING) {
            session.openForRead(new Session.OpenRequest(this).setCallback(statusCallback));
        } else {
            Log.w("Facebook test", "Open active session");
            Session.openActiveSession(this, true, statusCallback);
        }
    }

    private void setVisibilityForRepublishButton(Boolean visible) {
        ((Button) findViewById(R.id.republishButton)).setVisibility(visible ? View.VISIBLE : View.GONE);
    }

    @Override
    public void onActivityResult(int requestCode, int resultCode, Intent data) {
        super.onActivityResult(requestCode, resultCode, data);
        Session.getActiveSession().onActivityResult(this, requestCode, resultCode, data);
        //Toast.makeText(FacebookShareActivity.this, "onActivityResult", Toast.LENGTH_SHORT).show();
    }

    void publishToWall() {
        Session session = Session.getActiveSession();

        Bundle postParams = new Bundle();
        postParams.putString("message", message);

        final Context context = this;
        Request.Callback callback = new Request.Callback() {
            public void onCompleted(Response response) {
                FacebookRequestError error = response.getError();
                if (error != null) {
                    setVisibilityForRepublishButton(true);
                    Toast.makeText(context, error.getErrorMessage(), Toast.LENGTH_SHORT).show();
                } else {
                    JSONObject graphResponse = response.getGraphObject().getInnerJSONObject();
                    String postId = null;
                    try {
                        postId = graphResponse.getString("id");
                    } catch (JSONException e) {
                        setVisibilityForRepublishButton(true);
                        Log.i("Facebook error", "JSON error " + e.getMessage());
                    }
                    //Toast.makeText(context, postId, Toast.LENGTH_LONG).show();
                    finish();
                }
            }
        };

        Request request = new Request(Session.getActiveSession(), "me/feed", postParams, HttpMethod.POST, callback);

        RequestAsyncTask task = new RequestAsyncTask(request);
        task.execute();
    }
}
于 2013-01-12T08:48:17.690 に答える
2

私は同じ問題を抱えています.Facebookにログインしようとすると、SDK内にダイアログが表示されますが、それ自体がタブグループ内にあるアクティビティからです。上記のShareActivityのように。

私が行ったことは、基本的に、ShareActivity で呼び出すのではなく、ShareActivity の親アクティビティ (つまり、ShareGroupActivity) で startActivityForResult と呼ばれます。

1 、これを ShareGroupActivity に追加します。

@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
    System.out.println("facebook status called");
    super.onActivityResult(requestCode, resultCode, data);
    Session.getActiveSession().onActivityResult(this, requestCode, resultCode, data);
}

2 FacebookSDK プロジェクト内の src com.facebook の下にあるクラス Session を変更する必要があります。

2.1ブール値のメンバーを追加する

public boolean insideTabGroup;

2.2ログインを開くためにセッションで使用されるStartActivityDelegateを変更します。パラメータとしてブール値を追加

interface StartActivityDelegate {
    public void startActivityForResult(Intent intent, int requestCode, boolean insideTabGroup);

    public Activity getActivityContext();
}

2.3 内部クラス AuthorizationRequest 内で、このデリゲートの実装を変更します。

    AuthorizationRequest(final Activity activity) {
        startActivityDelegate = new StartActivityDelegate() {
            @Override
            public void startActivityForResult(Intent intent, int requestCode, boolean insideTabGroup) {
                if(insideTabGroup) {
                    ActivityGroup parentActivity = (ActivityGroup) activity.getParent();
                    parentActivity.startActivityForResult(intent,requestCode);

                } else {
                    activity.startActivityForResult(intent, requestCode);
                }
            }

            @Override
            public Activity getActivityContext() {
                return activity;
            }
        };
    }

2.4 また、ブーリアン パラメータを追加するだけで、AuthorizationRequest の他のコンストラクタを変更します。アクティビティ以外の場所から facebook へのログインを使用しないので、それで問題ありません。

2.5 Session クラスの tryLoginActivity メソッドを変更して、boolean メンバーをパラメーターとして使用します。

private boolean tryLoginActivity(AuthorizationRequest request) {
    Intent intent = getLoginActivityIntent(request);

    if (!resolveIntent(intent)) {
        return false;
    }

    try {
        request.getStartActivityDelegate().startActivityForResult(intent, request.getRequestCode(),this.insideTabGroup);

    } catch (ActivityNotFoundException e) {
        return false;
    }

    return true;
}

3 セッションにブール値のメンバーを設定します。

Session session = Session.getActiveSession();
session.insideTabGroup = true;

これでうまくいくはずです。

Cdt

于 2013-07-14T14:08:22.870 に答える
0

Parse.com Facebook SDK の統合でも同じエラーが発生し、 docsParseFacebookUtils.finishAuthenticationに記載されている呼び出しが欠落していました。

@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
  super.onActivityResult(requestCode, resultCode, data);
  ParseFacebookUtils.finishAuthentication(requestCode, resultCode, data);
}
于 2014-07-22T17:00:01.037 に答える