登录
首页 >  文章 >  前端

开发人员如何使电动汽车充电器能够与移动应用程序通信

来源:dev.to

时间:2025-01-20 10:43:13 466浏览 收藏

怎么入门文章编程?需要学习哪些知识点?这是新手们刚接触编程时常见的问题;下面golang学习网就来给大家整理分享一些知识点,希望能够给初学者一些帮助。本篇文章就来介绍《开发人员如何使电动汽车充电器能够与移动应用程序通信》,涉及到,有需要的可以收藏一下

在电动汽车 (ev) 世界中,电动汽车驾驶员最神奇的体验之一就是在移动应用程序上点击“开始”并看到充电器开始工作。

但是这个魔法是如何发生的呢?

让我们深入了解电动汽车充电器和移动应用程序如何通信的幕后旅程。

游戏中的玩家

  1. 移动应用程序:这是用户发起操作的地方,例如开始或停止充电会话。
  2. 后端服务器:操作背后的大脑,协调应用程序和充电器之间的通信。
  3. 电动汽车充电器:为您的电动汽车提供电力的硬件。

这些玩家之间的通信遵循名为ocpp(开放充电点协议)的标准化协议。具体来说,大多数系统都使用 基于 websocket 的 ocpp,这可确保实时、可靠的通信。

image description

开始充电过程

第 1 步:用户在应用程序中点击“开始”

当用户点击“开始”按钮时,该过程开始。后端服务器准备一个 remotestarttransaction 命令,其中包含以下详细信息:

{
  "connectorid": 1,
  "idtag": "remote-11902",
  "chargingprofile": {
    "transactionid": 11902,
    "chargingprofileid": 1,
    "stacklevel": 1,
    "chargingprofilepurpose": "txprofile",
    "chargingprofilekind": "relative",
    "chargingschedule": {
      "chargingrateunit": "a",
      "chargingscheduleperiod": [ ... ]
    }
  }
}

此命令通过后端使用 rpc 调用发送到充电器:

await client.call(
  'remotestarttransaction',
  remotestarttransactionbody
);

第 2 步:充电器响应

充电器通过响应确认命令:

{"status": "accepted"}

这表明充电器已准备好开始交易。

第三步:充电器发送starttransaction

当充电器完全准备好后,它会向后端发送starttransaction消息:

{
  "connectorid": 1,
  "idtag": "remote-11902",
  "meterstart": 0,
  "timestamp": "2025-01-15t02:09:54.000z"
}

监控充电会话

在整个充电过程中,充电器会定期发送metervalues更新,其中包括电压、电流和传递的能量等指标。这些更新可以配置为每 30 秒或以不同的时间间隔进行:

{
  "connectorid": 1,
  "transactionid": 11902,
  "metervalue": [
    {
      "timestamp": "2025-01-15t02:09:54.000z",
      "sampledvalue": [
        { "value": "241.10", "measurand": "voltage", "unit": "v" },
        { "value": "0.00", "measurand": "current.import", "unit": "a" },
        { "value": "0", "measurand": "power.active.import", "unit": "w" },
        { "value": "32", "measurand": "current.offered", "unit": "a" }
      ]
    }
  ]
}

停止充电过程

第 1 步:用户在应用程序中点击“停止”

当用户点击“停止”时,后端会向充电器发送remotestoptransaction命令:

await client.call(
  'remotestoptransaction',
  { transactionid: 11902 }
);

第 2 步:充电器响应

充电器确认:

{"status": "accepted"}

步骤3:充电器发送stoptransaction

完成关闭后,充电器会发送一条stoptransaction消息,其中包含传输的总能量等详细信息:

{
  "idTag": "remote-11902",
  "timestamp": "2025-01-15T02:40:49",
  "meterStop": 6379,
  "reason": "EVDisconnected",
  "transactionId": 11902,
  "transactionData": [
    {
      "timestamp": "2025-01-15T02:40:49",
      "sampledValue": [
        { "value": "6379.259277", "measurand": "Energy.Active.Import.Register", "unit": "Wh" }
      ]
    }
  ]
}

什么是连接器?

就像汽油泵可能有不同的柴油或汽油喷嘴一样,电动汽车充电器可以有多个连接器。常见类型包括:

  • ccs2:风靡欧洲和北美。
  • chademo:常见于日本。
  • mennekes(2 型):在欧洲广泛使用。

每个连接器独立运行,允许一个充电器为多辆车提供服务。

image description

ocpp

ocpp(开放充电点协议)是一种开放式通信标准,专为电动汽车(ev)充电站(充电点)和中央管理系统(通常称为后端系统或充电点管理系统)之间的交互而设计。

它实现了不同制造商和软件提供商的充电基础设施之间的互操作性。

ocpp 版本:

  • ocpp 1.5:早期版本,仍在一些旧系统中使用。
  • ocpp 1.6:广泛采用,支持 soap 和 websocket 通信。
  • ocpp 2.0 和 2.0.1:增强版本,具有更多功能,如改进的安全性 (tls)、支持智能充电、更好的诊断和固件管理。

关键用例:

  1. 充电站管理:充电站的远程监控、故障排除和固件更新。
  2. 智能充电:实现负载平衡、调度/预订以及与电网集成。
  3. 支付集成:允许充电站与支付网关交互并管理用户帐户。
  4. 分析和报告:帮助运营商分析使用模式并优化运营。

ocpp 的工作原理:

ocpp 定义了充电点和中央系统之间的消息结构和通信协议。例如:

  • 充电点发送有关其状态、能耗或错误的消息。
  • 中央系统可以发送命令来启动/停止充电、更新固件或执行诊断。

ocpp 由开放收费联盟 (oca) 管理,该联盟持续开发和推广该协议。

包裹

  1. python:mobilityhouse/ocpp
  2. javascript:mikuso/ocpp-rpc

总结一下

每次您从应用程序开始或停止充电时,一系列精确的实时消息都会在您的应用程序、后端和充电器之间流动。

ocpp 协议使这一切成为可能,确保不同制造商的充电器和应用程序可以无缝协作。

所以,下次您插入电动汽车并点击“开始”时,您就会更多地了解幕后的魔力!


我一直在开发一个超级方便的工具,叫做 liveapi。

它旨在让开发人员轻松编写 api 文档。

使用liveapi,您可以快速生成交互式api文档,允许用户直接从浏览器执行api。

image description

如果您厌倦了为 api 手动创建文档,这个工具可能会让您的生活变得更轻松。

以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于文章的相关知识,也可关注golang学习网公众号。

声明:本文转载于:dev.to 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>