热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

支付宝小程序控制硬件②】全网首篇,个人支付宝小程序控制智能硬件esp8266,从设计电路到设计协议控制两盏LED灯调节亮度。


本系列属于支付宝小程序控制智能硬件 esp8266等芯片的思路编程,欢迎大家点点手指关注我半颗心脏,博客文章列表干货多多,有任何疑问评论区留言,第一时间看到回复!

【支付宝小程序控制硬件①】 申请个人支付宝下程序开发的个人账户,认识支付宝小程序框架结构,做好智能控制第一步!
【支付宝小程序控制硬件②】 全网首篇,个人支付宝小程序控制智能硬件esp8266,从设计电路到设计协议控制两盏LED灯调节亮度。

支付宝小程序控制硬件②】 全网首篇,个人支付宝小程序控制智能硬件esp8266,从设计电路到设计协议控制两盏LED灯调节亮度。


文章目录

  • 一、前言;
  • 二、准备材料;
  • 三、注册支付宝小程序账号;
    • 3.1 注册;
  • 四、通讯原理以及协议;
  • 五、mqtt服务器搭建;
  • 六、设备端代码部分讲解;
  • 七、支付宝小程序代码部分讲解;
  • 八 、后记;


        当微信小程序崛起的时候,遇到了目前智能家居时代的时候,我做了一个微信小程序控制esp8266文章,之后网上很多都参考我思路,乃至图片都是和我一模一样的,哈哈!看来还行!

        今天给大家带来的是我小练习项目— 个人支付宝小程序控制智能硬件esp8266,我敢肯定是全网首篇的,因为我目前在百度找不到哈哈!

        前面章节我已经详细记录了我在支付宝小程序上集成mqtt协议的睬坑过程,现在回想起来依然是心累的,因为至今没有人测试和做这领域。作为“前人”,我深深感觉到是一种荣誉!可实现起来控制,而且还这样分享给大家一些笔记!

       最近在备考,很多时间都不怎么写博客了!谅解!!因为有些梦想未在指定的时间内实现,即使老去,也会感慨后悔当初!


二、准备材料;
  • esp8266 nodeMcu 一个,杜邦线若干,高亮 3.3v LED灯若干个!
  • 支付宝小程序账号一个,请自行注册!
  • 手机上安装支付宝软件最新版,不分ios版还是Android版!调试小程序!
  • 对esp8266 rtos3.0的编程熟悉。
  • 电路设计如下:

支付宝小程序控制硬件②】 全网首篇,个人支付宝小程序控制智能硬件esp8266,从设计电路到设计协议控制两盏LED灯调节亮度。


  • 实物图:
    支付宝小程序控制硬件②】 全网首篇,个人支付宝小程序控制智能硬件esp8266,从设计电路到设计协议控制两盏LED灯调节亮度。

三、注册支付宝小程序账号;

3.1 注册;


  • 访问:https://docs.alipay.com/mini/developer/getting-started,找到登录按钮用支付宝软件扫描就可以了!
  • 之后一路无脑式创建就可以了!
  • 下载开发 支付宝小程序专门的IDE开发工具,类似微信开发一样:https://docs.alipay.com/mini/ide/overview
  • 新建项目和导入项目,下面是本工程的截图,右上角有 模拟器调试预览上传主要功能:
    • 模拟器:本地新建一个手机模拟器,非真机环境,用来调试代码!我们mqtt调试切勿用模拟器调试!
    • 调试:是调试到真机功能,可以在IDE看到真机打印的日志!
    • 预览:也是调试到真机的功能,但是不可以在 IDE记录看到真机打印的日志!只能在本地真机调试!
    • 上传:上传到阿里云服务器,可以给其他用户扫描二维码体验,当然了 ,上传之后,就可以提交审核上架了!

支付宝小程序控制硬件②】 全网首篇,个人支付宝小程序控制智能硬件esp8266,从设计电路到设计协议控制两盏LED灯调节亮度。


四、通讯原理以及协议;

        实现的控制的原理我之前用微信小程序控制esp8266的思路一致,总结如下:

