OCPP 1.6 接入实现文档

一、简介

OCPP(Open Charge Point Protocol)是一个开放的通信协议,用于充电站(Charge Point)与中央系统(Central System,如充电站管理系统或服务提供商平台)之间的通讯。本篇文档将详细阐述如何基于OCPP 1.6版本进行接入和实现。

1.1 OCPP 1.6 特点

OCPP 1.6标准增强了安全性,支持JSON格式的消息传输,并引入了更多的功能以满足更复杂的充电需求,例如智能充电、远程触发控制、计量数据上报等。

二、环境准备

  • 硬件:确保充电设备支持OCPP 1.6协议并配置网络连接。
  • 软件:在充电站和中央系统两端均需安装支持OCPP 1.6的软件栈,包括协议解析库和应用层业务逻辑处理程序。
  • 安全设置:根据OCPP 1.6规范,可以使用TLS加密以保证通讯的安全性。

三、接入步骤

3.1 建立连接

  1. 充电站启动后主动向中央系统发起TCP连接请求,并发送BootNotification消息以告知其已上线。
  2. 中央系统收到BootNotification后回应一个确认消息,并可能提供一些配置信息。
    1)BootNotification.req:充电站启动后发送BootNotification.req消息给中央系统。
    2)BootNotification.conf:中央系统收到请求后回复BootNotification.conf确认消息,并可能提供配置信息。

3.2 认证授权

  • 根据实际部署情况,可能需要执行身份认证和授权过程,这通常通过AuthorizeStartTransaction等消息实现。
    1)Authorize.req:当用户插入充电枪时,充电站向中央系统发起Authorize.req请求,包含用户ID(如RFID标签ID)。
    2)Authorize.conf:中央系统验证用户身份并回复Authorize.conf响应,指示是否授权成功。
    3)StartTransaction.req:在授权成功后,充电站发送StartTransaction.req以开始充电交易。
    4)StartTransaction.conf:中央系统回复确认交易开始的消息。
     

3.3 数据交互

  • 充电站定期或在特定事件触发时向中央系统发送状态更新,如HeartbeatMeterValuesStatusNotification等。
    1)MeterValues.req:充电过程中,充电站定期或按需发送MeterValues.req报告计量值(如电量消耗)。
    2)Heartbeat.req/Heartbeat.conf:为了保持连接状态和检查存活,双方可定期互发心跳包。
  • 中央系统可以通过RemoteStartTransactionRemoteStopTransactionChangeConfiguration等命令来远程控制和管理充电站。
     

3.4 交易处理

  • 交易生命周期涉及StartTransactionStopTransaction等消息,用于记录并结算充电费用。
    1)StopTransaction.req:充电结束时,充电站发送StopTransaction.req停止交易并结算费用。
    2)StopTransaction.conf:中央系统确认交易已停止并完成计费处理。
    3)UpdateFirmware.req:如果有新固件版本,中央系统可以发送UpdateFirmware.req命令要求充电站升级固件。
     

四、关键接口实现

4.1 BootNotification
Json
{
  "messageTypeId": "BootNotification",
  "chargePointVendor": "Vendor Name",
  "chargePointModel": "Model Name",
  "firmwareVersion": "Version Number",
  "iccid": "Optional ICCID",
  "imsi": "Optional IMSI"
}
4.2 Authorize
Json
{
  "messageTypeId": "Authorize",
  "idTag": "User's ID Tag"
}
4.3 StartTransaction
Json
{
  "messageTypeId": "StartTransaction",
  "connectorId": "Connector Identifier",
  "idTag": "User's ID Tag",
  // Other optional parameters...
}
4.4 MeterValues
Json
{
  "messageTypeId": "MeterValues",
  "connectorId": "Connector Identifier",
  "transactionId": "Transaction Identifier",
  "meterValue": [
    {
      "timestamp": "Timestamp of the reading",
      "sampledValue": [
        {
          "value": "Energy consumed in Wh",
          // Other sampled values such as voltage, current, etc.
        }
      ]
    }
  ]
}

1. 创建基础结构

