ESP8266使用详解--基于Lua脚本语言
这些天,,,,今天终于看到了希望,,,天道酬勤
先说实现的功能...让ESP8266连接无线网,然后让它建立服务器,,我的客户端连接上以后,发给客户端发数据模块打印到串口,,往ESP8266串口里发数据自动转发给网口
先看效果图,终于不需要单片机配置了

程序源码


我的init.lua
lighton=
pin=
gpio.mode(pin,gpio.OUTPUT)
tmr.alarm(,,,function()
if lighton== then
lighton=
gpio.write(pin,gpio.HIGH)
else
lighton=
gpio.write(pin,gpio.LOW)
end
end) dofile("conncet_wifi.lua")
我的 conncet_wifi.lua
uart.setup(0,9600,8,0,1,0)
wifi.setmode(wifi.STATIONAP)
wifi.sta.config("","")
wifi.sta.connect()
tmr.alarm(, , , function()
if wifi.sta.getip() == nil then
print("Connecting...")
else
tmr.stop()
print("Connected, IP is "..wifi.sta.getip())
end
end) srv=net.createServer(net.TCP,)
srv:listen(,function(conn)
--print("build success")
connect = conn
conn:on("receive",function(conn,payload)
print(payload)
--conn:send("<h1> Hello, NodeMcu.</h1>")
end)
end)
uart.on("data",
function(data)
connect:send(data)
end, )
因为可能刷的固件不一样,如果出现下面的问题

修改为
APConfig={}
APConfig.ssid="ACLAY"
APConfig.pwd="wange903"
wifi.sta.config(APConfig)
如果想让多个客服端连接可参考这篇文章
51采集PCF8591数据通过ESP8266上传C#上位机
如果上面的代码有问题,,提示已经监听了端口不能重复监听,可以修改为下面的
ConnectCnt =
ConnectListenFlage=
UsartUsFlage =
connect0Flage=
connect1Flage=
connect2Flage=
connect3Flage=
connect4Flage=
tmr.alarm(, , , function()
if ConnectListenFlage == then
ConnectListenFlage = srv:listen(,function(conn0)
UsartUsFlage = if ConnectCnt == then
connect0 = conn0
connect0Flage =
connect1Flage=
if connect1 ~= nil then
connect1:close()
end
print("0-Connectd")
end
if ConnectCnt == then
connect1 = conn0
connect1Flage=
connect2Flage=
if connect2 ~= nil then
connect2:close()
end
print("1-Connectd")
end
if ConnectCnt == then
connect2 = conn0
connect2Flage=
connect3Flage=
if connect3 ~= nil then
connect3:close()
end
print("2-Connectd")
end
if ConnectCnt == then
connect3 = conn0
connect3Flage=
connect4Flage=
if connect4 ~= nil then
connect4:close()
end
print("3-Connectd")
end
if ConnectCnt == then
connect4 = conn0
connect4Flage=
connect0Flage=
if connect0 ~= nil then
connect0:close()
end
print("4-Connectd")
end conn0:on("receive",function(conn0,payload)
print(payload) end)
ConnectCnt = ConnectCnt+
if ConnectCnt == then
ConnectCnt =
end end)
end
end)
uart.setup(0,9600,8,0,1,0) tmr.alarm(, , , function()
if UsartUsFlage == then
uart.on("data",
function(data)
if connect0 ~= nil then
if connect0Flage == then
connect0:send(data)
end
end if connect1 ~= nil then
if connect1Flage == then
connect1:send(data)
end end if connect2 ~= nil then
if connect2Flage == then
connect2:send(data)
end end if connect3 ~= nil then
if connect3Flage == then
connect3:send(data)
end end if connect4 ~= nil then
if connect4Flage == then
connect4:send(data)
end end tmr.stop()
end, )
end
end)
这两天测试程序还发现一个bug就是如果客户端断开了,应该检测一下哪个断开了,数据就不应该发向那个连接,,,否则就会报错,然后模块会复位重启
所以加上这段代码
conn0:on("disconnection",function(sck,c)
--print(sck)
if sck == connect0 then
connect0 = nil
print("disconnect0")
end
if sck == connect1 then
connect1 = nil
print("disconnect1")
end
if sck == connect2 then
connect2 = nil
print("disconnect2")
end
if sck == connect3 then
connect3 = nil
print("disconnect3")
end
if sck == connect4 then
connect4 = nil
print("disconnect4")
end
end)
放一个全的
ConnectCnt = 0//连接计数
ConnectListenFlage=0//监听标志,只执行一次监听
UsartUsFlage = 0//允许串口数据发向网口 tmr.alarm(2, 1000, 1, function()
if NetMode == 0 then//TCP Sever模式
if ConnectListenFlage == 0 then
ConnectListenFlage = 1
srv:listen(ConnectPort,function(conn0)
UsartUsFlage = 1
--print(conn0)
if ConnectCnt == 0 then
connect0 = conn0
if connect1 ~= nil then
connect1:close()
end
connect1 = nil print("0-Connectd")
end
if ConnectCnt == 1 then
connect1 = conn0 if connect2 ~= nil then
connect2:close()
end
connect2 = nil print("1-Connectd")
end
if ConnectCnt == 2 then
connect2 = conn0 if connect3 ~= nil then
connect3:close()
end
connect3 = nil print("2-Connectd")
end
if ConnectCnt == 3 then
connect3 = conn0 if connect4 ~= nil then
connect4:close()
end
connect4 = nil print("3-Connectd")
end
if ConnectCnt == 4 then
connect4 = conn0
if connect0 ~= nil then
connect0:close()
end
connect0 = nil print("4-Connectd")
end
conn0:on("disconnection",function(sck,c) //断开连接函数
--print(sck)
if sck == connect0 then
connect0 = nil
print("disconnect0")
end
if sck == connect1 then
connect1 = nil
print("disconnect1")
end
if sck == connect2 then
connect2 = nil
print("disconnect2")
end
if sck == connect3 then
connect3 = nil
print("disconnect3")
end
if sck == connect4 then
connect4 = nil
print("disconnect4")
end end) conn0:on("receive",function(conn0,payload)
uart.write(0,payload)end)
--print(payload) end)
ConnectCnt = ConnectCnt+1
if ConnectCnt == 5 then
ConnectCnt = 0
end end)
end
end
串口函数里面
if UsartUsFlage == 1 then
if NetMode == 0 then
if connect0 ~= nil then
connect0:send(RevData)
end if connect1 ~= nil then
connect1:send(RevData)
end if connect2 ~= nil then
connect2:send(RevData)
end if connect3 ~= nil then
connect3:send(RevData)
end if connect4 ~= nil then
connect4:send(RevData)
end
end
现在一步步的做
首先亲们一定是把Esp8266刷了基于Lua脚本语言开发的固件
可以参考这篇文章ESP8266刷AT固件与nodemcu固件