支付宝小程序控制硬件②】 全网首篇,个人支付宝小程序控制智能硬件esp8266,从设计电路到设计协议控制两盏LED灯调节亮度。
  • 注意角色:(设备 --> esp8266,设备商云 --> 服务器,微信客户端 --> 支付宝小程序):
  • 先上图,也请认真观看上图,这是我本篇实现的控制过程,也是我想到的控制过程,哈哈!
  • 概述
    • ①:服务器我们采用自己的服务器,上位机就是支付宝客户端,我们是在支付宝的环境下开发的,也就避免不了和微信打交道,避免不了要遵循支付宝开发的规范!所以要有一定的前端开发知识哦!也就是H5+css+javaSrcipt,支付宝小程序开发和这个非常相似!如果想入门支付宝小程序开发,自己可以去琢磨!
    • ②:设备商云也就是我们的服务器,仅仅做一个中转信号处理,不做任何的消息存储和分析哈!
    • ③:通讯过程是 esp8266上报消息到服务器,服务器转发消息到支付宝小程序!反过来,微信小程序控制下发,先发送消息到服务器,然后到esp8266!
    • ④:既然服务器仅仅是一个中转信号处理,那么我们的支付宝小程序和esp8266的通讯协议,自己拟定就好,下面是我拟定的,也是本文项目的协议!

  • 支付宝小程序下发控制的通讯协议
主题 发送端 接收端 消息(JSON格式) 消息含义
/light/devsub 支付宝小程序 esp8266 “{“change”:“power”,“value”:true}” 开灯
“{“change”:“power”,“value”:“false”}” 关灯
“{“change”:“blue”,“value”:50}” 调节蓝灯亮度:value为亮度值 ,范围 [0,100]
“{“change”:“red”,“value”:50}” 调节红灯亮度:value为亮度值 ,范围 [0,100]
“{“change”:“query”,“value”:0}” 支付宝小程序主动请求最新状态
  • esp8266上报同步的通讯协议
主题 发送端 接收端 消息(JSON格式) 消息含义
/light/devpub esp8266 支付宝小程序 “{“power”:“false”,“blue”:50,“red”:50}” power为2个灯的状态,blue是蓝灯亮度值,red是蓝灯亮度值,范围都是 [0,100]


五、mqtt服务器搭建;

        关于mqtt服务器搭建的要求,在支付宝小程序是没要求的,只要支持websocket就可以了,不像微信小程序那样严格必须是443 端口!而是任意端口,而我为了方便,依然是采用之前微信小程序接入的443端口!

        所以,关于mqtt服务器搭建,以及如何反代理端口,请参考我之前的资料:

  • https://blog.csdn.net/xh870189248/article/details/84070944
  • https://www.bilibili.com/video/av39598869
  • https://blog.csdn.net/xh870189248/article/details/84070944

        如果能力有限搭建失败麻烦,也欢迎加群,有提供免费的mqtt的服务器连接测试!


六、设备端代码部分讲解;

        为了学习,我这里采用的是乐鑫最新的 rtos3.0分支上二次开发,意味要搭建 rtos3.0的环境,请自行搭建可参考我之前的博文:https://blog.csdn.net/xh870189248/article/details/81382279 。

        而我的mqtt通讯采用的是乐鑫自研的框架esp-mqtt,在工程构建前请手动选择 mqtt组件为esp-mqtt,可以在 make menuconfig设置,否则会报错:fatal error: mqtt_client.h: No such file or directory (GIT8266O-144),请知悉!可以参考下面的 动态图:
支付宝小程序控制硬件②】 全网首篇,个人支付宝小程序控制智能硬件esp8266,从设计电路到设计协议控制两盏LED灯调节亮度。


        我这里就不采用一键配网模式了,直接把路由器的账户密码写死在本地代码里面:

支付宝小程序控制硬件②】 全网首篇,个人支付宝小程序控制智能硬件esp8266,从设计电路到设计协议控制两盏LED灯调节亮度。


        下面是连接服务器的配置,请替换为你自己的服务器配置参数!