首先,你需要创建一个ChargePoint类和一个CentralSystem类来模拟双方交互。假设使用了Spring Boot和WebSockets(因为OCPP 1.6支持WebSocket传输):

Java

public class ChargePoint {
    // 连接WebSocket会话
    private WebSocketSession session;
    
    // 其他属性如vendor, model等...

    public void sendToCentralSystem(Message message) {
        try {
            this.session.sendMessage(new TextMessage(objectMapper.writeValueAsString(message)));
        } catch (JsonProcessingException e) {
            // 处理序列化异常
        } catch (IOException e) {
            // 处理网络IO异常
        }
    }

    // 实现其他接口调用方法,如bootNotification, startTransaction等...
}

public class CentralSystem {
    // 处理从充电站接收的消息
    public void handleMessage(String json) {
        Message message = objectMapper.readValue(json, Message.class);
        handleIncomingMessage(message);
    }

    private void handleIncomingMessage(Message message) {
        switch (message.getMessageTypeId()) {
            case BOOT_NOTIFICATION:
                BootNotificationRequest bootNotification = (BootNotificationRequest) message;
                // 处理并回应BootNotification请求
                break;
            // 类似的处理StartTransaction, MeterValues等其他类型的消息
        }
    }

    // 实现向充电站发送消息的方法
}

2. 定义消息模型

定义各类消息对象,例如BootNotificationRequestMeterValuesRequest等,它们都继承自一个基类Message

Java

public abstract class Message {
    private String messageTypeId;
    // 其他公共属性或方法...
}

public class BootNotificationRequest extends Message {
    private String chargePointVendor;
    private String chargePointModel;
    // 其他属性...
}

public class MeterValuesRequest extends Message {
    private List<MeterValue> meterValues;
    // 其他属性...
    
    public static class MeterValue {
        private Long timestamp;
        private List<SampledValue> sampledValues;
        // ...
    }
    
    public static class SampledValue {
        private String value;
        // 其他计量值属性...
    }
}

3. 序列化与反序列化

利用Jackson库或其他JSON库进行序列化和反序列化操作:

Java

import com.fasterxml.jackson.databind.ObjectMapper;

ObjectMapper objectMapper = new ObjectMapper();

4. 实际消息处理逻辑

handleIncomingMessage方法中,针对每种消息类型执行相应的业务逻辑,例如处理BootNotification

Java

private void handleIncomingMessage(Message message) {
    if (message instanceof BootNotificationRequest) {
        BootNotificationRequest bootNotification = (BootNotificationRequest) message;
        // 业务逻辑:验证设备信息、保存到数据库、回复确认消息等
        BootNotificationResponse response = new BootNotificationResponse(RegistrationStatus.Accepted, "config");
        String jsonResponse = objectMapper.writeValueAsString(response);
        chargePoint.sendToCentralSystem(response);
    }
    // 其他消息类型的处理...
}

五、注意事项

  • 确保正确处理各类消息的响应以及错误处理机制。
  • 遵循协议规定的消息序列化和反序列化规则,确保数据传输准确无误。
  • 对于长期运行的服务,必须考虑异常恢复、断线重连及事务一致性问题。

六、测试验证

  • 在完成对接后,进行全面的功能测试和压力测试,确保在各种场景下系统的稳定性和可靠性。

通过遵循上述步骤和指南,您可以成功地将符合OCPP 1.6标准的充电站接入到您的中央系统中,实现充电设施的智能化管理和运营。同时,请务必查阅官方的OCPP 1.6完整规范以获取详细的协议定义和要求。

七、实现效果

APP 效果图:

首页及钱包页

运营平台:

首页

订单详情页

如有海外充电平台定制需求,可私。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/404957.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Matlab论文插图绘制模板第137期—极坐标分组气泡图

在之前的文章中&#xff0c;分享了Matlab极坐标气泡图的绘制模板&#xff1a; 进一步&#xff0c;再来分享一下极坐标分组气泡图。 先来看一下成品效果&#xff1a; ​ 特别提示&#xff1a;本期内容『数据代码』已上传资源群中&#xff0c;加群的朋友请自行下载。有需要的朋…

