Я использую API конечных точек из облака Google и отправляю двойные значения, которые преобразуются из float в Android. В большинстве случаев это работает хорошо, но я заметил, что при небольшом количестве устройств я получаю следующую ошибку:
ошибка 400, неверный запрос
{
"code": 400,
"errors": [{
"domain": "global",
"location": "longitude",
"locationType": "parameter",
"message": "Invalid double value: '116.31765747070313'.",
"reason": "invalidParameter"
}],
"message": "Invalid double value: '116.31765747070313'."
}
Вот код на стороне андроида:
void callEndpoints(final int level, final float latitude, final float longitude) {
try {
API.GetPlacesFromLocationV2 remoteData = cbAPI.getPlacesFromLocationV2();
remoteData.setLatitude((double)latitude);
remoteData.setLongitude((double)longitude);
remoteData.setLevel((long) level);
Result res = remoteData.execute();
//Do stuff with res
} catch (IOException e) {
//print error
}
}
Вот код на стороне сервера Python.
PLACES_LOCATION_SEARCH_V2_CONTAINER = endpoints.ResourceContainer(
message_types.VoidMessage,
level=messages.IntegerField(1),
longitude=messages.FloatField(2),
latitude=messages.FloatField(3)
)
def getCellIdx(level, lon, lat):
scale = pow(2, level)
cellWidth = FULL_WIDTH / scale
cellHeight = FULL_HEIGHT / scale
wIdx = int((lon + 180.0) / cellWidth)
hIdx = int((lat + 90.0) / cellHeight)
return level * 100000000 + hIdx * 10000 + wIdx
@endpoints.method(PLACES_LOCATION_SEARCH_V2_CONTAINER,
DataCollection,
path="getPlacesFromLocation_v2", http_method='GET',
name="getPlacesFromLocation_v2")
def getPlacesFromLocation_v2(self, request):
cellIdx = placesGridSearch.getCellIdx(request.level,request.longitude,request.latitude)
#Do stuff with cellIdx, includes datastore access and memcache usage
return DataCollection(cellIdx)
Спасибо за вашу помощь.
Изменить: некоторая дополнительная информация. Я получаю ту же ошибку, если запускаю ее через проводник API с тем же значением долготы в облаке, но не запускаю ее на своем локальном сервере разработки. Также похоже, что функция endpoints никогда не вызывается (журнала нет), но есть журнал /_ah/spi/BackendService.logMessages, описывающий точно такую же ошибку.