Lua 为什么NodeMCU在使用此代码引导后会无错误地崩溃?

Lua 为什么NodeMCU在使用此代码引导后会无错误地崩溃?,lua,esp8266,nodemcu,Lua,Esp8266,Nodemcu,我的ESP8266不断重新启动 这是我的init.lua: cfg={} cfg.ssid="Sensor" cfg.auth=AUTH_OPEN wifi.ap.config(cfg) wifi.setmode(wifi.STATION) wifi.sta.getap(function(t) available_aps = "" if t then for k,v in pairs(t) do ap = string.format(

我的ESP8266不断重新启动

这是我的init.lua:

cfg={}
cfg.ssid="Sensor"
cfg.auth=AUTH_OPEN
wifi.ap.config(cfg)
wifi.setmode(wifi.STATION)
wifi.sta.getap(function(t)
    available_aps = "" 
    if t then 
        for k,v in pairs(t) do 
            ap = string.format("%-10s",k) 
            ap = trim(ap)
            available_aps = available_aps .. "<option value='".. ap .."'>".. ap .."</option>"
        end 
        setup_server(available_aps)
    end
end)

function setup_server(aps)
    wifi.setmode(wifi.SOFTAP)
    srv=net.createServer(net.TCP)
    srv:listen(80,function(client) 
        client:on("receive",function(client,request)
            wifi.sta.getap(function(t)
                available_aps = "" 
                if t then 
                    for k,v in pairs(t) do 
                        ap = string.format("%-10s",k) 
                        ap = trim(ap)
                        available_aps = available_aps .. "<option value='".. ap .."'>".. ap .."</option>"
                    end 
                end
            end)
            local buf = "";
            local _, _, method, path, vars = string.find(request, "([A-Z]+) (.+)?(.+) HTTP");
            if(method == nil)then
                _, _, method, path = string.find(request, "([A-Z]+) (.+) HTTP");
            end
            local _GET = {}
            if (vars ~= nil)then
                for k, v in string.gmatch(vars, "(%w+)=(%w+)&*") do
                    _GET[k] = v
                end
            end
            buf = "<html><body>"
            buf = buf .. "<h3>Config</h3><br>"
            buf = buf .. "<form method='get' action='http://" .. wifi.ap.getip() .."'>"
            buf = buf .. "Select access point: <select name='ap'>" .. available_aps .. "</select><br>"
            buf = buf .. "Enter wifi password: <input type='password' name='psw'></input><br>"
            buf = buf .. "Server-IP: <input name='ipTCP' value='192.168.178.1'></input><br>"
            buf = buf .. "<br><button type='submit'>Save</button>"
            buf = buf .. "</form></body></html>"
            local _on,_off = "",""
            if(_GET.pin == "ON1")then
                  buf = buf.."NICE";
            elseif(_GET.pin == "OFF1")then
                  gpio.write(led1, gpio.LOW);
            elseif(_GET.pin == "ON2")then
                  gpio.write(led2, gpio.HIGH);
            elseif(_GET.pin == "OFF2")then
                  gpio.write(led2, gpio.LOW);
            end
            client:send(buf);
            client:close();
            collectgarbage();
        end) 
    end)
end
cfg={}
cfg.ssid=“传感器”
cfg.auth=auth\u打开
wifi.ap.config(cfg)
wifi.setmode(wifi.STATION)
wifi.sta.getap(功能(t)
可用_aps=“”
如果不是,那么
对于k,v成对(t)do
ap=字符串.格式(“%-10s”,k)
ap=配平(ap)
可用的接入点=可用的接入点“…接入点”
结束
设置\u服务器(可用\u AP)
结束
(完)
功能设置\u服务器(aps)
wifi.setmode(wifi.SOFTAP)
srv=net.createServer(net.TCP)
srv:监听(80,功能(客户端)
客户机:开启(“接收”,功能(客户机,请求)
wifi.sta.getap(功能(t)
可用_aps=“”
如果不是,那么
对于k,v成对(t)do
ap=字符串.格式(“%-10s”,k)
ap=配平(ap)
可用的接入点=可用的接入点“…接入点”
结束
结束
(完)
本地buf=“”;
local u,u,method,path,vars=string.find(请求,“([A-Z]+)(.+)?(.+)HTTP”);
如果(方法==nil),则
_,方法,路径=string.find(请求,([A-Z]+)(.+)HTTP”);
结束
本地_GET={}
如果(vars~=nil),则
对于string.gmatch(vars,(%w+)=(%w+&*)do中的k,v
_获取[k]=v
结束
结束
buf=“”
buf=buf.“配置
” buf=buf.“” buf=buf.“选择接入点:……可用的接入点”
“ buf=buf.“输入wifi密码:
” buf=buf.“服务器IP:
” buf=buf.“
保存” buf=buf.“” 本地_on,_off=“”,“” 如果(_GET.pin==“ON1”),则 buf=buf.“不错”; elseif(_GET.pin==“OFF1”)则 gpio.write(led1,gpio.LOW); elseif(_GET.pin==“ON2”)则 gpio.write(led2,gpio.HIGH); elseif(_GET.pin==“OFF2”)则 gpio.write(led2,gpio.LOW); 结束 客户:发送(buf); 客户端:close(); 收集垃圾(); (完) (完) 结束
为什么每次重启后都会崩溃

如何对此进行故障排除

我有NodeMCU 0.9.5版本20150318,由Lua 5.1.4提供动力


另一个lua脚本正在正常运行。

我在客户端中有相同的功能:on(“接收”,功能(客户端,请求)。
它不应该在这里。

我在客户机中有相同的功能:on(“接收”,功能(客户机,请求)。 它不应该在这里

  • 我没有看到对wifi.sta.connect()的呼叫
  • 字符串是不可变的,因此每次重新分配buf时,您都会创建一个新的。是的,如果您没有首先用完,GC会将其清除
  • 你不能背对背地调用client:send()和client:close(),当然可以,但它不会很好地工作。我还担心在一次调用中发送所有这些
  • 即使它们不接受回调,wifi配置和连接例程也需要异步运行,使用计时器调用它们,然后在继续之前检查状态
  • 第一个项目是一个显示止动器,其他项目可能会导致彻底故障或间歇性故障

  • 我没有看到wifi.sta.connect()的呼叫
  • 字符串是不可变的,因此每次重新分配buf时,您都会创建一个新的。是的,如果您没有首先用完,GC会将其清除
  • 你不能背对背地调用client:send()和client:close(),当然可以,但它不会很好地工作。我还担心在一次调用中发送所有这些
  • 即使它们不接受回调,wifi配置和连接例程也需要异步运行,使用计时器调用它们,然后在继续之前检查状态

  • 第一项是一个显示停止项,其他项可能会导致彻底失败或间歇性故障。

    NodeMCU 0.9.5确实很旧,请尝试使用最近的固件版本。如果没有进一步的提示,您不能期望我们立即在长代码示例中发现错误。我确信当它崩溃时您会收到一些错误消息?尝试消除错误一步一步地编写代码,直到找到导致错误的几行。问题已经解决,但感谢您指出我有旧版本的nodemcu。不要使用0.95。不要在
    on('receive')
    中执行
    client:close()
    。它需要进入
    on('sent'))
    cb.NodeMCU 0.9.5真的很旧,请尝试使用最新的固件版本。如果没有进一步的提示,您不能期望我们立即在这么长的代码示例中发现错误。我确信当它崩溃时,您会收到一些错误消息?请尝试逐步消除代码,直到减少到导致错误的几行代码。问题是b即使解决了,但感谢您指出我有旧版本的nodemcu。不要使用0.95。不要在('receive')上执行
    中的
    客户端:close()
    。它需要在('sent')
    上执行