『瀚思彼岸』» 智能家居技术论坛

 找回密码
 立即注册
查看: 17785|回复: 114

[插件集成] 南方电网电费数据集成,支持用户名和密码直接登陆

  [复制链接]

2

主题

33

帖子

562

积分

论坛技术达人

积分
562
金钱
524
HASS币
20
发表于 2022-11-19 13:28:45 | 显示全部楼层 |阅读模式
本帖最后由 cubicpill 于 2023-5-20 12:52 编辑

南方电网电费数据HA集成

本集成已经加入HACS默认存储库,可以在HACS直接搜索安装

注意:本集成需求Home Assistant最低版本为2022.11

本集成仅适用于南方电网覆盖范围(广东、广西、云南、贵州、海南),国网接口与南网不通用,因此无法适配。

--------------------------------2023.05.20更新---------------------------------------------------

v1.1.1 正式版 每日电费和阶梯电价实体

功能性更新:

  • 新数据接入:每日电费和当前阶梯电价信息。
  • 添加了6个新实体:最近日电费、当前阶梯、当前阶梯剩余电量、当前阶梯电价、本月累计电费、上月电费。
  • 移除了设置中的”请求超时“参数。

非功能性更新:

  • 使用asyncio重构数据更新部分,提升数据获取速度。
  • 本版本最低HA版本要求为2022.11,请注意升级。
  • bug修复和其他小更改。

如有新增bug,欢迎反馈。
--------------------------------以下正文---------------------------------------------------

在论坛里看到 @louis_lee 大佬写的国网电费数据接入,奈何lz人在南网区域内,没办法直接用现成的插件。
看了一下论坛里大部分都是用Node-RED配合抓包得到的数据接入,比较麻烦,正好最近有点空研究了一下国网网上营业厅的登陆页面,发现比想象中容易,一步一步把登陆时的加密解密实现了。
后来发现网页端的登录态几个小时就会过期,于是又抓包研究了一下App(南网在线),发现App和网页端接口基本相同,但是登录态有效时间长很多,于是切换到了App端的API。
第一次写HA的集成,磕磕绊绊从有想法开始到最终实现写了接近两个周,期间参考了无数论坛和Github前辈们的代码,难免会有一些bug,请见谅。

由于该集成直接使用 Web API 登陆,因此资源消耗相对较小,性能较弱的机器也可以放心使用。

目前实现的功能见下文,也可以直接到Github看:https://github.com/CubicPill/china_southern_power_grid_stat

支持功能

  • 支持南方电网覆盖范围内的电费数据查询(广东、广西、云南、贵州、海南)
  • 支持使用手机号和密码登陆,支持登录态失效之后自动重新登陆
  • 支持多个南网账户(每个账户一个集成),支持单个账户下的多个缴费号
  • 数据自动抓取和更新(默认间隔4小时,可配置)
  • 全程GUI配置,无需编辑yaml进行配置(暂不支持yaml配置)

可接入如下数据:

  • 当前余额和欠费
  • 当前阶梯电量数据(档位、阶梯剩余电量、阶梯电价)
  • 昨日用电量
  • 最新一日用电量、电费(取有数据的最近一日)
  • 本年度总用电量、总电费(非实时,更新到上个月)
  • 本年度每月用电量、电费(非实时,更新到上个月)
  • 上年度总用电量、总电费
  • 上年度每月用电量、电费
  • 当月累计用电量、电费(非实时,有2天左右的延迟)
  • 当月每日用电量、电费(非实时,有2天左右的延迟)
  • 上月累计用电量、电费
  • 上月每日用电量、电费

不支持阶梯电费设置、峰谷电价设置和电费计算(本插件只进行数据抓取和转换,不进行任何计算),暂时也没有支持计划(南网暂时没有统一的API)。如有需求,建议单独创建对应的电价实体。

使用方法

使用HACS手动下载安装

使用手机号和密码登陆
setup_login.png

配置界面
setup_add_account.png

添加缴费号
setup_select_account.png

传感器列表

  • 余额
  • 欠费
  • 当前阶梯档位
  • 当前阶梯剩余电量
  • 当前阶梯电价
  • 上月电费
  • 上月用电量
  • 当月用电量
  • 当月电费
  • 本年度电费
  • 本年度用电量
  • 上年度电费
  • 上年度用电量
  • 最近日用电量
  • 最近日电费
  • 昨日用电量

传感器额外参数(每月用量、每日用量)
sensor_attr.png

参数设置
setup_params.png

数据更新策略

由于上月数据和去年数据在生成之后一般不会发生变化,因此对于上月累计用电量、上月每日用电量、上年度累计用电量、上年度每月用电量,数据更新间隔将会与一般更新间隔有所不同。
具体更新策略如下:

对于上月数据,在每月前3天(1~3日)将会跟随一般更新间隔更新(默认为4小时),其余时间将会停止更新,但数据依然可用。

对于去年数据,在每年一月的前7天(1月1日~1月7日)将会每天更新(在每天第一次触发更新时更新),其余时间将会停止更新,但数据依然可用。

