客户端使用SecurityAccess Service请求安全解锁服务端,SecurityAccess Service用于将客户端的数据上传到服务端或者将服务器的数据下载到服务端时候的安全访问。
客户端使用SecurityAccess Service请求安全解锁服务端流程如下所示:
第1步:客户端发送seed请求;
第2步:服务端发出seed;
第3步:客户端发送key密钥,依据服务端发出的seed进行处理;
第4步:服务端解析客户端发过来的key密钥,如果无误则完成安全解锁功能。
1
诊断请求
客户端发送seed请求协议:0X27 0X** 0X&&(A_Data.A_PCI.SI和A_Data.Parameter 1~k数据)。
其中:
0X27是服务ID(SID),1字节;
0X**是服务的子功能,当requestSeed为奇数时发送send命令,范围为:0X01~0X7F中的奇数,1字节;
0X&&是可选项,用于在请求种子信息时将数据传输到服务器,它可以包含服务端中验证的客户端标识,长度不固定。
客户端发送key密钥协议:0X27 0X** 0X&&(A_Data.A_PCI.SI和A_Data.Parameter 1~k数据)。
其中:
0X27是服务ID(SID),1字节;
0X**是服务的子功能,当sendKey为偶数时发送key密钥命令,范围为:0X01~0X7F中的偶数,1字节;
0X&&的值是通过将获取服务端发出seed数值进行安全算法生成的,所以这个值是随着服务端发出seed数值的变化而变化,长度不固定。
在ISO 14229-1-2020协议中规定了各类requestSeed和sendKey的意义和使用场景,如下所示:
标准中也规定了seed请求和key密钥的对应关系:
2
诊断响应
诊断响应有肯定响应和否定响应两种类型。
2.1、肯定响应
肯定响应表示服务端回复客户端请求成功,响应协议:0X67 0X** 0X&&(A_Data.A_PCI.SI和A_Data.Parameter 1~k数据)。
其中:
0X67是响应服务的SID,相当于0X27+0X40,1字节;
0X**是响应服务的子功能,范围为:0X00~0X7F,1字节。例如,客户端使用0X01子服务,此时肯定响应的子服务就是0X01;
0X&&的存在取决于securityAccessType参数,seed参数是服务端发来的数据,客户端在安全访问服务端时需要使用该值计算密钥,长度不固定。
2.2、否定响应
否定响应表示客户端或者服务端存在问题,否定响应会提示失败原因。
响应协议:0X7F 0X** 0X&&(A_Data.A_PCI.NR_SI、A_Data.A_PCI. SI和A_Data.Parameter 1数据)。
其中:
0X7F是否定响应固定数值,1字节;
0X**是诊断服务ID(SID),本篇博文使用的是0X27服务,则否定响应会返回0X27,1字节;
0X&&是NRC错误码,描述了返回错误的原因,1字节。
SecurityAccess Service(SID:0X27)有8种类型错误,如下所示:
审核编辑:刘清
-
PCI
+关注
关注
4文章
663浏览量
130250 -
SID
+关注
关注
0文章
14浏览量
3026
原文标题:详解UDS CAN诊断:SecurityAccess Service(SID:0X27)
文章出处:【微信号:美男子玩编程,微信公众号:美男子玩编程】欢迎添加关注!文章转载请注明出处。
发布评论请先 登录
相关推荐
评论