如何通过CAN破解汽车

汽车后装的辅助驾驶设备,一般需要知道汽车的CAN协议,各汽车厂家的CAN协议又是保密的,这时就需要破解,因为CAN协议是明文,所以破解也就轻松些。

破解流程(以转速表为例)

一辆车就是一个网络

  • 一辆汽车由多台计算机组成,以控制发动机、变速器、窗户、锁、灯等。这些计算机被称为电子控制单元(ECU),它们通过网络相互通信。例如,当你按下方向盘上的按钮来增加收音机的音量时,方向盘ECU向网络发送一个增加音量的命令,无线电ECU就会看到这个命令并采取相应的行动。
  • 一辆车里有多个网络,通常至少有两个:
    a. 一个用于关键数据,如发动机和动力系统信息
    b. 另一种是不太重要的数据,比如无线电和门锁
  • 关键网络使用快速可靠的协议,而非关键网络使用较慢、可靠性较低但成本较低的协议。网络的数量以及将哪些ecu连接在一起取决于汽车制造商、车型和年份。ECU还可以连接多个网络。

连接到网络

  • 一些网络可以通过OBD-II端口访问。OBD-II适用于1996年以后在美国和2004年以后在欧洲生产的所有轿车和轻型卡车。

  • 连接器位于驾驶员座位触手可及的位置。你可能需要取下一些塑料盖,但不用工具就可以使用。

  • OBD-II标准允许五种信令协议。由制造商决定使用哪一种。CAN是最受欢迎的,也是我们将要讨论的。它可以通过OBD-II连接器的引脚6和14访问。如果你的车有一个CAN总线,你会看到金属引线在引脚上,如上图所示。

  • CAN总线是一种可靠的、高速的总线,用于发送关键数据。不幸的是,总线上的数据包不是标准化的,所以您需要将它们颠倒过来才能知道它们的意思。OBD-II标准还为特定于供应商的引脚留有空间,这些引脚可以用于特定于供应商的协议。这使得经销商更容易诊断问题。

  • 在我的汽车(GM)上,我有一个标准的CAN总线在引脚6和14,和一个供应商特定的单线CAN总线在引脚1。标准CAN总线是一种可靠、高速(500kbps)的协议,也称为高速CAN (HS-CAN)。它用于关键数据。单线CAN总线(SW-CAN)或GMLAN速度较慢(33.3 kbps),可靠性较差,但成本较低,因为它只使用一根线。此总线用于非关键数据。

  • 如果你看到一个供应商特定的引脚,但不知道使用的是哪个协议,谷歌' OBD pinout '。还有低速CAN (LS-CAN)和中速CAN (MS-CAN)。MS-CAN通常在第3和第11针,在福特和沃尔沃汽车上以125 kbps的速度运行。

工具
你需要一台能够解读CAN数据的设备,以及分析数据的软件

硬件

  • 为了接收和发送CAN包,您需要一个能够做到这一点的设备。您经常会遇到基于ELM327的设备。虽然它们有自己的用途,但对于黑客来说,它们是可怕的。它们的速度太慢,无法监控CAN总线。此外还有Kvaser、Peak或EMS Wünsche等高端设备。这些可以完成工作,但太过了,而且相当昂贵。

  • 一些高端设备还要求你同时购买软件。USB2CAN是一个用于Linux的本地CAN接口,性价比很高。
    你也可以使用Cantact或CANUSB。然而,这些不是Linux中的本地CAN设备,而是使用基于ASCII的协议。这意味着它们的设置稍微复杂一些,性能也较差。另一方面,它们在多个操作系统中都得到了很好的支持。

  • 我使用的CANalyze是我为自己的需求设计的。它类似于USB2CAN,因为它是一个便宜的本地CAN接口,但它使用了一个较新的微控制器,是开源的,可以使用开源工具构建。本教程的其余部分假设您使用的是本机CAN接口。