如果需要强制刷新数据,重载集成即可。

一些技术细节

登陆接口加密原理

此部分较为敏感,详见 github repo

Web端接口和App端接口

对于南网API相关信息的提取主要通过Web端的抓包和JS代码获取。
之后因为登录态有效期问题,对App端抓包进行比对后切换到App端API。
经过验证,Web端(网上营业厅)和App端(南网在线)的API接口基本相同,差别主要在于:

Web App
API路径 ucs/ma/wt/ ucs/ma/zt/
支持登陆方式 手机号+密码/验证码,南网在线/微信/支付宝扫码 手机号+密码/验证码
token有效期 几小时 较长
Cookies token包含在cookies中 无cookies
敏感信息(姓名、地址等) 部分信息用“*”隐去 有明文全文

另外在HTTP请求头上有细微的差别(如:UA),但实际上对于请求的返回结果没有影响。

API 实现库

详见 github repo

代码和功能设计参考

感谢瀚思彼岸论坛以下帖子作者的辛苦付出,排名不分先后

自定义集成教程参考:Building a Home Assistant Custom Component Part 1: Project Structure and Basics

















sensors.png

评分

参与人数 12金钱 +113 HASS币 +20 收起 理由
cooliscool + 5 厉害了word楼主!
danmin + 5 谢谢分享用了1个月,回来感谢!.
274911110 + 2 感谢楼主分享!
flyice + 8 感谢楼主分享!
sorrypqa + 10 大神666!
25989406 + 10 论坛有你更精彩!
chenquanhao + 10 论坛有你更精彩!
ruike007 + 8 特别赞
佳艺造型 + 10 感谢楼主分享!
fsscyd + 5 终于见到南方电网的了,对小白来说太合适了.
+ 20 + 20 厉害了word楼主!
dscao + 20 论坛有你更精彩!

查看全部评分

回复

使用道具 举报

14

主题

191

帖子

888

积分

高级会员

Rank: 4

积分
888
金钱
697
HASS币
0
发表于 2022-11-19 14:24:52 来自手机 | 显示全部楼层
把国网也做了。坛子里国网那个用docker太耗费资源了。
回复

使用道具 举报

1

主题

40

帖子

455

积分

论坛分享达人

积分
455
金钱
415
HASS币
10
发表于 2022-11-19 14:56:16 | 显示全部楼层
厉害了,插件都出来了,我本来还想再让流程进化一下的,现在看来不用了哈哈哈哈哈
回复

使用道具 举报

0

主题

29

帖子

536

积分

高级会员

Rank: 4

积分
536
金钱
507
HASS币
0
发表于 2022-11-19 15:08:56 | 显示全部楼层
点添加已绑定的缴费号时候出现 Unknown error occurred
回复

使用道具 举报

22

主题

224

帖子

2388

积分

金牌会员

Rank: 6Rank: 6

积分
2388
金钱
2164
HASS币
0
发表于 2022-11-19 15:10:38 | 显示全部楼层
大佬,能否帮忙看下这个微信小程序的登陆怎么弄? token过一段时间就不行了。https://bbs.hassbian.com/thread-14730-1-1.html
回复

使用道具 举报

76

主题

1357

帖子

1万

积分

元老级技术达人

积分
18325
金钱
16928
HASS币
290
发表于 2022-11-19 15:27:27 | 显示全部楼层
好东西,来学习学习。
回复

使用道具 举报

50

主题

244

帖子

4290

积分

元老级技术达人

积分
4290
金钱
4036
HASS币
80
发表于 2022-11-19 15:40:00 | 显示全部楼层
不考虑向后兼容的话,密码存储可以用公钥加密后的值以避免明文存储密码,token可以在内存中刷新,没必要通过reload集成的方式。对于密码错误之类的exception还可以在follow和sensor中优化,遇到错误就停下,以免反复尝试被锁号。
没意思,跑路了
回复

使用道具 举报

0

主题

45

帖子

577

积分

高级会员

Rank: 4

积分
577
金钱
532
HASS币
0
发表于 2022-11-19 17:51:16 | 显示全部楼层
真厉害啊,今晚试试
回复

使用道具 举报

2

主题

47

帖子

308

积分

中级会员

Rank: 3Rank: 3

积分
308
金钱
261
HASS币
0
发表于 2022-11-19 18:24:35 | 显示全部楼层
ucomeito 发表于 2022-11-19 15:08
点添加已绑定的缴费号时候出现 Unknown error occurred

我也是这样
回复

使用道具 举报

7

主题

1072

帖子

3361

积分

论坛元老

Rank: 8Rank: 8

积分
3361
金钱
2289
HASS币
0
发表于 2022-11-19 18:28:14 | 显示全部楼层
这是大佬,大佬。
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

Archiver|手机版|小黑屋|Hassbian

GMT+8, 2024-4-26 17:38 , Processed in 0.115330 second(s), 35 queries .

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表