大家好,又见面了,我是你们的朋友全栈君。
汽车后装的辅助驾驶设备,一般需要知道汽车的CAN协议,各汽车厂家的CAN协议又是保密的,这时就需要激活成功教程,因为CAN协议是明文,所以激活成功教程也就轻松些。
你需要一台能够解读CAN数据的设备,以及分析数据的软件
要与设备通信,需要在Linux机器上安装can-utils包。你可以通过在Linux提示符中输入以下命令来实现:
sudo apt-get install can-utils
CAN-utils使得发送、接收和分析CAN包非常容易。这些是我们将要使用的命令。
cansniffer 只显示正在变化的报文
Candump 打印所有收到的数据包
Cansend 发送一个数据包
Linux通过SocketCAN在内核中内置CAN支持。这使得编写自己的附加程序变得很容易。你可以与can总线交互,就像你与任何其他网络交互一样,即通过套接字。
在开始激活成功教程之前,您应该对CAN总线的工作原理有一些了解。它由两根导线组成,并使用不同的信号。因为它是总线,多个设备可以连接到这两条线。当CAN帧在总线上发送时,它被所有ECU接收,但只有当它对ECU有用时才被处理。如果同时发送多个CAN帧,优先级最高的帧将获胜。一个CAN框架有三个部分与我们相关。
将CAN设备插入汽车的OBD-II端口和计算机的USB端口。在Linux提示符中运行以下命令启动CAN接口:
sudo ip link set can0 up type can bitrate 500000
这将以500 kbps的比特率打开can0接口(如果你只有一个设备连接,总是can0),这是标准的。
当汽车关闭时,ecu通常处于睡眠状态,所以你需要打开汽车或将其置于辅助模式。你可以通过在Linux提示符中运行下面的命令查看原始can数据:
candump can0
一旦接收到CAN数据,就会将其打印到屏幕上。然而,这是非常无组织的,很难看到哪些数据包对应于某个事件。你可以按ctrl+c来停止程序。为了使数据更具可读性,我们使用了cansniffer,它根据仲裁ID对数据包进行分组,并且只显示正在变化的数据包。为了启动它,在Linux提示符中运行命令:
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总线上:
cansend can0 0C9#8021C0071B101000
其中帧的格式为 #{data},必须用您自己的CAN消息替换。
您的汽车可以运行或配件模式。请确保使用引擎非空闲时获得的包,否则在引擎空闲时重放它不会看到任何变化。
如果只发送一次数据包,您可能不会看到仪器集群上有任何变化。这是因为ECU仍然以0.2秒的间隔在总线上连续发送原始消息,所以您的消息将被忽略。
回忆一下,速率是在canniffer的第一列给出的。有两种方法可以解决这个问题,除了断开生成这些消息的ECU。一种选择是以比当前正在发送的信息包更高的频率发送信息包。你可以在Linux提示符中运行以下命令:
while true; do cansend can0 0C9#8021C0071B101000; sleep 0.002; done
并将CAN消息替换为您已确定的消息。按ctrl+c停止。
另一种选择是监视总线,每次检测到想要欺骗的包时,立即发送自己的包。这可以通过在Linux提示符中运行来实现:
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提示符中运行以下命令:
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》(https://docs.alexomar.com/biblioteca/thecarhackershandbook.pdf) 2、How to hack a car — a quick crash-course
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/154171.html原文链接:https://javaforall.cn