软件
要与设备通信,需要在Linux机器上安装can-utils包。你可以通过在Linux提示符中输入以下命令来实现:
1 | sudo apt-get install can-utils
CAN-utils使得发送、接收和分析CAN包非常容易。这些是我们将要使用的命令。
1 | cansniffer 只显示正在变化的报文
2 | Candump 打印所有收到的数据包
3 | Cansend 发送一个数据包
Linux通过SocketCAN在内核中内置CAN支持。这使得编写自己的附加程序变得很容易。你可以与can总线交互,就像你与任何其他网络交互一样,即通过套接字。

CAN bus

在开始破解之前,您应该对CAN总线的工作原理有一些了解。它由两根导线组成,并使用不同的信号。因为它是总线,多个设备可以连接到这两条线。当CAN帧在总线上发送时,它被所有ECU接收,但只有当它对ECU有用时才被处理。如果同时发送多个CAN帧,优先级最高的帧将获胜。一个CAN框架有三个部分与我们相关。
  • 仲裁标识符
    消息的标识符。ECU使用它来决定是处理还是忽略接收到的帧。它还表示消息的优先级。编号越低优先级越高。例如,如果你是一个设计网络的工程师,你会给安全气囊部署的框架一个非常高的优先级或者一个低的仲裁ID。另一方面,对于用于门锁的数据,您可能会给出较低的优先级或较高的仲裁ID。

  • 数据长度码 (DLC)
    数据字段的长度,以字节为单位。一个CAN帧最多可以有8字节的数据。

  • 数据字段
    最多8字节的数据。

破解CAN协议

  • 破解CAN总线的一般方法是生成您想要模拟的行为,并找到导致该行为的消息。例如,让我们假设你车上的车道保持辅助系统(LKAS)是垃圾,而你已经制作了自己的。

  • 为了让它控制转向,你需要知道要发送什么信息。解决这个问题的方法是打开原来的LKAS,监控CAN总线并识别负责转动方向盘的包。一旦你确定了这些数据包,你就可以让你自己的LKAS把这些数据包发送到can总线来控制方向盘。

  • 在我们的情况下,我们想要欺骗转速表,所以我们需要改变转速通过踩油门与汽车上和空挡,然后试图找到包负责改变转速。

设置

将CAN设备插入汽车的OBD-II端口和计算机的USB端口。在Linux提示符中运行以下命令启动CAN接口:
1 | sudo ip link set can0 up type can bitrate 500000
这将以500 kbps的比特率打开can0接口(如果你只有一个设备连接,总是can0),这是标准的。

识别

当汽车关闭时,ecu通常处于睡眠状态,所以你需要打开汽车或将其置于辅助模式。你可以通过在Linux提示符中运行下面的命令查看原始can数据:
1 | candump can0
一旦接收到CAN数据,就会将其打印到屏幕上。然而,这是非常无组织的,很难看到哪些数据包对应于某个事件。你可以按ctrl+c来停止程序。为了使数据更具可读性,我们使用了cansniffer,它根据仲裁ID对数据包进行分组,并且只显示正在变化的数据包。为了启动它,在Linux提示符中运行命令:
1 | cansniffer -c can0
其中-c将更改的字节着色,can0是用来嗅闻的接口。移除固定数据包需要几秒钟。
您应该会看到类似下图的内容,尽管数字可能完全不同。

第一列(delta)显示了以秒为单位的接收仲裁ID的数据包的速率。第二列(ID)包含仲裁ID。其余的字母数字列(data…)包含数据字节。如果数据是ASCII表示,它可以在右边看到,否则它是一个点。

当你在引擎运行时踩油门以提高转速时,屏幕上可能会出现新的CAN信息,或者现有的信息会发生变化。
我们需要找到一个CAN消息,其中变化的字节与RPM的变化相关。我们可以预期这个值将随着RPM的增加/减少而增加/减少。
canniffer中的第一个CAN帧似乎随RPM而变化,它是仲裁id为C9的帧。可能有多个包随RPM而变化,这只是第一个。

