JSON Web 令牌 (JWT) 是一种开放式 Web 标准,用于在客户端和服务器之间进行身份验证和授权信息交换。当应用用户首次使用适当的角色凭据登录时,服务器会创建并返回经过编码且经过数字签名的 JWT,以供后续请求使用。此过程既会对用户进行身份验证,还会根据用户的账号角色授予他们访问路线、服务和资源的权限。
Fleet Engine 要求从低信任环境(智能手机和浏览器)进行 API 方法调用时,使用 JSON Web 令牌 (JWT)。
JWT 起源于您的服务器,经过签名和加密后传递给客户端,以便在到期或失效之前进行后续服务器互动。
关键详情
- 使用应用默认凭据对 Fleet Engine 进行身份验证和授权。
- 使用适当的服务账号为 JWT 签名。如需了解 Fleet Engine 服务账号角色,请参阅 Fleet Engine 基础知识。
与 API 密钥不同,JWT 的有效期较短,并且仅限于角色有权执行的操作。如需详细了解 JWT,请参阅 Wikipedia 上的 JSON Web 令牌。如需详细了解访问权限角色,请参阅本指南中的服务账号角色。
JWT 元素
JWT 包含标头和声明部分。标头部分包含从服务账号获取的私钥和加密算法等信息。声明部分包含 JWT 的创建时间、有效期、JWT 声明有权访问的服务,以及用于限定访问权限的其他授权信息,例如传送车辆 ID。
下表简要介绍了 JWT 字段的一般信息,以及在 Fleet Engine Cloud 项目中可以找到这些字段值的位置的具体信息。
字段 |
说明 |
---|---|
alg |
要使用的算法。`RS256`。 |
typ |
令牌的类型。`JWT`。 |
儿童 |
您的服务账号的私钥 ID。您可以在服务账号 JSON 文件的 |
字段 |
说明 |
---|---|
iss |
服务账号的电子邮件地址,可在服务账号 JSON 文件的 |
sub |
服务账号的电子邮件地址,可在服务账号 JSON 文件的 |
aud |
您的服务账号的 |
iat |
JWT 的创建时间戳,以 00:00:00 |
exp |
JWT 到期的时间戳,以 |
授权 |
根据用例,可能包含 如果指定 taskid,授权范围必须是以下某种形式的数组: "taskids": ["task_id_one","task_id_two"]
或 "taskids": ["*"] |
Fleet Engine JWT 声明
Fleet Engine 使用私有声明。使用私密声明可确保只有获授权的客户端才能访问自己的数据。
例如,当您的服务器为驾驶员的移动设备签发 JSON Web 令牌时,应包含 vehicleid
声明或 deliveryvehicleid
声明,其中包含该驾驶员的车辆 ID 的值。然后,根据驾驶员角色,JWT 仅允许对特定车辆 ID 进行访问,而不会允许对任何其他任意车辆 ID 进行访问。
Fleet Engine 使用以下私有声明:
按需行程
-
vehicleid
:- 无论是在行程还是车辆上运行,Driver SDK 始终都会使用此声明。车队引擎后端会先确保车辆与所请求的行程相关联,然后再进行修改。
- JWT 可以涵盖车辆和行程操作(即使不需要),这可能会简化 JWT 签名实现。
-
tripid
:- 消费者 SDK 始终使用此声明。
- JWT 可以涵盖车辆和行程操作,即使不需要也可以,这可能会简化令牌签名实现。
计划任务
-
deliveryvehicleid
在调用按运输车辆的 API 时使用。
-
taskid
在调用每个任务 API 时使用。
-
taskids
在调用
BatchCreateTasksAPI
时使用。此声明必须采用数组形式,并且数组应包含完成请求所需的所有任务 ID。请勿添加delivervehicleid
、trackingid
或taskid
声明。 -
trackingid
调用
GetTaskTrackingInfoAPI
时使用。声明必须与请求中的跟踪 ID 一致。请勿添加delivervehicleid
、taskid
或taskids
声明。
后续步骤
- 如需了解完整的身份验证流程,请参阅 Fleet Engine 安全设计。
- 了解如何从服务器发出 JSON Web 令牌。