1

私の Android アプリケーションは、Google Maps API v2 (パッケージで識別されるcom.google.android.gms.maps)と Facebook API ( com.facebook)の 2 つの API を使用します (この最後の API は @RINK のおかげで解決されました)。

両方のサービスは、公式のチュートリアルに従ってプロジェクトにインストールされ、昨日まで正常に機能していましたが、コードの何かが変更され、明らかに何が変わったのかわかりません。原因は、テスト用の電話にインストールされる前にアプリケーションに署名するデバッグ/リリース キーに関連していると確信しています。

特に、デフォルトで個人用フォルダー (Windows + Netbeans) に保存されているデバッグ キーを使用しており、削除するたびに再生成されます: C:\Users\Alessandro\.android\debug.keystore.

マップと Facebook の両方が、そのようなキーの SHA-1 フィンガープリントを知る必要がありますkeytool。それを持って、私はそれを専用の API サービス ページに置きました。

  • 形式の Google のコンソール APIBB:0D:AC:74:D3:21:E1:43:67:71:9B:62:91:AF:A1:66:6E:44:5D:75;com.UpMap
  • Facebook のアプリ開発ページ、キー ハッシュ フィールド。

前述のとおり、すべて正常に機能していましたが、突然、アプリケーションのマップが空白になり、Facebook ログインでエラーが発生しました。

11:24:51.064    1708    #1708   WARN    fb4a(:<default>):BlueServiceQueue   com.facebook.http.protocol.ApiException: remote_app_id does not match stored id 
11:24:51.064    1708    #1708   WARN    fb4a(:<default>):BlueServiceQueue       at com.facebook.http.protocol.ApiResponseChecker.b(ApiResponseChecker.java:74)
11:24:51.064    1708    #1708   WARN    fb4a(:<default>):BlueServiceQueue       at com.facebook.http.protocol.ApiResponseChecker.a(ApiResponseChecker.java:103)
11:24:51.064    1708    #1708   WARN    fb4a(:<default>):BlueServiceQueue       at com.facebook.http.protocol.ApiResponse.h(ApiResponse.java:208)
11:24:51.064    1708    #1708   WARN    fb4a(:<default>):BlueServiceQueue       at com.facebook.katana.server.protocol.AuthorizeAppMethod.a(AuthorizeAppMethod.java:266)
11:24:51.064    1708    #1708   WARN    fb4a(:<default>):BlueServiceQueue       at com.facebook.katana.server.protocol.AuthorizeAppMethod.a(AuthorizeAppMethod.java:27)
11:24:51.064    1708    #1708   WARN    fb4a(:<default>):BlueServiceQueue       at com.facebook.http.protocol.SingleMethodRunnerImpl.a(SingleMethodRunnerImpl.java:141)
11:24:51.064    1708    #1708   WARN    fb4a(:<default>):BlueServiceQueue       at com.facebook.http.protocol.AbstractSingleMethodRunner.a(AbstractSingleMethodRunner.java:16)
11:24:51.064    1708    #1708   WARN    fb4a(:<default>):BlueServiceQueue       at com.facebook.katana.server.handler.PlatformOperationHandler.c(PlatformOperationHandler.java:284)
11:24:51.064    1708    #1708   WARN    fb4a(:<default>):BlueServiceQueue       at com.facebook.katana.server.handler.PlatformOperationHandler.a(PlatformOperationHandler.java:185)
11:24:51.064    1708    #1708   WARN    fb4a(:<default>):BlueServiceQueue       at com.facebook.fbservice.service.BlueServiceQueue.d(BlueServiceQueue.java:245)
11:24:51.064    1708    #1708   WARN    fb4a(:<default>):BlueServiceQueue       at com.facebook.fbservice.service.BlueServiceQueue.d(BlueServiceQueue.java:51)
11:24:51.064    1708    #1708   WARN    fb4a(:<default>):BlueServiceQueue       at com.facebook.fbservice.service.BlueServiceQueue$3.run(BlueServiceQueue.java:191)
11:24:51.064    1708    #1708   WARN    fb4a(:<default>):BlueServiceQueue       at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:441)
11:24:51.064    1708    #1708   WARN    fb4a(:<default>):BlueServiceQueue       at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:305)
11:24:51.064    1708    #1708   WARN    fb4a(:<default>):BlueServiceQueue       at java.util.concurrent.FutureTask.run(FutureTask.java:137)
11:24:51.064    1708    #1708   WARN    fb4a(:<default>):BlueServiceQueue       at com.facebook.common.executors.HandlerExecutorServiceImpl$ListenableScheduledFuture.run(HandlerExecutorServiceImpl.java:268)
11:24:51.064    1708    #1708   WARN    fb4a(:<default>):BlueServiceQueue       at android.os.Handler.handleCallback(Handler.java:587)
11:24:51.064    1708    #1708   WARN    fb4a(:<default>):BlueServiceQueue       at android.os.Handler.dispatchMessage(Handler.java:92)
11:24:51.064    1708    #1708   WARN    fb4a(:<default>):BlueServiceQueue       at android.os.Looper.loop(Looper.java:123)
11:24:51.064    1708    #1708   WARN    fb4a(:<default>):BlueServiceQueue       at android.os.HandlerThread.run(HandlerThread.java:60)

ログイン中にAndroid Facebook SDK 3.0が「remote_app_idが保存されたIDと一致しません」という質問を読みましたが、同じ問題が発生するはずですが、keytoolを使用して生成した「キーハッシュ」は良好です。

