开发人员如何使电动汽车充电器能够与移动应用程序通信
来源:dev.to
时间:2025-01-20 10:43:13 466浏览 收藏
怎么入门文章编程?需要学习哪些知识点?这是新手们刚接触编程时常见的问题;下面golang学习网就来给大家整理分享一些知识点,希望能够给初学者一些帮助。本篇文章就来介绍《开发人员如何使电动汽车充电器能够与移动应用程序通信》,涉及到,有需要的可以收藏一下
在电动汽车 (ev) 世界中,电动汽车驾驶员最神奇的体验之一就是在移动应用程序上点击“开始”并看到充电器开始工作。
但是这个魔法是如何发生的呢?
让我们深入了解电动汽车充电器和移动应用程序如何通信的幕后旅程。
游戏中的玩家
- 移动应用程序:这是用户发起操作的地方,例如开始或停止充电会话。
- 后端服务器:操作背后的大脑,协调应用程序和充电器之间的通信。
- 电动汽车充电器:为您的电动汽车提供电力的硬件。
这些玩家之间的通信遵循名为ocpp(开放充电点协议)的标准化协议。具体来说,大多数系统都使用 基于 websocket 的 ocpp,这可确保实时、可靠的通信。
开始充电过程
第 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 型):在欧洲广泛使用。
每个连接器独立运行,允许一个充电器为多辆车提供服务。
ocpp
ocpp(开放充电点协议)是一种开放式通信标准,专为电动汽车(ev)充电站(充电点)和中央管理系统(通常称为后端系统或充电点管理系统)之间的交互而设计。
它实现了不同制造商和软件提供商的充电基础设施之间的互操作性。
ocpp 版本:
- ocpp 1.5:早期版本,仍在一些旧系统中使用。
- ocpp 1.6:广泛采用,支持 soap 和 websocket 通信。
- ocpp 2.0 和 2.0.1:增强版本,具有更多功能,如改进的安全性 (tls)、支持智能充电、更好的诊断和固件管理。
关键用例:
- 充电站管理:充电站的远程监控、故障排除和固件更新。
- 智能充电:实现负载平衡、调度/预订以及与电网集成。
- 支付集成:允许充电站与支付网关交互并管理用户帐户。
- 分析和报告:帮助运营商分析使用模式并优化运营。
ocpp 的工作原理:
ocpp 定义了充电点和中央系统之间的消息结构和通信协议。例如:
- 充电点发送有关其状态、能耗或错误的消息。
- 中央系统可以发送命令来启动/停止充电、更新固件或执行诊断。
ocpp 由开放收费联盟 (oca) 管理,该联盟持续开发和推广该协议。
包裹
- python:mobilityhouse/ocpp
- javascript:mikuso/ocpp-rpc
总结一下
每次您从应用程序开始或停止充电时,一系列精确的实时消息都会在您的应用程序、后端和充电器之间流动。
ocpp 协议使这一切成为可能,确保不同制造商的充电器和应用程序可以无缝协作。
所以,下次您插入电动汽车并点击“开始”时,您就会更多地了解幕后的魔力!
我一直在开发一个超级方便的工具,叫做 liveapi。
它旨在让开发人员轻松编写 api 文档。
使用liveapi,您可以快速生成交互式api文档,允许用户直接从浏览器执行api。
如果您厌倦了为 api 手动创建文档,这个工具可能会让您的生活变得更轻松。
从 lama2 到 liveapi:构建超级便捷的 api 文档(第二部分)
hexmos 的 athreya 又名 maneshwar ・ 2024 年 12 月 14 日
以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于文章的相关知识,也可关注golang学习网公众号。
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
329 收藏
-
259 收藏
-
334 收藏
-
277 收藏
-
420 收藏
-
181 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 507次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习