有哪些适合程序员的副业

如果你经常玩知乎、看公众号&#xff08;软件、工具、互联网这几类的&#xff09;你就会发现&#xff0c;好多资源连接都变成了夸克网盘、迅雷网盘的资源链接。 例如&#xff1a;天涯神贴&#xff0c;基本上全是夸克、UC、迅雷网盘的资源链接。 有资源的前提下&#xff0c;迅雷…

并发编程(2)管程(悲观锁)

4 共享模型之管程 本章内容 共享问题synchronized线程安全分析Monitorwait/notify线程状态转换活跃性Lock 4.1 共享带来的问题 4.1.1 小故事 老王&#xff08;操作系统&#xff09;有一个功能强大的算盘&#xff08;CPU&#xff09;&#xff0c;现在想把它租出去&#xff…

2024年阿里云服务器优惠价格表,值得买云主机清单

2024阿里云服务器优惠活动政策整理&#xff0c;轻量2核2G3M服务器61元一年、2核4G4M带宽165元1年&#xff0c;云服务器4核16G10M带宽26元1个月、149元半年&#xff0c;阿里云ECS云服务器2核2G3M新老用户均可99元一年续费不涨价&#xff0c;企业用户2核4G5M带宽199元一年&#x…

PLC_博图系列☞基本指令“赋值”

PLC_博图系列☞基本指令“赋值” 文章目录 PLC_博图系列☞基本指令“赋值”背景介绍&#xff1a;赋值说明参数示例 关键字&#xff1a; PLC、 西门子、 博图、 Siemens 、 赋值 背景介绍 这是一篇关于PLC编程的文章&#xff0c;特别是关于西门子的博图软件。我并不是专业的…

Vite+Vue3+Ant Design3.2报错: Cannot read properties of null (reading ‘isCE‘)

最近的ViteVue3Ant Design Vue3.2开发的项目莫名其妙的报错&#xff1a; Uncaught (in promise) TypeError: Cannot read properties of null (reading isCE) 一直找不到原因出在哪&#xff0c;害的我费了好多时间调试 &#xff0c;百度上也找了各个解决方法&#xff0c;有说使…

如何实现一个规则研究区域内数据的提取(matlab)

在利用经验正交分解&#xff08;EOF&#xff09;进行某一个研究区域分析时&#xff0c;我们需要将研究区域转换成N*M的矩阵&#xff0c;其中N为空间维度&#xff0c;M为时间维度&#xff0c;这意味着我们之前的数据加上时间维度是三维的&#xff0c;即&#xff08;lon,lat,rg&a…

2024年面试季,大前端相关开发者不妨了解一下鸿蒙开发岗

搜狐&#xff1a;我宣布与华为达成鸿蒙全面合作&#xff01; 美团&#xff1a;我宣布与华为达成鸿蒙全面合作&#xff01; 360 &#xff1a;我宣布与华为达成鸿蒙全面合作&#xff01; 高德&#xff1a;我宣布与华为达成鸿蒙全面合作&#xff01; 新浪&#xff1a;我宣布与华为…

java使用poi简单操作excel

文章目录 引言插入行/列合并单元格以及设置居中换行 引言 编程开发中&#xff0c;我们可能会接到某些需求&#xff0c;例如导出某某某列表数据&#xff0c;或者做一份报表&#xff0c;这时候就需要我们的poi出场了&#xff0c;至于一些规则数据的导出&#xff0c;直接使用easy…

游戏服务器价格对比分析,2024高主频高性能服务器租用价格

游戏服务器租用多少钱一年&#xff1f;1个月游戏服务器费用多少&#xff1f;阿里云4核16G10M游戏服务器26元1个月、149元半年&#xff0c;腾讯云4核16G游戏服务器32元、312元一年&#xff0c;华为云26元&#xff0c;京东云主机也是26元起&#xff0c;游戏服务器配置从4核16G、4…

Linux学习方法-框架学习法——Linux驱动架构的演进