在此消息中有4个字节正在更改(红色),但并非所有字节都必须指示RPM。第三个字节07的变化似乎与不同的RPM无关。最后一个字节是1B。
然而,只要我们把脚从油门上拿开,它就到了00。这将表明,它代表油门位置,而不是RPM。
最后是两个字节21 C0,它们似乎与RPM中的变化相对应。更重要的是,它是一个16字节整数,即当第二个字节C0溢出时,第一个字节21增加1。似乎21对应大约2000 RPM。当您将重播消息时,请注意这一点。

重播

一旦你有了一个候选,在Linux提示符中使用以下命令将它发送到CAN总线上:
1 | cansend can0 0C9#8021C0071B101000
其中帧的格式为 #{data},必须用您自己的CAN消息替换。
您的汽车可以运行或配件模式。请确保使用引擎非空闲时获得的包,否则在引擎空闲时重放它不会看到任何变化。
如果只发送一次数据包,您可能不会看到仪器集群上有任何变化。这是因为ECU仍然以0.2秒的间隔在总线上连续发送原始消息,所以您的消息将被忽略。
回忆一下,速率是在canniffer的第一列给出的。有两种方法可以解决这个问题,除了断开生成这些消息的ECU。一种选择是以比当前正在发送的信息包更高的频率发送信息包。你可以在Linux提示符中运行以下命令:
1 | while true; do cansend can0 0C9#8021C0071B101000; sleep 0.002; done
并将CAN消息替换为您已确定的消息。按ctrl+c停止。
另一种选择是监视总线,每次检测到想要欺骗的包时,立即发送自己的包。这可以通过在Linux提示符中运行来实现:
1 | candump can0 | grep ' 0C9 ' | while read line; do cansend can0 0C9#8021C0071B101000; done
你需要用你识别的CAN消息和它的仲裁id分别替换CAN消息和0C9。您可以对这两种方法进行试验,看看哪一种效果更好。
如果转速表变了,干得好,你找到了!如果没有,则识别与RPM相关的下一条消息并重播它。

模糊测试

现在您已经有了在仪器集群上设置RPM的CAN帧,您可以使用发送的数据来查看发生了什么。我们已经注意到,与RPM对应的两个字节表现为一个16位整数,因此为了将转速表设置为8k RPM,我们在Linux提示符中运行以下命令:
1 | while true; do cansend can0 0C9#0080000000101000; sleep 0.002; done
结果是……

就是这样!您现在可以尝试控制速度计,收音机,灯,门锁等使用相同的方法。

可能的问题

虽然CAN总线是最流行的网络,但它不是唯一的网络。如果您不能在can总线上找到您要查找的消息,请尝试不同的网络。特别是非关键信息,如收音机、灯和门锁,可能会在不同的网络上。
如前所述,通过CAN传输的确切数据取决于汽车的制造商、型号和年份。有些汽车在CAN消息中使用计数器,以确保同一消息不会被多次处理。这稍微有点困难,但是你应该能够使用提供的信息来完成它。一些汽车还使用校验和来确保数据的完整性。计算这个校验和是很困难的。
当在总线上重放识别的数据包时,您的CAN到USB设备可能进入“总线关闭”状态。这是CAN标准的一部分,当设备遇到太多错误时就会发生。这种情况通常发生在交通繁忙的公共汽车上。为了解决这个问题,你可以尝试延迟和计时,也许可以尝试在将汽车置于辅助模式后立即重播消息,尝试等待一段时间,在汽车上尝试,等等。如果您已经确定哪些ECU连接到总线,您还可以拉他们的保险丝,以阻止他们发送消息和降低总线上的流量。

参考

1、《The Car Hacker’s Handbook》
2、How to hack a car — a quick crash-course
(0)