我也重新刷一下

我现在使用的这一款,,这上面有一个灯,这款是人家做的开发板,所以集成了USB转串口,,
首先是做一个程序让灯闪,这样做就只是做指示灯,正好看一下它的一些API函数

复位一下模块


关于这句要说一下,,,,这个模块默认上电执行的是 init.Lua中的程序,因为刚刷新完固件所以模块里面没有任何文件,,
我们编写一个程序把它保存为一个后缀名为.lua的文件,,这些文件呢,点击

文件就保存到ESP8266内部了,我上面写了两个文件一个名为init.lua(必须的,一上电模块就执行的文件),另一个conncet_wifi.lua
要想使用这个文件只需要

先写init.lua




可以给模块重新上电试一下,或者复位,模块总是执行这个程序



我为了方便用电脑上位机测试,所以就让模块工作在AP+STATION模式下,让模块连接我的360wifi

先设置模块的模式,然后是连接我的无线




为了保证模块一上电就执行


接着就是建立服务器




对了具体的关于 ::::::号有没有疑问,其实自己现在也有,不过自己看到了Lua讲解::::号的地方,先知道这样用,,,,,自己看懂了再在关于lua入门里面写一下
网口已经能接收到数据然后发送到串口了

现在要做的是往模块串口发数据然后传给网口





完成后可以给模块重新上电,或者复位一下,因为模块这样写进去可能不是从init.lua开始执行的

用别的串口调试助手连接上模块,因为这个软件的串口是发的命令

好了,,,,
补充
上面的AP加STATION模式下模块是发出WIFI信号的,而且设置了模块监听的端口是8080,所以可以完全连接模块发出的无线网,然后和模块进行通信,
只不过模块IP地址填写的是模块默认的ip 192.168.4.1 端口号 8080
连接模块的无线


对了串口每隔500ms会打印Connecting...
是由于Lua程序中写的模块是如果没有连接到路由器就会打印

