>我有以下代码
conn = net.createConnection(net.TCP, 0)
conn:on("sent", function(sck,c)
print("Sent")
sck:close()
end)
conn:on("connection", function(sck,c)
print("Connected..")
sck:send("test")
end)
conn:connect(9090, "192.168.1.89")
print("Send data.")
当在 ESPlorer 中作为片段运行时,这工作正常,IE 运行实时解释器。我看到输出"已连接.."和"已发送",并且消息出现在服务器上。当它是init.lua或我的mcu-temp的一部分时.lua我什至看不到"已连接.."消息。
与 WIFI 的连接正常,并且板在尝试"实时"和从文件之间重置。我真的很想知道为什么它以一种方式工作正常而不是另一种方式。
无线网络连接还可以
我严重怀疑这一点。如果您从 ESPlorer 运行,那么是的,但当您重新启动设备时不会。
连接到 AP 通常需要几秒钟。您需要等到它连接,直到您可以继续启动序列。请记住:使用 NodeMCU 时,大多数操作都是异步和事件驱动的,wifi.sta.connect()
不会阻塞。
这是我从 https://cknodemcu.wordpress.com/借来并改编的启动序列。
SSID = <tbd>
PASSWORD = <tbd>
function startup()
local conn = net.createConnection(net.TCP, 0)
conn:on("sent", function(sck, c)
print("Sent")
sck:close()
end)
conn:on("connection", function(sck, c)
print("Connected..")
sck:send("test")
end)
conn:connect(9090, "192.168.1.89")
print("Sent data.")
end
print("setting up WiFi")
wifi.setmode(wifi.STATION)
wifi.sta.config(SSID,PASSWORD)
wifi.sta.connect()
tmr.alarm(1, 1000, 1, function()
if wifi.sta.getip() == nil then
print("IP unavaiable, Waiting...")
else
tmr.stop(1)
print("Config done, IP is "..wifi.sta.getip())
print("You have 5 seconds to abort startup")
print("Waiting...")
tmr.alarm(0, 5000, 0, startup)
end
end)
就在两天前,我在SO上回答了几乎相同的问题。有关替代解决方案,请参阅 https://stackoverflow.com/a/37495955/131929。