配套视频学习链接&#xff1a;https://www.bilibili.com/video/BV1HE411w7by?p4&vd_sourced488bc722b90657aaa06a1e8647eddfc 目录 Linux驱动演进的过程 Linux驱动的原始架构(Linux V2.4) 平台总线架构(platform) Linux设备树 Linux驱动演进的趋势 Linux驱动演进的过程…

最新攻略揭秘!多微信一键转发朋友圈,快速推广

现如今&#xff0c;微信朋友圈已然成为很多企业和个人的重要推广渠道之一。而如何快速推广朋友圈内容&#xff0c;吸引更多关注和转发&#xff0c;成为许多人关注的焦点。 今天就给大家分享一个可以实现一键转发朋友圈的工具——微信管理系统&#xff0c;帮助你快速提升内容曝…

#gStore-weekly | workbench功能详解之知识更新

gStore workbench作为gStore的可视化管理工具&#xff0c;不仅提供了可视化查询功能&#xff0c;还提供了可视化的知识更新功能&#xff0c;用户可以在可视化界面上进行知识的新增、修改和删除等操作&#xff0c;让我们的知识管理更加清晰和便捷。 1.查询知识 登录workbenc…

深信服技术认证“SCCA-C”划重点:深信服超融合HCI

为帮助大家更加系统化地学习云计算知识&#xff0c;高效通过云计算工程师认证&#xff0c;深信服特推出“SCCA-C认证备考秘笈”&#xff0c;共十期内容。“考试重点”内容框架&#xff0c;帮助大家快速get重点知识 划重点来啦 *点击图片放大展示 深信服云计算认证&#xff08;S…

TDesign Vue Next Starter中后台项目的生产环境部署与CSP内容安全策略、CORS跨源资源共享和服务后端开发

TDesign Vue Next Starter中后台项目的生产环境部署与CSP内容安全策略、CORS跨源资源共享和服务后端开发 目录 TDesign Vue Next Starter中后台项目的生产环境部署与CSP内容安全策略、CORS跨源资源共享和服务后端开发 一、TDesign Vue Next Starter中后台项目模板 1.1、项目…

​​​​​​​Sora:OpenAI的革命性AI视频模型与其对未来影像创作的影响

随着深度学习技术和计算能力的进步&#xff0c;人工智能不仅在图像识别、自然语言处理等领域取得了卓越成就&#xff0c;同时也在不断突破视频处理和生成的边界。在这一背景下&#xff0c;OpenAI推出了Sora——一种新型的AI视频模型&#xff0c;标志着AI在视频内容创作领域的又…

后端程序员入门react笔记(四)-综合运用,写一个小demo

样式模块化 有时候我们会遇到这样的问题&#xff0c;有两个css对一个class声明了样式&#xff0c;这样的话后引入的css会覆盖前面的css样式&#xff0c;导致样式冲突&#xff0c;那么我们怎么解决这种问题呢&#xff0c;我们可以使用样式的模块化&#xff0c;我们起名一个inde…

Shell好用的工具: cut

目标 使用cut可以切割提取指定列\字符\字节的数据 介绍 cut 译为“剪切, 切割” , 是一个强大文本处理工具&#xff0c;它可以将文本按列进行划分的文本处理。cut命令逐行读入文本&#xff0c;然后按列划分字段并进行提取、输出等操作。 语法 cut [options] filename opti…

Vue(学习笔记)

什么是Vue Vue是一套构建用户界面的渐进式框架 构建用户界面&#xff1a; 基于数据渲染出用户可以看到的界面 渐进式&#xff1a; 所谓渐进式就是循序渐进&#xff0c;不一定非得把Vue中的所有API都学完才能开发Vue&#xff0c;可以学一点开发一点 创建Vue实例 比如就上面…

java面向对象上:类的结构之一

目录 1.相同点 2.不同点 2.1 在类中声明的位置的不同 2.2 关于权限修饰符的不同 2.3 默认初始化值的情况&#xff1a; 2.4 在内存中加载的位置 补充&#xff1a;回顾变量的分类&#xff1a; 方式一&#xff1a;按照数据类型&#xff1a; 方式二&#xff1a;按照在类中…