为什么使用这个代码启动后,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("%-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

为什么每次重启后会崩溃?

我该如何排除这个问题?

我使用的是基于 Lua 5.1.4 的 NodeMCU 0.9.5 20150318 版本。

其他的 Lua 脚本正常运行。

点赞
用户1252334
用户1252334

我在client:on("receive",function(client,request)中有同样的函数。 这不应该在这里。

2015-12-19 23:59:22
用户1241224
用户1241224
  1. 我没有看到调用 wifi.sta.connect() 的指令。
  2. 字符串是不可变的,所以每次重新赋值 buf 时,都会创建一个新字符串。如果你的空间不够就会被垃圾回收器清理掉。
  3. 你不能连续调用 client:send() 和 client:close()... 好吧,你可以这么做,但是可能不会很好用。我还担心一次发送这么多数据会有问题。
  4. 即使它们不接受回调函数,wifi 配置和连接例程也需要异步运行,可以使用定时器调用它们,然后在继续之前检查状态。

第一项是一个致命问题,其他项可能会导致彻底失败,也可能是间歇性的。

2016-04-29 00:29:35