Android Google将API放置在多个开发人员的位置
我们是一个在android应用程序上合作的团队。Android Google将API放置在多个开发人员的位置,android,google-api,google-places-api,Android,Google Api,Google Places Api,我们是一个在android应用程序上合作的团队。 不幸的是,只有使用google places API编写代码的人才能运行该活动,而其他人则不能。 我们在GoogleMapsAPI中遇到了同样的问题,但这是因为我们都使用了相同的API密钥 更改API密钥(每个人都有自己的密钥)后,问题停止。 这是导致崩溃的代码(同样,编写活动的人设法运行它) public void refreshPlacesData(){ Uri Uri=PlaceContract.PlaceEntry.CONTENT\u U
不幸的是,只有使用google places API编写代码的人才能运行该活动,而其他人则不能。
我们在GoogleMapsAPI中遇到了同样的问题,但这是因为我们都使用了相同的API密钥
更改API密钥(每个人都有自己的密钥)后,问题停止。
这是导致崩溃的代码(同样,编写活动的人设法运行它)
public void refreshPlacesData(){
Uri Uri=PlaceContract.PlaceEntry.CONTENT\u Uri;
游标数据=getContentResolver().query(
乌里,
无效的
无效的
无效的
无效);
if(data==null | | data.getCount()==0)返回;
List guids=new ArrayList();
while(data.moveToNext()){
add(data.getString(data.getColumnIndex(PlaceContract.PlaceEntry.COLUMN_PLACE_ID));
}
Pendingreult placeResult=Places.GeoDataApi.getPlaceById(mClient,
toArray(新字符串[guids.size());您可以向PlacesAPI添加多个SHA-1,goto
然后选择GooglePlacesAPI,限制您的Api,然后添加SHA
希望这能有所帮助为什么你们都要制作单独的密钥?为什么不简单地将SHA-1添加到一个密钥中?你认为这与我们遇到的问题有关吗?很明显,你的日志中说是由:java.lang.NullPointerException:GoogleAppClient不能为null引起的
意味着你传递给函数的apiClient为null或未初始化d,但是为所有开发人员提供单独的密钥可能会引起很多麻烦,你们都获得SHA-1并将其添加到一个api密钥中,然后仅在应用程序中使用该json文件,然后该代码将在每个系统上运行让我发布一个答案,不能将图像发布到链接,然后选择你们正在处理的项目如果电子储蓄器,谢谢
public void refreshPlacesData() {
Uri uri = PlaceContract.PlaceEntry.CONTENT_URI;
Cursor data = getContentResolver().query(
uri,
null,
null,
null,
null);
if (data == null || data.getCount() == 0) return;
List<String> guids = new ArrayList<String>();
while (data.moveToNext()) {
guids.add(data.getString(data.getColumnIndex(PlaceContract.PlaceEntry.COLUMN_PLACE_ID)));
}
PendingResult<PlaceBuffer> placeResult = Places.GeoDataApi.getPlaceById(mClient,
guids.toArray(new String[guids.size()])); <---this is where it crash
placeResult.setResultCallback(new ResultCallback<PlaceBuffer>() {
@Override
public void onResult(@NonNull PlaceBuffer places) {
mAdapter.swapPlaces(places);
mGeofencing.updateGeofencesList(places);
if (mIsEnabled) mGeofencing.registerAllGeofences();
}
});
}
E/AndroidRuntime: FATAL EXCEPTION: main
Process: com.rubz.dvir.rubz, PID: 25203
java.lang.RuntimeException: Failure delivering result ResultInfo{who=null, request=1, result=-1, data=Intent { (has extras) }} to activity {com.rubz.dvir.rubz/com.rubz.dvir.rubz.JobRequestActivity}: java.lang.NullPointerException: GoogleApiClient must not be null
at android.app.ActivityThread.deliverResults(ActivityThread.java:3382)
at android.app.ActivityThread.handleSendResult(ActivityThread.java:3425)
at android.app.ActivityThread.access$1300(ActivityThread.java:139)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1248)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:136)
at android.app.ActivityThread.main(ActivityThread.java:5105)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:515)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:792)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:608)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.NullPointerException: GoogleApiClient must not be null
at com.google.android.gms.common.internal.zzbq.zza(Unknown Source)
at com.google.android.gms.common.api.internal.zzm.<init>(Unknown Source)
at com.google.android.gms.location.places.zzm$zzb.<init>(Unknown Source)
at com.google.android.gms.location.places.zzm$zzc.<init>(Unknown Source)
at com.google.android.gms.location.places.internal.zzl.<init>(Unknown Source)
at com.google.android.gms.location.places.internal.zzh.getPlaceById(Unknown Source)
at com.rubz.dvir.rubz.JobRequestActivity.refreshPlacesData(JobRequestActivity.java:445)
at com.rubz.dvir.rubz.JobRequestActivity.onActivityResult(JobRequestActivity.java:515)
at android.app.Activity.dispatchActivityResult(Activity.java:5467)
at android.app.ActivityThread.deliverResults(ActivityThread.java:3378)
at android.app.ActivityThread.handleSendResult(ActivityThread.java:3425)
at android.app.ActivityThread.access$1300(ActivityThread.java:139)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1248)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:136)
at android.app.ActivityThread.main(ActivityThread.java:5105)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:515)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:792)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:608)
at dalvik.system.NativeStart.main(Native Method)
Application terminated.