OCPP.Core
OCPP.Core是一个用.NET 8编写的OCPP(开放充电点协议)服务器。它包含一个管理Web界面,用于管理充电点和充电令牌(RFID令牌)。
状态
目前支持OCPP1.6J和2.0(JSON/REST)。
OCPP.Core目前正在与6个KEBA P30c/x充电点一起使用,这些充电点在负载管理和OCPP1.6J下运行。 这里是我的首次实际使用体验报告。
如果它能与您的充电站正常工作或遇到问题,请反馈
OCPP服务器目前处理以下消息:
OCPP V1.6:
- 启动通知
- 心跳
- 授权
- 开始交易
- 结束交易
- 电表值
- 状态通知
- 数据传输
- 重置
- 解锁连接器
OCPP V2.0:
- 启动通知
- 心跳
- 授权
- 交易事件
- 电表值
- 状态通知
- 数据传输
- 日志状态通知
- 固件状态通知
- 清除充电限制
- 通知充电限制
- 通知电动车充电计划
- 重置
- 解锁连接器
管理Web界面
Web界面支持英语和德语本地化。它有一个概览页面,显示所有充电站及其可用性。
每个充电点(或连接器!)都显示为一个带有状态信息的磁贴。如果有车辆正在充电,磁贴会变红并显示持续时间。如果充电站发送当前功率和充电状态(SoC)数据,这些信息会显示在磁贴的底部。例如,我们的KEBA设备只发送主电表值:-(
点击充电点/连接器磁贴,您可以看到最近交易的列表,并可以将其下载为CSV格式。
Web界面有两种不同的角色。普通用户可以查看充电点和交易(如上截图所示)。管理员还可以创建和编辑充电站、充电标签和连接器。
多连接器行为
起初,我没有太关注多连接器。带有多个连接器的充电点并不常见。但后来我们在家里安装了充电点,发现我们的设备(带负载管理)作为单个充电点运行,每个充电点有一个连接器(详见此处)。
我在V1.1版本中添加了多连接器支持。当服务器收到带有连接器编号的OCPP消息(状态和交易消息)时,OCPP服务器会在数据库(ConnectorStatus表)中动态构建连接器列表。管理员用户可以查看此列表,并可选择配置自定义名称。
这导致显示充电点的不同场景:
- 没有已知连接器的充电点 => 使用其名称显示充电点
- 有一个已知连接器但没有特定名称的充电点 => 使用充电点名称显示一个充电点
- 有2个或更多连接器但没有特定名称的充电点 => 使用默认名称"充电点名称:连接器编号"显示每个连接器
如果连接器有指定名称,该名称将覆盖充电点名称或默认方案(如上所述)。这允许您为每个连接器定义自定义名称(如左/右)。
系统要求
OCPP.Core使用.NET 8编写,因此可在不同平台上运行。我还将其安装在Azure上进行测试。 存储基于EntityFramework-Core,支持不同的数据库。项目包含SQL-Server(SQL-Express)和SQLite的脚本。
引用的包:
- Microsoft.EntityFrameworkCore
- Microsoft.EntityFrameworkCore.Sqlite
- Microsoft.EntityFrameworkCore.SqlServer
- Newtonsoft.Json
- Karambolo.Extensions.Logging.File
构建、配置和安装
构建、配置和安装OCPP.Core的步骤在此处有详细描述。
测试...
Web界面
在浏览器中打开配置的URL。项目中的调试URL是"http://localhost:8082/"。 您应该看到登录界面。输入配置的管理员账户。
打开"管理"菜单,创建一个ID为"station42"的充电点和一个充电标签。
管理菜单:
创建新充电点:
您可以选择为此充电点添加认证数据:基本认证的用户名/密码和/或客户端证书的指纹。 编辑充电点时,您可以在此处向充电点发送重启或解锁命令。
创建新充电标签:
Web界面支持英语和德语本地化
OCPP服务器
测试OCPP服务器的一个简单方法是使用模拟器:
- OCPP1.6简单充电盒模拟器
- OCPP-2.0-CP-模拟器
注意:两个模拟器在某些操作中都存在小问题和大问题。这就是为什么我修改了它们并在此项目中包含了副本。 还有一个带有两个连接器的1.6模拟器的扩展版本。
在浏览器中打开其中一个模拟器,输入"ws://localhost:8081/OCPP/station42"作为中央站URL。 "station42"是您在上一步中创建的充电点ID。
输入您之前输入的充电标签ID作为"Tag"。
点击"连接"
现在模拟器应该在底部显示成功消息。 当您开始一个交易并刷新Web界面时,您应该在充电点磁贴中看到相应的状态。