私はしようとしました:

  • 保存されたデバッグ キーを削除して再生成し、SHA を更新して Google と Facebook に保存します。
  • Google と Facebook から提供され、AndroidManifest.xml に記述されている API キーが正しいかどうかを確認します
  • アプリのパッケージ名が正しいかどうかを確認します
  • Google と Facebook のソース ライブラリを含むプロジェクト全体をクリーンアップして再構築する

これは私のマニフェストです:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
      package="com.UpMap"
      android:versionCode="1"
      android:versionName="1.0">

    <uses-sdk android:minSdkVersion="8" android:targetSdkVersion="18" />

    <permission android:name="com.UpMap.permission.MAPS_RECEIVE" android:protectionLevel="signature"/>
    <uses-permission android:name="com.UpMap.permission.MAPS_RECEIVE"/>
    <uses-permission android:name="android.permission.INTERNET" />
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/>
    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
    <uses-permission android:name="com.google.android.providers.gsf.permission.READ_GSERVICES"/>

    <uses-feature android:glEsVersion="0x00020000" android:required="true"/>

    <application android:label="@string/app_name" android:allowBackup="true">
        <uses-library android:name="com.google.android.maps" />

        <activity 
            android:name="MainActivity"
            android:label="@string/app_name"
            android:theme="@style/Theme.AppCompat"
            android:screenOrientation="portrait">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />
                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>

        <activity 
            android:name="LevelActivity"
            android:label="@string/app_name"
            android:theme="@style/Theme.AppCompat"
            android:windowSoftInputMode="adjustPan|adjustResize"
            android:screenOrientation="portrait"
            uiOptions="splitActionBarWhenNarrow">
            <meta-data 
                android:name="android.support.UI_OPTIONS"
                android:value="splitActionBarWhenNarrow" />
        </activity>

        <activity 
            android:name="FacebookActivity"
            android:label="@string/app_name"
            android:theme="@style/Theme.AppCompat"
            android:windowSoftInputMode="adjustPan|adjustResize"
            android:screenOrientation="portrait">
        </activity>

         <activity android:name="com.facebook.LoginActivity"/>

        <meta-data
            android:name="com.google.android.maps.v2.API_KEY"
            android:value="<HIDDEN_GOOGLE_KEY>"
        />

        <meta-data 
            android:name="com.facebook.sdk.ApplicationId" 
            android:value="@string/fb_app_id"/>

    </application>
</manifest> 

これは、Google マップを表示するアクティビティのコードです。

<?xml version="1.0" encoding="UTF-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:id="@+id/LevelLayout">

    <TextView  
        android:layout_width="match_parent" 
        android:layout_height="wrap_content" 
        android:text="@string/where_is_it"
        android:textSize="28sp"
        android:layout_margin="5dp"
        android:layout_marginBottom="0dp"
    />

    <LinearLayout
            android:id="@+id/SolutionLayout"
            android:orientation="horizontal"
            android:layout_width="match_parent"
            android:layout_height="40dp"
            android:layout_margin="5dp"
            android:background="#000000"
            android:gravity="center"
        >
    </LinearLayout>

    <FrameLayout
        android:layout_width="match_parent"
        android:layout_height="300dp"
    >   
        <fragment 
            class="com.google.android.gms.maps.SupportMapFragment"
            xmlns:map="http://schemas.android.com/apk/res-auto"
            android:id="@+id/TheMap"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            map:mapType="satellite"
            map:uiRotateGestures="false"
            map:uiScrollGestures="false"
            map:uiTiltGestures="false"
            map:uiZoomControls="false"
            map:uiZoomGestures="false"
        />

        <LinearLayout
            android:id="@+id/MapOverlay"
            android:clickable = "true"
            android:onClick="mapOverlayClick"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:paddingTop="80dp"
            android:paddingBottom="80dp"
            android:paddingLeft="20dp"
            android:paddingRight="20dp"
            android:background="#00000000"
        >   
            <TextView  
                android:id="@+id/HintView"
                android:layout_width="match_parent" 
                android:layout_height="match_parent"
                android:textSize="15sp"
                android:background="#AA000000"
                android:padding="10dp"
                android:gravity="center"
                android:visibility="invisible"
            />
        </LinearLayout>

    </FrameLayout>

</LinearLayout>

そして、次の行を使用して、コードで GoogleMap オブジェクトを取得します。

GoogleMap theMap = ((SupportMapFragment) getSupportFragmentManager().findFragmentById(R.id.TheMap)).getMap();

何が問題なのかわかりません。おそらく、上記で指定したデバッグ キーを使用してアプリケーションに署名していると思いますが、実際に使用されているキーは別のパスにありますか?

4

2 に答える 2

1

このような同じ問題に直面しています。私の問題は、Facebook に送信されたキー ハッシュを出力することで解決されます。キーハッシュを取得するためにこのコードを入力してください

try {
    PackageInfo info = getPackageManager().getPackageInfo(
          "com.facebook.login", PackageManager.GET_SIGNATURES);
    for (Signature signature : info.signatures) 
        {
           MessageDigest md = MessageDigest.getInstance("SHA");
           md.update(signature.toByteArray());
           Log.d("KeyHash:", Base64.encodeToString(md.digest(), Base64.DEFAULT));
        }
    }
} catch (NameNotFoundException e) {
} catch (NoSuchAlgorithmException e) {
}
于 2013-08-16T09:51:45.443 に答える