相关推荐

  • 汽车OBD协议介绍

    今日推荐 ↓↓↓ 内容简介 本书结合电动汽车这一新兴行业,从电动汽车与充电设施系统分析上拓展商业模式的研究.内容侧重电动汽车发展商业模式理论和相关企业的实践结合:突出电动汽车与充电设施结合的特点:本书 ...

  • 汽车E/E架构网络安全设计(三):攻击方式和防护手段

    上一篇主要是介绍汽车电电子电气架构的信息安全问题,那么,面对这些问题,如今的整车厂都是如何解决的呢?现在汽车上都采用了哪些安全保护机制呢?本篇将为大家介绍汽车信息安全防护的现状. 汽车信息安全的现状 ...

  • 谈谈汽车的OBD系统

    OBD是On-board diagnostics的缩写.OBD系统是指对车辆状态进行监控和报告的车载系统.借助OBD端口和OBD连接器可以获取车辆发生故障时刻的车辆参数,如车速.排放数据.发动机数据等 ...

  • 1分钟破解汽车智能钥匙?!车主该如何应对?

    随着汽车技术的发展 汽车钥匙也不断跟随技术的潮流而前进 从最初的摇把到后来的传统钥匙 这种"原始"传统型纯机械钥匙功能都十分有限 因此已逐步被淘汰 (摇把.传统钥匙) 后来 汽车钥 ...

  • 立木顶千斤! 汽车安全结构的唯一法则, 只有大虎悠破解了!

    此话题一共分为上.中.下三部分.我们在上篇与中篇里已经将汽车安全力学设计思路的大概要点做了简单的归类和阐述,最终我们知道汽车的乘员舱必须保证坚固的性能,碰撞中尽量不得发生变形. 要不发生变形,很多人往 ...

  • 新能源汽车基础设施的困局如何破解?

    新能源汽车基础设施对于关乎着新能源汽车用车体验,新能源基础设施是影响消费者购买新能源汽车的重要因素之一.面对日益增长的新能源汽车,新能源基础设施的困局如何破解? 基础设施的困局在于充电基础设施建设的数 ...

  • 汽车“无钥匙启动”被破解 求车主们的心理阴影面积

    不知道作为一名车主,如果你看到这样的画面会是什么样的心情-- 当你把车停好,拔下钥匙离开,旁边一个陌生人从你身边慢慢经过.十几秒钟之后,一直在你爱车旁边等候的另一个陌生人,轻轻一拉车门,进到车内打着火 ...

  • 效果通出击,巨量引擎破解难题释放汽车营销真效能

    市场和营销环境深刻变化间,2019车市迎来增长新挑战. 市场"僧多肉少",营销更需"智取":智能化.电动化快速推进下,更多新生力量入局,汽车竞争格局更加多元:车 ...

  • 汽车是怎么开发出来的?浅谈汽车开发流程

    许良  汽车话题下的优秀答主你知道汽车是怎么开发出来的吗?你的脑海中很可能浮现出来这样一个画面:一个非常有艺术气息的设计师,在草图上帅气的描绘着看起来非常犀利的线条.对,但不全对.对于汽车工程师的我而 ...

  • 破解关于癌症的十大迷思

    破解关于癌症的十大迷思

  • 为什么有些跑者一跑起来心率特别高?如何破解

    跑者中存在这样一群人,平时安静心率也不是太高,但只要一跑步,无论快慢,心率就会迅速飙升到老高的水平,比如超过160次/分,甚至170次/分,即便是降低速度,心率也下不来,跑步时心率总是维持在较高水平, ...

  • 集宁战役:傅作义破解我军3套王牌战术

    1946年八九月间爆发的集宁战役,又称大同集宁战役,是我华北部队遭受的一场较为沉重的失利.这场战役我军对手是国民党第12战区的傅作义,由于对他的作战特点不了解,我军连连失利,最终大同城没打下,还使部队 ...