私の 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 のコンソール API
BB: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();
何が問題なのかわかりません。おそらく、上記で指定したデバッグ キーを使用してアプリケーションに署名していると思いますが、実際に使用されているキーは別のパスにありますか?