支付宝小程序控制硬件②】 全网首篇,个人支付宝小程序控制智能硬件esp8266,从设计电路到设计协议控制两盏LED灯调节亮度。


        下面是mqtt状态回调函数,实现的逻辑主要是如下:

  • 连接成功回调函数下开始订阅主题;
  • 服务器下发函数做自己的业务逻辑,这里的是异步进行的哈!下面的截图可以看到,是解析到了支付宝小程序下发的数据指令!

支付宝小程序控制硬件②】 全网首篇,个人支付宝小程序控制智能硬件esp8266,从设计电路到设计协议控制两盏LED灯调节亮度。


七、支付宝小程序代码部分讲解;

        布局是必不可少的,这里很简单, 就是三个控件,样式代码就不贴了:
支付宝小程序控制硬件②】 全网首篇,个人支付宝小程序控制智能硬件esp8266,从设计电路到设计协议控制两盏LED灯调节亮度。


        业务逻辑函数:

  • 其中的 sliderBlueCallBack() 函数是蓝色滑条的滑动回调函数!
  • 其中的 sliderRedCallBack() 函数是蓝色滑条的滑动回调函数!.
  • 工程一开始加载页面后回调函数onLoad()就开始连接服务器!

支付宝小程序控制硬件②】 全网首篇,个人支付宝小程序控制智能硬件esp8266,从设计电路到设计协议控制两盏LED灯调节亮度。


  • 最后得到的预览效果就是这样啦,还行啦!!

支付宝小程序控制硬件②】 全网首篇,个人支付宝小程序控制智能硬件esp8266,从设计电路到设计协议控制两盏LED灯调节亮度。


八 、后记;

支付宝小程序控制硬件②】 全网首篇,个人支付宝小程序控制智能硬件esp8266,从设计电路到设计协议控制两盏LED灯调节亮度。

  • 支付宝小程序是本人从集成mqtt协议开始到后面的通讯协议到控制esp8266的,而且协议和服务器搭建是花费蛮多时间的,最重要的是,这博文是花费几乎四个小时排版和编写,哈哈!各位能力强的朋友就参考我思路可以了,群里有些人要Bug我的代码,所以,我也就放在咸鱼了。需要的去看看吧!
  • 因为这个是我以后的面试作品,需要的就光顾下,价格绝对地便宜,不喜勿喷哈不喜勿喷哈!博文技术参考还是可以的!哈哈!!咸鱼APP扫描即可!骚扰者请不要扫描了啦,只求真诚交易!
支付宝小程序控制硬件②】 全网首篇,个人支付宝小程序控制智能硬件esp8266,从设计电路到设计协议控制两盏LED灯调节亮度。

