CN111746464B - 防盗校验的匹配码生成方法及装置 - Google Patents
防盗校验的匹配码生成方法及装置 Download PDFInfo
- Publication number
- CN111746464B CN111746464B CN202010623921.9A CN202010623921A CN111746464B CN 111746464 B CN111746464 B CN 111746464B CN 202010623921 A CN202010623921 A CN 202010623921A CN 111746464 B CN111746464 B CN 111746464B
- Authority
- CN
- China
- Prior art keywords
- controller
- matching code
- code
- random number
- matching
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Active
Links
Images
Classifications
-
- B—PERFORMING OPERATIONS; TRANSPORTING
- B60—VEHICLES IN GENERAL
- B60R—VEHICLES, VEHICLE FITTINGS, OR VEHICLE PARTS, NOT OTHERWISE PROVIDED FOR
- B60R25/00—Fittings or systems for preventing or indicating unauthorised use or theft of vehicles
- B60R25/20—Means to switch the anti-theft system on or off
Landscapes
- Engineering & Computer Science (AREA)
- Mechanical Engineering (AREA)
- Lock And Its Accessories (AREA)
- Burglar Alarm Systems (AREA)
Abstract
本发明提供了一种防盗校验的匹配码生成方法及装置,涉及汽车技术领域,该方法包括:分别获取第一控制器和第二控制器对应的标志位的数值;其中,标志位的数值用于表示是否写入匹配码;根据标志位的数值,判断第一控制器和第二控制器中是否有至少一个未写入匹配码;如果是,通过执行匹配码匹配操作生成目标匹配码,目标匹配码用于在第一控制器与第二控制器之间进行防盗校验。本发明能够有效降低匹配码匹配的操作难度。
Description
技术领域
本发明涉及密码校验技术领域,尤其是涉及防盗校验的匹配码生成方法及装置。
背景技术
在汽车上,为了确保控制器交互的唯一,保证整车安全性,一般会先要求控制器之间进行防盗校验,校验通过后才允许车辆后续动作。在进行防盗校验过程中,为了确保校验双方的唯一性,需要防盗校验双方控制器之间具备唯一匹配的匹配码,这个唯一的匹配码可以保证双方控制器是一一匹配的。在目前的方案中,这个唯一的匹配码都是在汽车下线时,通过诊断仪对两个控制器进行下入的;在后期如果更换任意控制器时,为了确保唯一性,这两个控制器都需要重新写入新的匹配码;这种方案操作较麻烦,需要有诊断仪且要求操作人员有一定的操作经验。
发明内容
有鉴于此,本发明的目的在于提供一种防盗校验的匹配码生成方法及装置,能够有效降低匹配码匹配的操作难度。
为了实现上述目的,本发明实施例采用的技术方案如下:
第一方面,本发明实施例提供了一种防盗校验的匹配码生成方法,所述方法应用于进行防盗校验的第一控制器与第二控制器,所述方法包括:分别获取所述第一控制器和所述第二控制器对应的标志位的数值;其中,所述标志位的数值用于表示是否写入匹配码;根据所述标志位的数值,判断所述第一控制器和所述第二控制器中是否有至少一个未写入匹配码;如果是,通过执行匹配码匹配操作生成目标匹配码,所述目标匹配码用于在所述第一控制器与所述第二控制器之间进行防盗校验。
进一步,所述方法还包括:设置所述第一控制器的第一初始匹配码和与所述第一初始匹配码对应的第一标志位;其中,所述第一标志位置于零时表示所述第一控制器未写入所述第一初始匹配码;所述第一初始匹配码为0xFFFF;设置所述第二控制器的第二初始匹配码和与所述第二初始匹配码对应的第二标志位;其中,所述第二标志位置于零时表示所述第二控制器未写入所述第二初始匹配码;所述第二初始匹配码为0x0000。
进一步,所述根据所述标志位的数值,判断所述第一控制器和所述第二控制器中是否有至少一个未写入匹配码的步骤,包括:判断所述第一标志位是否置于零,以及判断所述第二标志位是否置于零;当所述第一标志位为零时,确定所述第一控制器未写入所述第一初始匹配码;当所述第二标志位为零时,确定所述第二控制器未写入所述第二初始匹配码。
进一步,当所述第一控制器和所述第二控制器均未写入匹配码时,所述通过执行匹配码匹配操作生成目标匹配码的步骤,包括:所述第一控制器基于预设的校验算法生成第一seed;将所述第一seed发送给所述第二控制器,以使所述第二控制器反馈第一密码;其中,所述第一密码为所述第二控制器在接收到所述第一seed后,基于所述校验算法和所述第一初始匹配码生成的;所述第一控制器对所述第一密码进行校验,并当校验成功时生成第一随机数;其中,所述第一随机数不同于所述第一初始匹配码且不同于所述第二初始匹配码;将所述第一随机数发送给所述第二控制器,并在所述第二控制器基于所述第一随机数反馈写入匹配码的第二标志位后,确定将所述第一随机数作为目标匹配码。
进一步,所述第一控制器对所述第一密码进行校验的步骤,包括:所述第一控制器判断是否在第一预设时间内接收到所述第一密码;如果接收到,校验所述第一密码与所述第一seed是否一致;如果一致,确定校验成功;如果不一致,确定校验失败,并执行所述将所述第一seed发送给所述第二控制器的步骤;所述方法还包括:当校验失败的次数达到第一预设次数时,停止防盗校验并上报校验匹配失败故障。
进一步,所述将所述第一随机数发送给所述第二控制器,并在所述第二控制器基于所述第一随机数反馈写入匹配码的第二标志位后,确定将所述第一随机数作为目标匹配码的步骤,包括:所述第一控制器在所述第一密码校验成功后的第二预设时间内,将所述第一随机数发送给所述第二控制器,以使所述第二控制器将所述第一随机数作为目标匹配码写入存储器后,向所述第一控制器反馈匹配码成功写入标志;所述第一控制器判断是否在第三预设时间内接收到所述第二控制器反馈的匹配码成功写入标志;如果是,确定将所述第一随机数作为目标匹配码写入存储器;如果否,将所述第一随机数重新发送给所述第二控制器;所述方法还包括:当重新发送所述第一随机数的次数达到第二预设次数时,停止防盗校验并上报校验匹配失败故障。
进一步,所述第一控制器基于预设的校验算法生成第一seed的步骤,包括:所述第一控制器生成第二随机数,并根据预设的校验算法对所述第二随机数和所述第二初始匹配码进行处理,得到第一seed;其中,所述校验算法包括MD5校验算法。
进一步,所述第二控制器反馈第一密码的步骤,包括:所述第二控制器在成功接收到所述第一seed后,判断所述第一seed的低32位是否为所述第二初始匹配码;如果是,基于所述校验算法和所述第一初始匹配码生成第一密码。
进一步,当所述第一控制器未写入匹配码且所述第二控制器写入匹配码时,所述通过执行匹配码匹配操作生成目标匹配码的步骤,包括:所述第二控制器基于预设的校验算法生成第二seed;将所述第二seed发送给所述第一控制器,以使所述第一控制器反馈第二密码;其中,所述第二密码为所述第一控制器在接收到所述第二seed后,基于所述校验算法和所述第二初始匹配码生成的;所述第二控制器对所述第二密码进行校验,并当校验成功时生成第三随机数;其中,所述第三随机数不同于所述第一初始匹配码且不同于所述第二初始匹配码;将所述第三随机数发送给所述第一控制器,并在所述第一控制器基于所述第三随机数反馈写入匹配码的第一标志位后,确定将所述第三随机数作为目标匹配码。
第二方面,本发明实施例还提供一种防盗校验的匹配码生成装置,所述装置应用于进行防盗校验的第一控制器与第二控制器,所述装置包括:获取模块,用于分别获取所述第一控制器和所述第二控制器对应的标志位的数值;其中,所述标志位的数值用于表示是否写入匹配码;判断模块,用于根据所述标志位的数值,判断所述第一控制器和所述第二控制器中是否有至少一个未写入匹配码;生成模块,用于在是的情况下,通过执行匹配码匹配操作生成目标匹配码,所述目标匹配码用于在所述第一控制器与所述第二控制器之间进行防盗校验。
第三方面,本发明实施例还提供一种电子设备,包括处理器和存储装置;所述存储装置上存储有计算机程序,所述计算机程序在被所述处理器运行时执行上述第一方面所述的方法。
第三方面,本发明实施例还提供一种计算机可读存储介质,所述计算机可读存储介质上存储有计算机程序,所述计算机程序被处理器运行时执行上述第一方面所述的方法的步骤。
本发明提供了一种防盗校验的匹配码生成方法及装置,该匹配码生成方法首先分别获取第一控制器和第二控制器对应的标志位的数值,该标志位的数值用于表示是否写入匹配码,然后由此判断第一控制器和第二控制器中是否有至少一个未写入匹配码;如果是,通过执行匹配码匹配操作生成用于在第一控制器与第二控制器之间防盗校验的目标匹配码。本实施例提供的上述方式,双方控制器能够根据标志位的数值,自动识别匹配码是否写入或控制器是否更新,如果有任一控制器未写入匹配码,则双方控制器之间自动执行匹配码匹配操作,从而避免了整车下线时的匹配码写入操作,也避免了更换控制器后需要通过重新进行匹配码匹配的操作;因此,上述匹配码生成方式有效降低了匹配码匹配的操作难度。
本发明的其他特征和优点将在随后的说明书中阐述,或者,部分特征和优点可以从说明书推知或毫无疑义地确定,或者通过实施本公开的上述技术即可得知。
为使本发明的上述目的、特征和优点能更明显易懂,下文特举较佳实施例,并配合所附附图,作详细说明如下。
附图说明
为了更清楚地说明本发明具体实施方式或现有技术中的技术方案,下面将对具体实施方式或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图是本发明的一些实施方式,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
图1示出了本发明实施例所提供的一种防盗校验的匹配码生成方法流程图;
图2示出了本发明实施例所提供的一种匹配码匹配方法信令图;
图3示出了本发明实施例所提供的另一种匹配码匹配方法信令图;
图4示出了本发明实施例所提供的一种防盗校验的匹配码生成装置的结构框图。
具体实施方式
为使本发明实施例的目的、技术方案和优点更加清楚,下面将结合附图对本发明的技术方案进行清楚、完整地描述,显然,所描述的实施例是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。
在汽车上,一般会先要求控制器之间进行防盗校验,校验通过后才允许车辆后续动作。比如乘用车常用的防盗认证,先需要BCM(车声控制器)或者PEPS(无钥匙进入启动系统)和ECU(发动机控制器)进行IMMO认证,认证通过后发动机才允许启动。在进行校验的时候,需要防盗校验双方控制器具备唯一匹配的匹配码;在一种具体实现过程中,发起校验的控制器随机生产一个随机码,接受随机码的控制器将随机码和匹配码组合成一个数据,经过加密算法计算后,得到解密密码A,然后发送给发起校验的控制器;发起校验的控制器会根据随机码和匹配码同步计算解密密码A',若A和A'这两者密码一致,则认为双方校验通过,可以进行后续动作。
可以看出,两个控制器之间的唯一的匹配码是校验的基础。然而,在目前的方案中,这个唯一的匹配码都是在汽车下线时,通过诊断仪对两个控制器进行下入的;在后期如果任意控制器需要更换时,为了确保唯一性,这两个控制器都需要重新写入新的匹配码;这种方案操作较麻烦,需要有诊断仪且要求操作人员有一定的操作经验。基于此,为改善以上问题至少之一,本发明实施例提供了一种防盗校验的匹配码生成方法及装置,能够有效降低匹配码匹配的操作难度。为便于理解,以下对本发明实施例进行详细介绍。
实施例一:
本实施例提供了一种防盗校验的匹配码生成方法,该方法可应用于进行防盗校验的第一控制器与第二控制器。参照图1所示的防盗校验的匹配码生成方法流程图,该方法具体包括如下步骤S102至步骤S106:
步骤S102,分别获取第一控制器和第二控制器对应的标志位的数值;其中,标志位的数值用于表示是否写入匹配码。
为了保证第一控制器和第二控制器是唯一匹配的,需要第一控制器和第二控制器之间能够相互识别的匹配码。在实际应用中,第一控制器和第二控制器通常可以根据同一个64位的seed,按照同一个加密算法计算解密密码,通过对比两个解密密码是否一致来确定校验是否通过。基于此,本实施例可以将Seed其中的低32位作为唯一的匹配码,并通过如下方法预先设置控制器的标志位,包括:
设置第一控制器的第一初始匹配码和与第一初始匹配码对应的第一标志位;其中,第一标志位置于零时表示第一控制器未写入第一初始匹配码;第一初始匹配码为0xFFFF。具体的,第一控制器默认的低32位匹配码为0xFFFF,如果第一控制器的第一初始匹配码是0xFFFF,第一控制器需要将第一初始匹配码对应的第一标志位置于零(为便于描述,采用“0”表示零),表示第一控制器未写入匹配码,并通过CAN总线将第一标志位实时发送给第二控制器;如果第一初始匹配码非0xFFFF,则将第一标志位置于1,表示第一控制器已写入匹配码。
同理,设置第二控制器的第二初始匹配码和与第二初始匹配码对应的第二标志位;其中,第二标志位置于零时表示第二控制器未写入第二初始匹配码;第二初始匹配码为0x0000。具体的,第二控制器默认的32位匹配码为0x0000;如果第二控制器的匹配码是0x0000,第二控制器需要将第二初始匹配码对应的第二标志位置于0,表示第二控制器未写入匹配码,并通过CAN总线将第二标志位实时发送给第一控制器;如果第二初始匹配码非0x0000,则将第二标志位置于1,表示第二控制器已写入匹配码。
根据上述设置后的标志位,在获取两个控制器的标志位的数值后,可执行如下步骤S104。
步骤S104,根据标志位的数值,判断第一控制器和第二控制器中是否有至少一个未写入匹配码;
在本实施例中,可以判断第一标志位是否置于零,以及判断第二标志位是否置于零。当第一标志位为零时,确定第一控制器未写入第一初始匹配码;当第二标志位为零时,确定第二控制器未写入第二初始匹配码。可以理解的是,当第一标志位不为0也即为1时,确定第一控制器已写入第一初始匹配码;当第二标志位不为0也即为1时,确定第二控制器已写入第一初始匹配码。
基于以上判断结果,可以有如下三种场景:场景一为第一控制器和第二控制器均未写入匹配码,该场景一般适用于车辆下线状态;场景二是第一控制器写入匹配码,但是第二控制器未写入匹配码,该场景诸如第二控制器更换了新件;场景三是第一控制器未写入匹配码,但是第二控制器写入了匹配码,该场景诸如第一控制器更换了新件。
如果第一控制器和第二控制器中有至少一个未写入匹配码,也即出现上述三种场景中的任意一种,执行如下步骤S106。
步骤S106,通过执行匹配码匹配操作生成目标匹配码,目标匹配码用于在第一控制器与第二控制器之间进行防盗校验。控制器未写入匹配码的场景不同,通过执行匹配码匹配操作生成目标匹配码也有所不同,下文中将针对上述三种场景,分别对该步骤进行详细介绍。
本实施例提供的防盗校验的匹配码生成方法,根据获取第一控制器和第二控制器对应的标志位的数值,自动判断第一控制器和第二控制器中是否有至少一个未写入匹配码或者有更新;如果是,控制器之间自动执行匹配码匹配操作,以生成用于在两个控制器之间防盗校验的目标匹配码。上述方式避免了汽车下线时的匹配码写入操作,同时也避免了更换控制器后需要通过重新进行匹配码匹配的操作;因此,上述匹配码生成方式有效降低了匹配码匹配的操作难度。
为了便于理解,本实施例案按照不同场景,对上述步骤S106中匹配码匹配操作的执行方式分别展开描述。
场景一:第一控制器和第二控制器均未写入匹配码。具体的,当第一控制器接收到第二控制器未写入匹配码的标志位(也即第二标志位置于0),且第一控制器当前的匹配码为0xFFFF时,第一控制器需要将第一标志位置于0,表示未写入匹配码,此时第一控制器判定第一控制器和第二控制器均未写入匹配码。在此情况下,由第一控制器作为执行主体,通过执行匹配码匹配操作生成目标匹配码的过程,主要包括如下四大步骤:
步骤一,第一控制器基于预设的校验算法生成第一seed。
在一种具体实现方式中,第一控制器生成第二随机数(如一个32位的随机数),并根据预设的校验算法对第二随机数和第二初始匹配码(0x0000)进行处理,得到第一seed。其中,校验算法以MD5校验算法为例,根据MD5校验算法将第二随机数与0x0000相结合,得到64为的第一seed。
步骤二,通过CAN将第一seed发送给第二控制器,以使第二控制器反馈第一密码。
其中,第一密码为第二控制器在接收到第一seed后,基于校验算法和第一初始匹配码生成的,具体过程可参照如下所示:第二控制器在成功接收到第一seed后,判断第一seed的低32位是否为第二初始匹配码0x0000;如果是,基于校验算法和第一初始匹配码0xFFFF生成第一密码。
步骤三,第一控制器对第一密码进行校验,并当校验成功时生成第一随机数;其中,第一随机数不同于第一初始匹配码且不同于第二初始匹配码,也即第一随机数是一个非0x0000,且非0xFFFF的随机数。
上述第一控制器对第一密码进行校验的步骤,包括:第一控制器判断是否在第一预设时间(如500ms)内接收到第一密码;如果接收到,校验第一密码与第一seed是否一致;如果一致,确定校验成功;也即,当第一控制器在500ms内接收到第二控制器反馈的第一密码,且第一密码与第一seed一致时,确定校验成功。
如果超过500ms未收到第二控制器反馈的第一密码或者第一密码与第一seed不一致,则确定本次校验失败,并重新执行上述将第一seed发送给第二控制器的步骤。
在此情况下,当校验失败的次数达到第一预设次数(如3次)时,停止防盗校验并上报校验匹配失败故障。在实际应用中,上述第一控制器对第一密码进行校验的步骤重复3次,如果超过3次还不成功,本轮KL15循环则不再认证,等待下次KL15循环,并上报校验匹配失败故障。每次KL15上电默认是无故障,只有在超过3次校验失败后,才上报上述故障,KL15下电后复位,第一控制器需要判断是由于超时导致的故障还是由于第一密码与第一seed不一致导致的故障。
步骤四,将第一随机数发送给第二控制器,并在第二控制器基于第一随机数反馈写入匹配码的第二标志位后,确定将第一随机数作为目标匹配码。
在本实施例中,第一控制器在第一密码校验成功后的第二预设时间(比如500ms)内,将第一随机数发送给第二控制器,以使第二控制器将第一随机数作为目标匹配码写入存储器eeprom后,向第一控制器反馈匹配码成功写入标志。
第一控制器判断是否在第三预设时间(比如500ms)内接收到第二控制器反馈的匹配码成功写入标志。如果是,确定将第一随机数作为目标匹配码写入存储器;如果否,将第一随机数重新发送给第二控制器。进一步的,当重新发送第一随机数的次数达到第二预设次数(如3次)时,停止防盗校验并上报校验匹配失败故障。
具体的,如果超过500ms还未收到第二控制器反馈的匹配码成功写入标志,则重复发送第一随机数给第二控制器,如果重复发送超过3次还未收到第二控制器反馈的匹配码成功写入标志,则本轮KL15循环不再匹配,等待下次KL15循环重新安装流程匹配,并上报匹配码写入失败故障。
在该场景一中,第二控制器只要接收到第一控制器发送的认证报文(第一seed),则计算第一密码,并将第一密码发送给第一控制器,但是如果第二控制器接收到的第一seed低32位非0x0000,则第二控制器不做回复。
基于上述针对场景一的描述,可具体参照如图2所示一种匹配码匹配方法信令图,包括:
步骤(1),第一控制器生成32位的随机数,并根据MD5校验算法对32位的随机数和0x0000进行处理,得到64位的第一seed;
步骤(2),通过CAN将第一seed发送给第二控制器;
步骤(3),第二控制器判断是否接收到第一seed;在成功接收到第一seed后,执行如下步骤(4);在没有成功接收到第一seed的情况下,发送第二标志位的数值给第一控制器;
步骤(4),判断第一seed的低32位是否为0x0000;若是,执行如下步骤(5),若否,不做回复。
步骤(5),基于MD5校验算法和0xFFFF生成第一密码;
步骤(6),第一控制器判断是否在500ms内接收到第一密码;若是,执行如下步骤(7),若否,重新将第一seed发送给第二控制器;
步骤(7),校验第一密码与第一seed是否一致;若一致,执行如下步骤(8);若不一致,重新将第一seed发送给第二控制器;
步骤(8),确定校验成功。
步骤(9),第一控制器生成一个非0x0000,且非0xFFFF的第一随机数;
步骤(10),在500ms内将第一随机数发送给第二控制器;
步骤(11),第二控制器判断是否接收到第一随机数;若是,执行如下步骤(12),若否,发送第二标志位的数值给第一控制器;
步骤(12),将第一随机数作为目标匹配码写入存储器后,向第一控制器反馈匹配码成功写入标志。
步骤(13),第一控制器判断是否在500ms内接收到第二控制器反馈的匹配码成功写入标志;若是,执行如下步骤(14),若否,将第一随机数重新发送给第二控制器。
步骤(14),第一控制器将第一随机数作为目标匹配码写入存储器eeprom。
至此,针对场景一的匹配流程结束。
场景二:第一控制器写入匹配码,第二控制器未写入匹配码。具体的,当第一控制器接收到第二控制器未写入匹配码的标志位,且第一控制器的匹配码非0xFFFF时,则进入第一控制器写入、第二控制器未写入匹配码的匹配流程。该场景二下,通过执行匹配码匹配操作生成目标匹配码的过程,可参照上述场景一的实现方式,在此不再展开描述。
场景三:第一控制器未写入匹配码且第二控制器写入匹配码。具体的,当LVM接收到第一控制器的未写入匹配码的标志位,且第二控制器的匹配码非0x0000时,则将第二标志位置于1,表示第二控制器已写入匹配码,在此情况下,进入第二控制器写入匹配码、第一控制器未写入匹配码的匹配流程。由第二控制器作为执行主体,通过执行匹配码匹配操作生成目标匹配码的过程,主要包括如下步骤:
步骤1,第二控制器基于预设的校验算法生成第二seed。
步骤2,将第二seed发送给第一控制器,以使第一控制器反馈第二密码;其中,第二密码为第一控制器在接收到第二seed后,基于校验算法和第二初始匹配码生成的。
步骤3,第二控制器对第二密码进行校验,并当校验成功时生成第三随机数;其中,第三随机数不同于第一初始匹配码且不同于第二初始匹配码;
步骤4,将第三随机数发送给第一控制器,并在第一控制器基于第三随机数反馈写入匹配码的第一标志位后,确定将第三随机数作为目标匹配码。
基于上述主要步骤,针对场景三的匹配码匹配的具体流程可参照图3所示,包括:
步骤(1),第二控制器生成32位的随机数,并根据MD5校验算法对32位的随机数和0xFFFF进行处理,得到64位的第二seed;
步骤(2),通过CAN将第二seed发送给第一控制器;
步骤(3),第一控制器判断是否接收到第二seed;在成功接收到第二seed后,执行如下步骤(4);在没有成功接收到第二seed的情况下,发送第一标志位的数值给第二控制器;
步骤(4),判断第二seed的低32位是否为0xFFFF;若是,执行如下步骤(5),若否,不做回复。
步骤(5),基于MD5校验算法和0x0000生成第二密码;
步骤(6),第二控制器判断是否在500ms内接收到第二密码;若是,执行如下步骤(7),若否,重新将第二seed发送给第一控制器;
步骤(7),校验第二密码与第二seed是否一致;若一致,执行如下步骤(8);若不一致,重新将第二seed发送给第一控制器;
步骤(8),确定校验成功。
步骤(9),第二控制器生成一个非0x0000,且非0xFFFF的第三随机数;
步骤(10),在500ms内将第三随机数发送给第一控制器;
步骤(11),第一控制器判断是否接收到第三随机数;若是,执行如下步骤(12),若否,发送第一标志位的数值给第二控制器;
步骤(12),将第三随机数作为目标匹配码写入存储器后,向第二控制器反馈匹配码成功写入标志。
步骤(13),第二控制器判断是否在500ms内接收到第一控制器反馈的匹配码成功写入标志;若是,执行如下步骤(14),若否,将第三随机数重新发送给第一控制器。
步骤(14),第二控制器将第三随机数作为目标匹配码写入存储器eeprom。
至此,针对场景三的匹配流程结束。
该场景三下的匹配码匹配过程,其实现原理和前述场景一中的匹配码匹配过程相似,为简要描述,本实施例部分未提及之处,可参考前述场景一中相应的实施例内容。
综上,上述实施例提供的防盗校验的匹配码生成方法,根据获取第一控制器和第二控制器对应的标志位的数值,自动判断第一控制器和第二控制器中是否有至少一个未写入匹配码或者有更新;如果是,控制器之间自动执行匹配码匹配操作,以生成用于在两个控制器之间防盗校验的目标匹配码。上述方式避免了汽车下线时的匹配码写入操作,同时也避免了更换控制器后需要通过重新进行匹配码匹配的操作;因此,上述匹配码生成方式有效降低了匹配码匹配的操作难度。
实施例二:
基于上述实施例所提供的防盗校验的匹配码生成方法,本实施例提供一种防盗校验的匹配码生成装置,参见图4所示的一种防盗校验的匹配码生成装置的结构框图,该装置应用于进行防盗校验的第一控制器与第二控制器,装置包括:
获取模块402,用于分别获取第一控制器和第二控制器对应的标志位的数值;其中,标志位的数值用于表示是否写入匹配码;
判断模块404,用于根据标志位的数值,判断第一控制器和第二控制器中是否有至少一个未写入匹配码;
生成模块406,用于在是的情况下,通过执行匹配码匹配操作生成目标匹配码,目标匹配码用于在第一控制器与第二控制器之间进行防盗校验。
本实施例提供的防盗校验的匹配码生成装置,根据获取第一控制器和第二控制器对应的标志位的数值,自动判断第一控制器和第二控制器中是否有至少一个未写入匹配码或者有更新;如果是,控制器之间自动执行匹配码匹配操作,以生成用于在两个控制器之间防盗校验的目标匹配码。上述方式避免了汽车下线时的匹配码写入操作,同时也避免了更换控制器后需要通过重新进行匹配码匹配的操作;因此,上述匹配码生成方式有效降低了匹配码匹配的操作难度。
在一些实施方式中,上述装置还包括设置模块(图中未示出),用于:设置第一控制器的第一初始匹配码和与第一初始匹配码对应的第一标志位;其中,第一标志位置于零时表示第一控制器未写入第一初始匹配码;第一初始匹配码为0xFFFF;设置第二控制器的第二初始匹配码和与第二初始匹配码对应的第二标志位;其中,第二标志位置于零时表示第二控制器未写入第二初始匹配码;第二初始匹配码为0x0000。
在一些实施方式中,上述判断模块404还用于:判断第一标志位是否置于零,以及判断第二标志位是否置于零;当第一标志位为零时,确定第一控制器未写入第一初始匹配码;当第二标志位为零时,确定第二控制器未写入第二初始匹配码。
在一些实施方式中,当第一控制器和第二控制器均未写入匹配码时,生成模块406还用于:第一控制器基于预设的校验算法生成第一seed;将第一seed发送给第二控制器,以使第二控制器反馈第一密码;其中,第一密码为第二控制器在接收到第一seed后,基于校验算法和第一初始匹配码生成的;第一控制器对第一密码进行校验,并当校验成功时生成第一随机数;其中,第一随机数不同于第一初始匹配码且不同于第二初始匹配码;将第一随机数发送给第二控制器,并在第二控制器基于第一随机数反馈写入匹配码的第二标志位后,确定将第一随机数作为目标匹配码。
在一些实施方式中,上述生成模块406还用于:第一控制器判断是否在第一预设时间内接收到第一密码;如果接收到,校验第一密码与第一seed是否一致;如果一致,确定校验成功;如果不一致,确定校验失败,并执行将第一seed发送给第二控制器的步骤;上述装置还包括上报故障模块(图中未示出),用于当校验失败的次数达到第一预设次数时,停止防盗校验并上报校验匹配失败故障。
在一些实施方式中,上述生成模块406还用于:第一控制器在第一密码校验成功后的第二预设时间内,将第一随机数发送给第二控制器,以使第二控制器将第一随机数作为目标匹配码写入存储器后,向第一控制器反馈匹配码成功写入标志;第一控制器判断是否在第三预设时间内接收到第二控制器反馈的匹配码成功写入标志;如果是,确定将第一随机数作为目标匹配码写入存储器;如果否,将第一随机数重新发送给第二控制器;
上述上报故障模块还用于:当重新发送第一随机数的次数达到第二预设次数时,停止防盗校验并上报校验匹配失败故障。
在一些实施方式中,上述生成模块406还用于:第一控制器生成第二随机数,并根据预设的校验算法对第二随机数和第二初始匹配码进行处理,得到第一seed;其中,校验算法包括MD5校验算法。
在一些实施方式中,上述生成模块406还用于:第二控制器在成功接收到第一seed后,判断第一seed的低32位是否为第二初始匹配码;如果是,基于校验算法和第二初始匹配码生成第一密码。
在一些实施方式中,当第一控制器未写入匹配码且第二控制器写入匹配码时,上述生成模块406还用于:第二控制器基于预设的校验算法生成第二seed;将第二seed发送给第一控制器,以使第一控制器反馈第二密码;其中,第二密码为第一控制器在接收到第二seed后,基于校验算法和第二初始匹配码生成的;第二控制器对第二密码进行校验,并当校验成功时生成第三随机数;其中,第三随机数不同于第一初始匹配码且不同于第二初始匹配码;将第三随机数发送给第一控制器,并在第一控制器基于第三随机数反馈写入匹配码的第一标志位后,确定将第三随机数作为目标匹配码。
本实施例所提供的装置,其实现原理及产生的技术效果和前述实施例二中的图像处理方法相同,为简要描述,本实施例部分未提及之处,可参考前述实施例二中相应内容。
实施例三:
基于前述实施例,本实施例给出了一种电子设备,包括处理器和存储装置;存储装置上存储有计算机程序,计算机程序在被处理器运行时执行上述防盗校验的匹配码生成方法。
进一步,本实施例还提供了一种计算机可读存储介质,计算机可读存储介质上存储有计算机程序,计算机程序被处理器运行时执行上述防盗校验的匹配码生成方法的步骤。
所属领域的技术人员可以清楚地了解到,为描述的方便和简洁,上述描述的系统的具体工作过程,可以参考前述方法实施例中的对应过程,在此不再赘述。
所述功能如果以软件功能单元的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读取存储介质中。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分或者该技术方案的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质中,包括若干指令用以使得一台计算机设备(可以是个人计算机,服务器,或者网络设备等)执行本发明各个实施例所述方法的全部或部分步骤。而前述的存储介质包括:U盘、移动硬盘、只读存储器(ROM,Read-Only Memory)、随机存取存储器(RAM,Random Access Memory)、磁碟或者光盘等各种可以存储程序代码的介质。
最后应说明的是:以上所述实施例,仅为本发明的具体实施方式,用以说明本发明的技术方案,而非对其限制,本发明的保护范围并不局限于此,尽管参照前述实施例对本发明进行了详细的说明,本领域的普通技术人员应当理解:任何熟悉本技术领域的技术人员在本发明揭露的技术范围内,其依然可以对前述实施例所记载的技术方案进行修改或可轻易想到变化,或者对其中部分技术特征进行等同替换;而这些修改、变化或者替换,并不使相应技术方案的本质脱离本发明实施例技术方案的精神和范围,都应涵盖在本发明的保护范围之内。因此,本发明的保护范围应以所述权利要求的保护范围为准。
Claims (10)
1.一种防盗校验的匹配码生成方法,其特征在于,所述方法应用于进行防盗校验的第一控制器与第二控制器,所述方法包括:
分别获取所述第一控制器和所述第二控制器对应的标志位的数值;其中,所述标志位的数值用于表示是否写入匹配码;
根据所述标志位的数值,判断所述第一控制器和所述第二控制器中是否有至少一个未写入匹配码;
如果是,通过执行匹配码匹配操作生成目标匹配码,所述目标匹配码用于在所述第一控制器与所述第二控制器之间进行防盗校验;
所述方法还包括:
设置所述第一控制器的第一初始匹配码和与所述第一初始匹配码对应的第一标志位;其中,所述第一标志位置于零时表示所述第一控制器未写入所述第一初始匹配码;所述第一初始匹配码为0xFFFF;
设置所述第二控制器的第二初始匹配码和与所述第二初始匹配码对应的第二标志位;其中,所述第二标志位置于零时表示所述第二控制器未写入所述第二初始匹配码;所述第二初始匹配码为0x0000;
当所述第一控制器和所述第二控制器均未写入匹配码时,所述通过执行匹配码匹配操作生成目标匹配码的步骤,包括:
所述第一控制器基于预设的校验算法生成第一seed;
将所述第一seed发送给所述第二控制器,以使所述第二控制器反馈第一密码;其中,所述第一密码为所述第二控制器在接收到所述第一seed后,基于所述校验算法和所述第一初始匹配码生成的;
所述第一控制器对所述第一密码进行校验,并当校验成功时生成第一随机数;其中,所述第一随机数不同于所述第一初始匹配码且不同于所述第二初始匹配码;
将所述第一随机数发送给所述第二控制器,并在所述第二控制器基于所述第一随机数反馈写入匹配码的第二标志位后,确定将所述第一随机数作为目标匹配码。
2.根据权利要求1所述的方法,其特征在于,所述根据所述标志位的数值,判断所述第一控制器和所述第二控制器中是否有至少一个未写入匹配码的步骤,包括:
判断所述第一标志位是否置于零,以及判断所述第二标志位是否置于零;
当所述第一标志位为零时,确定所述第一控制器未写入所述第一初始匹配码;
当所述第二标志位为零时,确定所述第二控制器未写入所述第二初始匹配码。
3.根据权利要求1所述的方法,其特征在于,所述第一控制器对所述第一密码进行校验的步骤,包括:
所述第一控制器判断是否在第一预设时间内接收到所述第一密码;
如果接收到,校验所述第一密码与所述第一seed是否一致;
如果一致,确定校验成功;
如果不一致,确定校验失败,并执行所述将所述第一seed发送给所述第二控制器的步骤;
所述方法还包括:
当校验失败的次数达到第一预设次数时,停止防盗校验并上报校验匹配失败故障。
4.根据权利要求1所述的方法,其特征在于,所述将所述第一随机数发送给所述第二控制器,并在所述第二控制器基于所述第一随机数反馈写入匹配码的第二标志位后,确定将所述第一随机数作为目标匹配码的步骤,包括:
所述第一控制器在所述第一密码校验成功后的第二预设时间内,将所述第一随机数发送给所述第二控制器,以使所述第二控制器将所述第一随机数作为目标匹配码写入存储器后,向所述第一控制器反馈匹配码成功写入标志;
所述第一控制器判断是否在第三预设时间内接收到所述第二控制器反馈的匹配码成功写入标志;
如果是,确定将所述第一随机数作为目标匹配码写入存储器;
如果否,将所述第一随机数重新发送给所述第二控制器;
所述方法还包括:
当重新发送所述第一随机数的次数达到第二预设次数时,停止防盗校验并上报校验匹配失败故障。
5.根据权利要求1所述的方法,其特征在于,所述第一控制器基于预设的校验算法生成第一seed的步骤,包括:
所述第一控制器生成第二随机数,并根据预设的校验算法对所述第二随机数和所述第二初始匹配码进行处理,得到第一seed;其中,所述校验算法包括MD5校验算法。
6.根据权利要求1所述的方法,其特征在于,所述第二控制器反馈第一密码的步骤,包括:
所述第二控制器在成功接收到所述第一seed后,判断所述第一seed的低32位是否为所述第二初始匹配码;
如果是,基于所述校验算法和所述第一初始匹配码生成第一密码。
7.根据权利要求1所述的方法,其特征在于,当所述第一控制器未写入匹配码且所述第二控制器写入匹配码时,所述通过执行匹配码匹配操作生成目标匹配码的步骤,包括:
所述第二控制器基于预设的校验算法生成第二seed;
将所述第二seed发送给所述第一控制器,以使所述第一控制器反馈第二密码;其中,所述第二密码为所述第一控制器在接收到所述第二seed后,基于所述校验算法和所述第二初始匹配码生成的;
所述第二控制器对所述第二密码进行校验,并当校验成功时生成第三随机数;其中,所述第三随机数不同于所述第一初始匹配码且不同于所述第二初始匹配码;
将所述第三随机数发送给所述第一控制器,并在所述第一控制器基于所述第三随机数反馈写入匹配码的第一标志位后,确定将所述第三随机数作为目标匹配码。
8.一种防盗校验的匹配码生成装置,其特征在于,所述装置应用于进行防盗校验的第一控制器与第二控制器,所述装置包括:
获取模块,用于分别获取所述第一控制器和所述第二控制器对应的标志位的数值;其中,所述标志位的数值用于表示是否写入匹配码;
判断模块,用于根据所述标志位的数值,判断所述第一控制器和所述第二控制器中是否有至少一个未写入匹配码;
生成模块,用于在是的情况下,通过执行匹配码匹配操作生成目标匹配码,所述目标匹配码用于在所述第一控制器与所述第二控制器之间进行防盗校验;
第一标志位设置模块,用于设置所述第一控制器的第一初始匹配码和与所述第一初始匹配码对应的第一标志位;其中,所述第一标志位置于零时表示所述第一控制器未写入所述第一初始匹配码;所述第一初始匹配码为0xFFFF;
第二标志位设置模块,用于设置所述第二控制器的第二初始匹配码和与所述第二初始匹配码对应的第二标志位;其中,所述第二标志位置于零时表示所述第二控制器未写入所述第二初始匹配码;所述第二初始匹配码为0x0000;
当所述第一控制器和所述第二控制器均未写入匹配码时,所述生成模块,还包括:
第一seed生成模块,用于所述第一控制器基于预设的校验算法生成第一seed;
第一密码反馈模块,用于将所述第一seed发送给所述第二控制器,以使所述第二控制器反馈第一密码;其中,所述第一密码为所述第二控制器在接收到所述第一seed后,基于所述校验算法和所述第一初始匹配码生成的;
第一随机数生成模块,用于所述第一控制器对所述第一密码进行校验,并当校验成功时生成第一随机数;其中,所述第一随机数不同于所述第一初始匹配码且不同于所述第二初始匹配码;
目标匹配码确定模块,用于将所述第一随机数发送给所述第二控制器,并在所述第二控制器基于所述第一随机数反馈写入匹配码的第二标志位后,确定将所述第一随机数作为目标匹配码。
9.一种电子设备,其特征在于,包括处理器和存储装置;
所述存储装置上存储有计算机程序,所述计算机程序在被所述处理器运行时执行如权利要求1至7任一项所述的方法。
10.一种计算机可读存储介质,所述计算机可读存储介质上存储有计算机程序,其特征在于,所述计算机程序被处理器运行时执行上述权利要求1至7任一项所述的方法的步骤。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202010623921.9A CN111746464B (zh) | 2020-06-30 | 2020-06-30 | 防盗校验的匹配码生成方法及装置 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202010623921.9A CN111746464B (zh) | 2020-06-30 | 2020-06-30 | 防盗校验的匹配码生成方法及装置 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN111746464A CN111746464A (zh) | 2020-10-09 |
CN111746464B true CN111746464B (zh) | 2022-02-11 |
Family
ID=72680356
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202010623921.9A Active CN111746464B (zh) | 2020-06-30 | 2020-06-30 | 防盗校验的匹配码生成方法及装置 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN111746464B (zh) |
Families Citing this family (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN113799734B (zh) * | 2021-10-25 | 2022-11-18 | 中国第一汽车股份有限公司 | 一种车辆防盗系统的防盗匹配方法、装置、服务器及介质 |
Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
EP0835790A2 (en) * | 1996-10-14 | 1998-04-15 | Denso Corporation | Anti-theft device using code type transponder |
CN105799643A (zh) * | 2016-03-03 | 2016-07-27 | 陈健强 | 基于智能眼镜镜片敲击次数的汽车解锁实现方法及系统 |
CN108860062A (zh) * | 2018-07-24 | 2018-11-23 | 上海大郡动力控制技术有限公司 | 带有通信数据保护的电动汽车防盗认证方法 |
JP6626565B2 (ja) * | 2015-07-16 | 2019-12-25 | 浙江吉利汽車研究院有限公司Zhejiang Geely Automobile Research Institute Co., Ltd | 車両の起動方法 |
CN111196246A (zh) * | 2018-11-20 | 2020-05-26 | 广州汽车集团股份有限公司 | 一种车辆防盗匹配方法及系统 |
Family Cites Families (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP4362136B2 (ja) * | 2007-02-26 | 2009-11-11 | 三菱電機株式会社 | 車両用電子キー装置 |
CN104590206B (zh) * | 2013-10-31 | 2016-12-07 | 北汽福田汽车股份有限公司 | 点火锁控制设备及方法 |
CN106274805B (zh) * | 2015-05-29 | 2019-04-19 | 比亚迪股份有限公司 | 汽车电子钥匙及其方法、汽车控制器及其方法、及系统 |
CN106627489A (zh) * | 2016-12-09 | 2017-05-10 | 广州汽车集团股份有限公司 | 一种纯电动汽车防盗认证方法及系统 |
-
2020
- 2020-06-30 CN CN202010623921.9A patent/CN111746464B/zh active Active
Patent Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
EP0835790A2 (en) * | 1996-10-14 | 1998-04-15 | Denso Corporation | Anti-theft device using code type transponder |
JP6626565B2 (ja) * | 2015-07-16 | 2019-12-25 | 浙江吉利汽車研究院有限公司Zhejiang Geely Automobile Research Institute Co., Ltd | 車両の起動方法 |
CN105799643A (zh) * | 2016-03-03 | 2016-07-27 | 陈健强 | 基于智能眼镜镜片敲击次数的汽车解锁实现方法及系统 |
CN108860062A (zh) * | 2018-07-24 | 2018-11-23 | 上海大郡动力控制技术有限公司 | 带有通信数据保护的电动汽车防盗认证方法 |
CN111196246A (zh) * | 2018-11-20 | 2020-05-26 | 广州汽车集团股份有限公司 | 一种车辆防盗匹配方法及系统 |
Also Published As
Publication number | Publication date |
---|---|
CN111746464A (zh) | 2020-10-09 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US10360018B2 (en) | Update control apparatus, software update system, and update control method | |
US9602487B2 (en) | Method for the protected transmission of data | |
CN111131313B (zh) | 智能网联汽车更换ecu的安全保障方法及系统 | |
US20180234248A1 (en) | Communication system, vehicle, and monitoring method | |
JP5864510B2 (ja) | 修正プログラム確認方法、修正プログラム確認プログラム、及び情報処理装置 | |
JP6782446B2 (ja) | 監視装置、通信システム、車両、監視方法、およびコンピュータプログラム | |
US20180074929A1 (en) | Network monitoring device, network system, and computer program product | |
US8898475B2 (en) | Method, controller and system for detecting infringements of the authenticity of system components | |
CN109150514B (zh) | 一种密钥的写入方法及设备 | |
KR102368606B1 (ko) | 효율적인 차량용 리프로그래밍 장치 및 그 제어방법 | |
CN111480141A (zh) | 用于更新机动车控制设备的软件的方法和设备 | |
CN110989564B (zh) | 一种汽车数据诊断方法及装置 | |
CN108377193B (zh) | 一种里程备份方法、装置、车辆及控制设备 | |
CN111746464B (zh) | 防盗校验的匹配码生成方法及装置 | |
CN108482308B (zh) | 电动汽车安全控制方法、装置、存储介质及电动汽车 | |
CN113645590A (zh) | 基于加密算法的远程控制车辆的方法、装置、设备及介质 | |
CN109131218B (zh) | 车辆的启动方法、装置、车辆及计算机可读存储介质 | |
US11100229B2 (en) | Secure hybrid boot systems and secure boot procedures for hybrid systems | |
CN112887099A (zh) | 数据签名方法、电子设备及计算机可读存储介质 | |
CN110968841B (zh) | 可编程逻辑控制器的激活方法、装置和系统 | |
JP6662657B2 (ja) | 車両用監視システム | |
EP3968601B1 (en) | Synchronization of a communication between a vehicle and a backend device using a hash message | |
US10789365B2 (en) | Control device and control method | |
US20240036878A1 (en) | Method for booting an electronic control unit | |
CN113138591B (zh) | 一种车辆安全因子的控制方法、装置、控制设备及汽车 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
GR01 | Patent grant | ||
GR01 | Patent grant |