我有一个带有地图和编辑文本的屏幕,用户可以在其中键入位置。这些地图来自Mapbox,但其地理编码不够好,所以我想使用Google提供的地图。 当用户输入时,他应该根据他正在键入的地址看到建议位置的列表。当他点击任何一个时,地图上应该放一个别针。 我在开发人员的控制台中创建了一个项目,生成了一个限制Android设备的API密钥。发送请求时使用密钥。 我定义了一个像这样的Retrofit界面
public interface GeocodingApi {
String PATH = "maps/api/geocode/json";
String KEY_ADDRESS = "address";
String KEY_KEY = "key";
String KEY_LANGUAGE = "language";
@GET(PATH)
Single<GeocodingResponse> getPlaces(
@Query(value = KEY_ADDRESS, encoded = true) String address,
@Query(KEY_KEY) String apiKey,
@Query(KEY_LANGUAGE) String language
);
}
然后我提出这样的请求
disposable = getGeocodingApi()
.getPlaces(addressName, getApiKey(), getLanguage())
.subscribeOn(Schedulers.io())
.subscribe(
response -> {
if (!"OK".equals(response.getStatus())) {
final String errorMessage = response.getErrorMessage();
if (errorMessage != null) {
Log.i(TAG, errorMessage);
}
return;
}
final List<AddressResponse> addresses = response.getAddresses();
for (final AddressResponse address : addresses) {
final String formattedAddress = address.getFormattedAddress();
if (formattedAddress != null) {
Log.i(TAG, formattedAddress);
}
final GeometryResponse geometry = address.getGeometry();
final double lat = geometry.getLocation().getLat();
final double lon = geometry.getLocation().getLon();
Log.i(TAG, "Lat: " + lat + ", lon: " + lon + "\n");
}
},
error -> Log.e(TAG, error.toString())
);
但我得到的是一个错误,说我的IP地址,网站或设备无权使用此API密钥。这是为什么?在生成api密钥时,我使用SHA1指纹指定了我的应用程序包名称。 有人可以帮我解决这个问题吗?
答案 0 :(得分:0)
通过删除开发者控制台中的api密钥限制解决了该问题。您可以创建一个没有任何限制的新密钥,也可以更改当前密钥的限制,并等待最多5分钟以使设置生效。