오류
오류가 발생하면 표준 형식 오류 응답 본문이 반환되고 HTTP 상태 코드가 오류 상태로 설정됩니다.
응답에는 다음 키가 있는 단일 error 객체가 포함된 객체가 포함됩니다.
code: 응답의 HTTP 상태와 동일합니다.message: 오류에 대한 간략한 설명입니다.status: 오류의 특성을 나타내는 상태 코드입니다.
예를 들어 잘못된 placeId 매개변수를 전송하면 다음 오류가 반환됩니다.
{ "error": { "code": 400, "message": "\"placeId\" value is malformed: \"aChIJqaknMTeuEmsRUYCD5Wd9ARM\"", "status": "INVALID_ARGUMENT" } }
가능한 오류는 다음과 같습니다.
| 코드 | 상태 | 메시지 | 문제 해결 |
|---|---|---|---|
| 400 | INVALID_ARGUMENT |
제공한 키가 잘못되었습니다. | API 키가 유효하지 않거나 요청에 포함되지 않았습니다. 전체 키를 포함하고 이 키에 API를 사용 설정했는지 확인하세요. |
| 400 | INVALID_ARGUMENT |
'\"path\" 매개변수에 잘못된 값(☃)이 포함되어 있습니다.' | 요청에 잘못된 인수가 포함되어 있습니다. 이 오류의 가장 가능성 높은 원인은 다음과 같습니다.
더 이상 존재하지 않는 도로 또는 도로가 아닌 장소에 |
| 403 | PERMISSION_DENIED |
등록되지 않은 요청이 차단되었습니다. Google Developers Console을 사용하여 가입하세요. | 다음 중 하나 이상의 이유로 인해 요청이 거부되었습니다.
Google Maps Platform 제품을 사용하려면 계정에서 결제를 사용 설정해야 하고 모든 요청에 유효한 API 키를 포함해야 합니다. 이 문제를 해결하려면 다음 단계를 따르세요.
|
| 404 | NOT_FOUND |
이 서비스에는 HTTPS가 필요합니다. |
http://roads.googleapis.com/가 아닌
https://roads.googleapis.com/로 요청을 전송하고 있는지 확인하세요. |
| 429 | RESOURCE_EXHAUSTED |
프로젝트 요청 한도에 도달하여 요청이 제한되었습니다. | Google Cloud Platform Console에서 구성한 요청 한도를 초과했습니다. 이 한도는 일반적으로 일일 요청 수, 100초당 요청 수, 사용자별 100초당 요청 수로 설정됩니다. 이 한도는 단일 사용자 또는 소규모 사용자 그룹이 일일 할당량을 소진하지 못하도록 구성해야 하지만 모든 사용자가 합리적으로 액세스할 수 있도록 해야 합니다. 이러한 한도를 구성하려면 API 사용량 상한 설정 을 참고하세요. |
지수 백오프
요청이 실패하면 지수 백오프로 요청을 재시도해야 합니다. 예를 들어 요청이 한 번 실패하면 1초 후에 재시도하고, 다시 실패하면 2초 후에 재시도한 다음 4초 후에 재시도하는 식으로 재시도합니다. 이렇게 하면 많은 클라이언트가 요청을 매우 빠르게 재시도하려고 하므로 손상된 요청이나 대규모 오류로 인해 Google 서버가 과부하되지 않습니다.
문제해결 FAQ
구현 문제
- 차량 위치를 샘플링해야 하는 빈도는 어느 정도인가요?
- 고품질의 도로 스냅 결과를 얻으려면 1~10초마다 샘플링하는 것이 좋습니다.
- 쿼리당 전송할 수 있는 포인트 수에 제한이 있나요?
- 예, 쿼리는 최대 100개의 포인트를 포함할 수 있습니다.
- 스냅된 위도/경도 쌍을 저장하는 데 사용해야 하는 정밀도 수준은 어느 정도인가요?
- 최대 확대/축소 수준에서도 스냅된 경로가 모든 확대/축소 수준에서 도로를 따르도록 하려면 스냅된 위도/경도 쌍을 소수점 이하 7자리 정밀도로 저장해야 합니다.
- 인코딩된 폴리라인을 사용하여 스냅된 경로를 표시할 수 있나요?
- 인코딩된 폴리라인은 소수점 이하 5자리 정밀도로만 지정되므로 약 2미터의 오류가 발생합니다. 따라서 스냅된 경로가 높은 확대/축소 수준에서 도로를 따르도록 하려면 인코딩된 폴리라인이 적합하지 않습니다.
일반적인 문제
- 일부 포인트가 스냅되지 않거나 스냅된 경로에 간격이 있습니다. 이를 수정하려면 어떻게 해야 하나요?
- 확대할 때 스냅된 경로가 들쭉날쭉하거나 도로에서 약간 벗어나는 이유는 무엇인가요?
-
- 스냅된 위도/경도 쌍을 표시하기 전에 정밀도를 자르고 있나요? 스냅된 위도/경도 쌍을 소수점 이하 7자리 미만의 정밀도로 저장하면 스냅된 경로가 지도에 표시될 때 정밀도 오류가 발생합니다.
- 인코딩된 폴리라인을 사용하고 있나요? 인코딩된 폴리라인은 위도/경도 쌍을 소수점 이하 5자리로 자르므로 수 미터의 오류가 발생하여 높은 확대/축소 수준에서 들쭉날쭉하거나 도로에서 약간 벗어나는 선이 생성됩니다.
위의 두 가지 경우가 모두 해당하지 않는다면 지도 타일이 최근에 업데이트되어 스냅에 사용되는 도로 색인과 동기화되지 않았을 수 있습니다. 일부 쿼리만 영향을 받는다면 이것이 원인일 가능성이 높습니다. Google 지도는 정기적으로 업데이트되므로 이 문제가 가끔 발생할 수 있으며, 지도에서 오래된 경로 (예: 몇 주 전에 스냅된 경로)를 정기적으로 보는 경우 더 자주 발생할 수 있습니다. 최적의 시각화를 위해서는 지도 타일과 스냅에 사용되는 도로 색인 간의 불일치를 최소화하기 위해 지도에 표시하기 직전에 오래된 경로를 다시 스냅해야 합니다.
- 도로 X의 제한 속도가 잘못 표시되는 원인은 무엇인가요?
- 제한 속도는 정확도와 적용 범위가 다양한 여러 소스에서 가져옵니다.
예를 들어 특정 도로 유형 또는 특정 지역의 제한 속도가 지속적으로 잘못되는 패턴을 발견한 경우 다음 단계를 따라 Google에 알려주세요.
- 데스크톱 컴퓨터에서 Google 지도를 열거나 Android용 Google 지도 앱을 엽니다.
- 왼쪽 메뉴를 엽니다.
- 의견 보내기 를 선택합니다. 참고: 로그인하라는 메시지가 표시될 수 있습니다.
- 지도 수정 을 선택합니다.
- 수정할 도로 구간을 선택합니다.
- 다음 을 선택합니다.
- '기타' 필드에서 해당 도로의 제한 속도가 잘못되었다고 표시합니다.
- 제출 을 선택합니다.
- 스냅된 경로가 도로를 따라가지 않고 모퉁이를 자르는 이유는 무엇인가요?
-
이 문제를 해결하려면 다음을 확인하세요.
interpolate매개변수가true로 설정되어 있는지 확인합니다.- 원래 데이터 포인트가 충분히 가까운 간격(1~10초마다)으로 샘플링되는지 확인합니다.
- 제한 속도 변경이 없는 도로의 스냅된 경로에 많은 도로 구간이 반환되는 이유는 무엇인가요?
interpolate매개변수가true로 설정되면 도로 스냅 쿼리는 모퉁이, 곡선, 로터바우트를 따라 도로를 따르는 폴리라인을 반환합니다. 도로가 곡선인 경우 제한 속도가 변경되지 않더라도 도로 형상을 밀접하게 따르는 폴리라인을 만들기 위해 여러 도로 구간이 반환됩니다.