Trước khi sử dụng thư viện theo dõi đội xe JavaScript, hãy đảm bảo rằng bạn đã quen thuộc và thiết lập Fleet Engine. Để biết thông tin chi tiết, hãy xem phần Fleet Engine.
Tài liệu này trình bày cách bật hoạt động uỷ quyền giữa ứng dụng trang web và Fleet Engine. Sau khi thiết lập các yêu cầu đối với Fleet Engine bằng mã thông báo uỷ quyền chính xác, bạn sẽ sẵn sàng theo dõi một chiếc xe trên bản đồ.
Thiết lập lệnh uỷ quyền
Fleet Engine yêu cầu sử dụng Mã thông báo web JSON (JWT) cho các lệnh gọi phương thức API từ môi trường có độ tin cậy thấp: điện thoại thông minh và trình duyệt.
JWT bắt nguồn từ máy chủ của bạn, được ký, mã hoá và chuyển đến máy khách để tương tác với máy chủ sau đó cho đến khi hết hạn hoặc không còn hợp lệ.
Thông tin chi tiết quan trọng
- Sử dụng Thông tin xác thực mặc định của ứng dụng để xác thực và uỷ quyền đối với Fleet Engine.
- Sử dụng tài khoản dịch vụ phù hợp để ký JWT. Xem các vai trò serviceaccount của Fleet Engine trong phần Kiến thức cơ bản về Fleet Engine.
Cơ chế uỷ quyền hoạt động như thế nào?
Việc uỷ quyền bằng dữ liệu Fleet Engine liên quan đến cả việc triển khai phía máy chủ và phía máy khách.
Uỷ quyền phía máy chủ
Trước khi bạn thiết lập quy trình xác thực và uỷ quyền trong ứng dụng Theo dõi đội xe, máy chủ phụ trợ phải có khả năng phát hành Mã thông báo web JSON cho ứng dụng Theo dõi đội xe để truy cập vào Fleet Engine. Ứng dụng Theo dõi đội xe sẽ gửi các JWT này cùng với các yêu cầu của mình để Fleet Engine nhận ra các yêu cầu này là đã được xác thực và được phép truy cập vào dữ liệu trong yêu cầu. Để biết hướng dẫn về cách triển khai JWT phía máy chủ, hãy xem phần Phát hành mã thông báo web JSON trong mục Kiến thức cơ bản về Fleet Engine.
Để tạo mã thông báo từ máy chủ khi triển khai tính năng Theo dõi đội xe, hãy xem phần sau:- Nguyên tắc chung để phát hành mã thông báo web JSON, bao gồm cả các phần cho cả chuyến đi theo yêu cầu và nhiệm vụ theo lịch
- Chuyến đi theo yêu cầu: Ví dụ về mã thông báo cho một thao tác máy chủ phụ trợ
- Các nhiệm vụ theo lịch: Mã thông báo ví dụ để theo dõi tất cả các nhiệm vụ và xe trong đội xe
Uỷ quyền phía máy khách
Khi bạn sử dụng thư viện Theo dõi đội xe bằng JavaScript, thư viện này sẽ yêu cầu mã thông báo từ máy chủ bằng cách sử dụng một trình tìm nạp mã thông báo uỷ quyền. Điều này xảy ra khi một trong các trường hợp sau đây là đúng:
Không có mã thông báo hợp lệ, chẳng hạn như khi SDK chưa gọi trình tìm nạp khi tải trang mới hoặc khi trình tìm nạp chưa trả về mã thông báo.
Mã thông báo đã hết hạn.
Mã thông báo sắp hết hạn (trong vòng 1 phút).
Nếu không, thư viện Theo dõi đội xe bằng JavaScript sẽ sử dụng mã thông báo hợp lệ đã được phát hành trước đó và không gọi trình tìm nạp.
Tạo một trình tìm nạp mã uỷ quyền
Tạo trình tìm nạp mã thông báo uỷ quyền theo các nguyên tắc sau:
Trình tìm nạp phải trả về một cấu trúc dữ liệu có 2 trường, được gói trong một
Promise
như sau:Một chuỗi
token
.Một số
expiresInSeconds
. Mã thông báo sẽ hết hạn sau khoảng thời gian này kể từ khi được tìm nạp. Trình tìm nạp mã thông báo xác thực phải truyền thời gian hết hạn tính bằng giây, từ thời điểm tìm nạp đến thư viện như trong ví dụ.
Trình tìm nạp sẽ gọi một URL trên máy chủ của bạn để truy xuất mã thông báo. URL này (
SERVER_TOKEN_URL
) tuỳ thuộc vào cách triển khai phụ trợ của bạn. URL ví dụ sau đây dành cho phần phụ trợ của ứng dụng mẫu trên GitHub:https://SERVER_URL/token/fleet_reader
Ví dụ: Tạo trình tìm nạp mã uỷ quyền
Các ví dụ sau đây minh hoạ cách tạo một trình tìm nạp mã thông báo uỷ quyền:
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,
};
}