如果不想要可以去掉
最后呢!提供一下自己做的板子
ESP8266使用详解--基于Lua脚本语言的更多相关文章
- 八,ESP8266 文件保存数据(基于Lua脚本语言)
https://www.cnblogs.com/yangfengwu/p/7533845.html 应该是LUA介绍8266的最后一篇,,,,,,下回是直接用SDK,,然后再列个12345...... ...
- ESP8266使用详解(AT,LUA,SDK)
https://www.cnblogs.com/yangfengwu/p/10100152.html 8266综合开发教程(LUA) https://www.cnblogs.c ...
- 一,ESP8266下载和刷固件(基于Lua脚本语言)
用自己的小板测试...... 安排上呢 一, ESP8266下载和刷固件(Lua开发----体验一下lua开发的魅力所在) 二, 控制一个灯亮灭 三, TCP服务器 四, TCP客户端 五, UDP ...
- 五,ESP8266 TCP服务器多连接(基于Lua脚本语言)
https://www.cnblogs.com/yangfengwu/p/7524326.html 一些时间去准备朋友的元器件了... 接着写,,争取今天写完所有的文章,,因为答应了朋友下周5之前要做 ...
- 二,ESP8266 GPIO和SPI和定时器和串口(基于Lua脚本语言)
https://www.cnblogs.com/yangfengwu/p/7514336.html 我们写lua用这个软件 如果点击的时候提示安装,,安装就行,,如果没有提示呢可以,按照下面链接的提示 ...
- 六,ESP8266 TCP Client(基于Lua脚本语言)
今天不知道是不是让我姐挺失望.......很多时候都不知道自己努力的方向对不对,,以后能不能带给家人最美好的期盼...... Init.lua 没啥改变,,就改了一下加载Client.lua gpio ...
- 四,ESP8266 TCP服务器(基于Lua脚本语言)
我要赶时间赶紧写完所有的内容....朋友的东西答应的还没做完呢!!!!!!!没想到又来了新的事情,,....... 配置模块作为TCP服务器然后呢咱们连接服务器发指令控制LED亮灭 控制的指令呢咱就配 ...
- 三,ESP8266 SPI(基于Lua脚本语言)
https://www.cnblogs.com/yangfengwu/p/7520260.html 重点是说SPI通信协议,,,, 不要害怕协议因为协议是人规定的,,刚好我也是人......规定的协议 ...
- 九,ESP8266 判断是断电上电(强制硬件复位)之后运行的内部程序还是内部软件复位之后运行的程序(基于Lua脚本语言)
现在我有一个需求,WIFI模块控制一个继电器,我要做的是如果内部程序跑乱了,造成了内部程序复位重启,那么控制继电器的状态不能改变 如果是设备断电了,然后又来电了,我需要的是继电器一定要是断开才好.不能 ...
随机推荐
- memcache数据组织
转自:原链接 使用命令 set(key, value) 向 memcached 插入一条数据, memcached 内部是如何组织数据呢 一 把数据组装成 item memcached 接受到客户端的 ...
- jQuery插件的开发
jQuery插件的开发包括两种: 一种是类级别的插件开发,即给jQuery添加新的全局函数,相当于给jQuery类本身添加方法.jQuery的全局函数就是属于jQuery命名空间的函数,另一种是对象级 ...
- 分布式事务 & 两阶段提交 & 三阶段提交
可以参考这篇文章: http://blog.csdn.net/whycold/article/details/47702133 两阶段提交保证了分布式事务的原子性,这些子事务要么都做,要么都不做. 而 ...
- sql语句:if exists语句使用
') begin print('exists ') end else begin print('no exists ') end go
- MySQL-教学系统数据库设计
根据大学教学系统的原型,我构建出如下ER关系图,来学习搭建数据库: 上面共有五个实体,分别是学生,教师,课程,院系,行政班级: 1.其中学生和课程的关系是多对多,即一个学生可以选择多门课程,而一个课程 ...
- Android px、dp和sp单位区别
[转]http://www.cnblogs.com/bjzhanghao/archive/2012/11/06/2757300.html 在调整布局的时候,某些控件的大小需要设置单位: px: 即像素 ...
- 隐马尔可夫模型(HMM)原理
本文主要讨论隐马尔科夫模型的三大要素,三大假设和三大问题. 1.引入 隐马尔可夫模型是一个关于时序的概率模型,它描述了一个由隐藏的马尔可夫链生成状态序列,再由状态序列生成观测序列的过程.其中,状态之间 ...
- iOS 之 时间格式与字符串转换
这个知识点涉及到三个类:NSDate.NSString,另外是一个最重要的类NSDateFormatter.它起到格式转换的作用,至于方法查看头文件就好了.时间格式注意下:yyyyMMddHHmmss
- 为什么32位操作系统最大支持4GB内存
因为32位操作系统的地址空间为32位,地址总数为2^32,每个地址对应1Byte内存空间,这样,32位操作系统管理的最大内存空间限制为2^32Byte=4*1024*1024*1024Byte,即4G ...
- PHP新手之学习类与对象(4)
五.范围解析操作符(::) 范围解析操作符(也可称作 Paamayim Nekudotayim)或者更简单地说是一对冒号,可以用于访问静态成员.方法和常量,还可以用于覆盖类中的成员和方法. 当在类的外 ...