推荐阅读
  • 使用eclipse创建一个Java项目的步骤
    本文介绍了使用eclipse创建一个Java项目的步骤,包括启动eclipse、选择New Project命令、在对话框中输入项目名称等。同时还介绍了Java Settings对话框中的一些选项,以及如何修改Java程序的输出目录。 ... [详细]
  • 本文详细介绍了Java中vector的使用方法和相关知识,包括vector类的功能、构造方法和使用注意事项。通过使用vector类,可以方便地实现动态数组的功能,并且可以随意插入不同类型的对象,进行查找、插入和删除操作。这篇文章对于需要频繁进行查找、插入和删除操作的情况下,使用vector类是一个很好的选择。 ... [详细]
  • 本文介绍了一些Java开发项目管理工具及其配置教程,包括团队协同工具worktil,版本管理工具GitLab,自动化构建工具Jenkins,项目管理工具Maven和Maven私服Nexus,以及Mybatis的安装和代码自动生成工具。提供了相关链接供读者参考。 ... [详细]
  • 一次上线事故,30岁+的程序员踩坑经验之谈
    本文主要介绍了一位30岁+的程序员在一次上线事故中踩坑的经验之谈。文章提到了在双十一活动期间,作为一个在线医疗项目,他们进行了优惠折扣活动的升级改造。然而,在上线前的最后一天,由于大量数据请求,导致部分接口出现问题。作者通过部署两台opentsdb来解决问题,但读数据的opentsdb仍然经常假死。作者只能查询最近24小时的数据。这次事故给他带来了很多教训和经验。 ... [详细]
  • Python脚本编写创建输出数据库并添加模型和场数据的方法
    本文介绍了使用Python脚本编写创建输出数据库并添加模型数据和场数据的方法。首先导入相应模块,然后创建输出数据库并添加材料属性、截面、部件实例、分析步和帧、节点和单元等对象。接着向输出数据库中添加场数据和历程数据,本例中只添加了节点位移。最后保存数据库文件并关闭文件。文章还提供了部分代码和Abaqus操作步骤。另外,作者还建立了关于Abaqus的学习交流群,欢迎加入并提问。 ... [详细]
  • 工作经验谈之-让百度地图API调用数据库内容 及详解
    这段时间,所在项目中要用到的一个模块,就是让数据库中的内容在百度地图上展现出来,如经纬度。主要实现以下几点功能:1.读取数据库中的经纬度值在百度上标注出来。2.点击标注弹出对应信息。3 ... [详细]
  • 分布式事务_分布式事务ACID/BASE/CAP + TCC/2PC/Soga/....
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了分布式事务ACID/BASE/CAP+TCC/2PC/Soga/.相关的知识,希望对你有一定的参考价值。 ... [详细]
  • 基于Springboot实现Mqtt
    转载:基于Springboot实现MqttJava端开发:pom.xml: ... [详细]
  • React Native集成支付宝支付的实现方法
    这篇文章主要介绍了React Native集成支付宝支付的实现现,ativeModules是JS代码调用原生模块的桥梁。所以,我们只需要在原生工程中集成支付宝和微信支付的sdk,然 ... [详细]
  • php对接AliGenie天猫精灵服务器控制智能硬件esp8266② 全面认识第三方授权机制 oauth2.0 协议,如何在 php 上搭建 oauth2.0服务端!(附带demo)
    本系列博客学习由非官方人员半颗心脏潜心所力所写,仅仅做个人技术交流分享,不做任何商业用途。如有不对之处,请留言,本人及时更改 ... [详细]
  • 本文介绍了Java工具类库Hutool,该工具包封装了对文件、流、加密解密、转码、正则、线程、XML等JDK方法的封装,并提供了各种Util工具类。同时,还介绍了Hutool的组件,包括动态代理、布隆过滤、缓存、定时任务等功能。该工具包可以简化Java代码,提高开发效率。 ... [详细]
  • 本文讨论了如何优化解决hdu 1003 java题目的动态规划方法,通过分析加法规则和最大和的性质,提出了一种优化的思路。具体方法是,当从1加到n为负时,即sum(1,n)sum(n,s),可以继续加法计算。同时,还考虑了两种特殊情况:都是负数的情况和有0的情况。最后,通过使用Scanner类来获取输入数据。 ... [详细]
  • 本文介绍了OC学习笔记中的@property和@synthesize,包括属性的定义和合成的使用方法。通过示例代码详细讲解了@property和@synthesize的作用和用法。 ... [详细]
  • Google Play推出全新的应用内评价API,帮助开发者获取更多优质用户反馈。用户每天在Google Play上发表数百万条评论,这有助于开发者了解用户喜好和改进需求。开发者可以选择在适当的时间请求用户撰写评论,以获得全面而有用的反馈。全新应用内评价功能让用户无需返回应用详情页面即可发表评论,提升用户体验。 ... [详细]
  • Matlab 中的一些小技巧(2)
    1.Ctrl+D打开子程序  在MATLAB的Editor中,将输入光标放到一个子程序名称中间,然后按Ctrl+D可以打开该子函数的m文件。当然这个子程序要在路径列表中(或在当前工作路径中)。实际上 ... [详细]
author-avatar
踢出个未来为我鼓掌
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有