JavaScript Fleet Tracking Library를 사용하기 전에 Fleet Engine을 숙지하고 설정해야 합니다. 자세한 내용은 Fleet Engine을 참고하세요.
이 문서에서는 웹페이지 앱과 Fleet Engine 간의 승인을 사용 설정하는 방법을 보여줍니다. 올바른 승인 토큰으로 Fleet Engine에 대한 요청을 설정하면 지도에서 차량을 추적할 수 있습니다.
승인 설정하기
Fleet Engine에서는 JSON 웹 토큰(JWT)을 사용하여 API 메서드를 호출해야 합니다. 신뢰도가 낮은 환경(스마트폰 및 브라우저)
JWT는 서버에서 생성되고 서명, 암호화되어 만료되거나 더 이상 유효하지 않을 때까지 후속 서버 상호작용을 위해 클라이언트 에 전달됩니다.
주요 세부정보
- 애플리케이션 기본 사용자 인증 정보를 사용하여 Fleet Engine에 대해 인증하고 승인합니다.
- 적절한 서비스 계정을 사용하여 JWT에 서명합니다. Fleet Engine 기본사항에서 Fleet Engine 서비스 계정 역할을 참고하세요.
승인은 어떻게 작동하나요?
Fleet Engine 데이터에 대한 승인에는 서버 측 및 클라이언트 측 구현이 모두 포함됩니다.
서버 측 승인
Fleet Tracking 애플리케이션에서 인증 및 승인을 설정하기 전에 백엔드 서버는 Fleet Engine에 액세스할 수 있도록 Fleet Tracking 애플리케이션에 JSON 웹 토큰을 발급할 수 있어야 합니다. Fleet Tracking 애플리케이션은 이러한 JWT를 요청과 함께 전송하므로 Fleet Engine은 요청을 인증된 것으로 인식하고 요청의 데이터에 액세스할 수 있도록 승인합니다. 서버 측 JWT 구현에 관한 안내는 JSON 웹 토큰 발급을 Fleet Engine 필수사항에서 참고하세요.
Fleet Tracking을 구현할 때 서버에서 토큰을 생성하려면 다음을 참고하세요.- JSON 웹 토큰 발급에 관한 일반 가이드라인, 온디맨드 이동과 예약된 작업 모두에 관한 섹션을 포함하여
- 온디맨드 이동: 백엔드 서버 작업의 토큰 예
- 예약된 작업: Fleet의 모든 작업과 차량을 추적하는 토큰 예
클라이언트 측 승인
JavaScript Fleet Tracking Library를 사용하면 승인 토큰 가져오기 도구를 사용하여 서버에서 토큰을 요청합니다. 다음 중 하나라도 참인 경우 이 작업을 실행합니다.
유효한 토큰이 없습니다. 예를 들어 SDK가 새 페이지 로드 시 가져오기 도구를 호출하지 않았거나 가져오기 도구가 토큰을 반환하지 않은 경우입니다.
토큰이 만료되었습니다.
토큰이 만료되기 1분 전입니다.
그 외의 경우 JavaScript Fleet Tracking Library는 이전에 발급된 유효한 토큰을 사용하며 가져오기 도구를 호출하지 않습니다.
승인 토큰 가져오기 도구 만들기
다음 가이드라인에 따라 승인 토큰 가져오기 도구를 만듭니다.
가져오기 도구는 다음과 같이
Promise로 래핑된 두 개의 필드가 있는 데이터 구조를 반환해야 합니다.문자열
token.숫자
expiresInSeconds. 토큰은 가져온 후 이 시간 동안 만료됩니다. 인증 토큰 가져오기 도구는 만료 시간(초)을 가져온 시간부터 예와 같이 라이브러리에 전달해야 합니다.
가져오기 도구는 서버의 URL을 호출하여 토큰을 가져와야 합니다. 이 URL(
SERVER_TOKEN_URL)은 백엔드 구현에 따라 다릅니다. 다음 예시 URL은 GitHub의 샘플 앱 백엔드용입니다.https://SERVER_URL/token/fleet_reader
예시 - 승인 토큰 가져오기 도구 만들기
다음 예에서는 승인 토큰 가져오기 도구를 만드는 방법을 보여줍니다.
JavaScript
async function authTokenFetcher(options) {
// options is a record containing two keys called
// serviceType and context. The developer should
// generate the correct SERVER_TOKEN_URL and request
// based on the values of these fields.
const response = await fetch(SERVER_TOKEN_URL);
if (!response.ok) {
throw new Error(response.statusText);
}
const data = await response.json();
return {
token: data.Token,
expiresInSeconds: data.ExpiresInSeconds
};
}
TypeScript
function authTokenFetcher(options: {
serviceType: google.maps.journeySharing.FleetEngineServiceType,
context: google.maps.journeySharing.AuthTokenContext,
}): Promise<google.maps.journeySharing.AuthToken> {
// The developer should generate the correct
// SERVER_TOKEN_URL based on options.
const response = await fetch(SERVER_TOKEN_URL);
if (!response.ok) {
throw new Error(response.statusText);
}
const data = await response.json();
return {
token: data.token,
expiresInSeconds: data.ExpiresInSeconds,
};
}