读取几个字符串后TCP连接崩溃

时间:2016-11-14 05:28:37

标签: sockets tcp lua esp8266 nodemcu

我正在使用ESP8266 wifi模块使用NodeMCU在LUA中对其进行编程。我能够从iPhone应用程序连接到由wifi模块创建的TCP服务器,以发送3个浮动。我将大字符串解析为3个字符串并使用uart和Arduino发送它们。它工作得很好,但在大约10个输入后它崩溃/冻结。我需要不断的数据流来保持一致但我始终无法可靠地做到这一点。 我在每一行之后打印出来,以便跟踪实际发生的情况,甚至在此之后我还不确定发生了什么。

代码    `

print("11\n")
wifi.setmode(wifi.STATION)
print("22\n")
wifi.sta.config("WDTS03","Walker14!")
print("33\n")
elWiFi =(wifi.sta.getip())
if elWiFi ~= nil then
    print(wifi.sta.getip())
end
print("44\n")
if srv~=nil then
    print("444\n")
    srv:close()
    print("555 \n")
end

print("Create server \n")
srv=net.createServer(net.TCP) 
print("1\n")
if srv ~= nil then
    print("srv !=nil \n")
    srv:listen(6969,function(conn) 
    print("listening \n")
        if conn ~= nil then
        print("incoming\n")

        conn:on("receive",function(conn,numbers) 
        print("2\n")
        print(#numbers)
        print("chekcing for nil \n")
        if numbers ~= nil then 
            print("3\n")
            p = string.find(numbers, "x=")
            print("4\n")
            q = string.find(numbers, "&y")
            print("5\n")
            if p ~= nill then
                print("6\n")
                if q ~=  nil then
                    print("7\n")
                    x = (string.sub(numbers,p+2, q-1))
                    print("x=" .. x)
                end
            end --p ~= nill
            print("8\n")
            p = string.find(numbers, "y=")
            print("9\n")
            q = string.find(numbers, "&z")
            print("10\n")
            if p ~= nill then
                print("11\n")
                if q ~=  nil then
                 print("12\n")
                    y = (string.sub(numbers,p+2, q-1))
                    print("y=" .. y)
                end
            end --p ~= nill
            print("13\n")
            p = string.find(numbers, "z=")
            print("14\n")
            q = string.find(numbers, " H")
            print("15\n")
            if p ~= nill then
                print("16\n")
                if q ~=  nil then
                    print("17\n")
                    z = (string.sub(numbers,p+2, q-1))
                    print("z=" .. z)
                end
            end-- p ~= nill
            print("18\n")

        end --numbers ~= nil
        print("54\n")

        --conn:send("test\n")

        end)
        print("55 \n")
        end
        print("66 \n")
    end)
    print("77\n")

end
print("666\n")`

我得到以下输出

11

22

33

44

Create server 

1

srv !=nil 

77

666

> listening 

incoming

55 

66 

listening 

incoming

55 

66 

listening 

incoming

55 

66 

listening 

incoming

55 

66 

2

338
chekcing for nil 

3

4

5

6

7

x=0.1722259521484375
8

9

10

11

12

y=-0.7733306884765625
13

14

15

16

17

z=-0.5716094970703125
18

54

2

337
chekcing for nil 

3

4

5

6

7

.
.--repeats a few times 
.

y=-0.005340576171875
13

14

15

16

17

z=-0.9838409423828125
18

54

PANIC: unprotected error in call to Lua API (attempt to call a nil value)
�l� �=+���T2n���

NodeMCU 0.9.6 build 20150704  powered by Lua 5.1.4
11

22`

它失败了" conn:on" " srv:listen"几次之后

感谢您的帮助,对不起,如果格式混乱了。第一次

1 个答案:

答案 0 :(得分:1)

评论太长了,抱歉。

  

PANIC:调用Lua API时出现无保护错误(尝试调用nil值)

很难分辨哪个值为零/ null。创建FHS以减少需要分析的代码量。

以下代码段最终会因关闭的上升值而导致内存不足。每个回调函数都应使用自己传递的套接字实例的副本,而不是引用包装回调函数。第三行不应重用conn变量,而应使用新名称定义一个变量。 有关详细信息,请参阅Minimal, Complete, and Verifiable Example (MCVE)

srv:listen(6969,function(conn)
  if conn ~= nil then
    conn:on("receive",function(conn,numbers)
  

NodeMCU 0.9.6 build 20150704

不要使用那些旧的0.9.x二进制文件,它们已经过时并且包含许多错误。 https://stackoverflow.com/a/37379426/131929可帮助您开始使用新固件。