main.lua 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  1. -- LuaTools需要PROJECT和VERSION这两个信息
  2. PROJECT = "sntpdemo"
  3. VERSION = "1.0.0"
  4. --[[
  5. 本demo需要mqtt库, 大部分能联网的设备都具有这个库
  6. mqtt也是内置库, 无需require
  7. ]]
  8. -- sys库是标配
  9. _G.sys = require("sys")
  10. --[[特别注意, 使用mqtt库需要下列语句]]
  11. _G.sysplus = require("sysplus")
  12. -- 统一联网函数
  13. sys.taskInit(function()
  14. local device_id = mcu.unique_id():toHex()
  15. -----------------------------
  16. -- 统一联网函数, 可自行删减
  17. ----------------------------
  18. if wlan and wlan.connect then
  19. -- wifi 联网, ESP32系列均支持
  20. local ssid = "luatos1234"
  21. local password = "12341234"
  22. log.info("wifi", ssid, password)
  23. -- TODO 改成自动配网
  24. -- LED = gpio.setup(12, 0, gpio.PULLUP)
  25. wlan.init()
  26. wlan.setMode(wlan.STATION) -- 默认也是这个模式,不调用也可以
  27. device_id = wlan.getMac()
  28. wlan.connect(ssid, password, 1)
  29. elseif mobile then
  30. -- Air8000/Air600E系列
  31. --mobile.simid(2) -- 自动切换SIM卡
  32. -- LED = gpio.setup(27, 0, gpio.PULLUP)
  33. device_id = mobile.imei()
  34. elseif w5500 then
  35. -- w5500 以太网, 当前仅Air105支持
  36. w5500.init(spi.HSPI_0, 24000000, pin.PC14, pin.PC01, pin.PC00)
  37. w5500.config() --默认是DHCP模式
  38. w5500.bind(socket.ETH0)
  39. -- LED = gpio.setup(62, 0, gpio.PULLUP)
  40. elseif socket then
  41. -- 适配的socket库也OK
  42. -- 没有其他操作, 单纯给个注释说明
  43. else
  44. -- 其他不认识的bsp, 循环提示一下吧
  45. while 1 do
  46. sys.wait(1000)
  47. log.info("bsp", "本bsp可能未适配网络层, 请查证")
  48. end
  49. end
  50. -- 默认都等到联网成功
  51. sys.waitUntil("IP_READY")
  52. sys.publish("net_ready", device_id)
  53. end)
  54. sys.taskInit(function()
  55. -- 等待联网
  56. local ret, device_id = sys.waitUntil("net_ready")
  57. sys.wait(1000)
  58. -- 对于Cat.1模块, 移动/电信卡, 通常会下发基站时间, 那么sntp就不是必要的, 而联通卡通常不会下发, 就需要sntp了
  59. -- 对应ESP32系列模块, 固件默认也会执行sntp, 所以手动调用sntp也是可选的
  60. -- sntp内置了几个常用的ntp服务器, 也支持自选服务器
  61. while 1 do
  62. -- 使用内置的ntp服务器地址, 包括阿里ntp
  63. log.info("开始执行SNTP")
  64. socket.sntp()
  65. -- 自定义ntp地址
  66. -- socket.sntp("ntp.aliyun.com")
  67. -- socket.sntp({"baidu.com", "abc.com", "ntp.air32.cn"})
  68. -- 通常只需要几百毫秒就能成功
  69. local ret = sys.waitUntil("NTP_UPDATE", 5000)
  70. if ret then
  71. -- 以下是获取/打印时间的演示,注意时区问题
  72. log.info("sntp", "时间同步成功", "本地时间", os.date())
  73. log.info("sntp", "时间同步成功", "UTC时间", os.date("!%c"))
  74. log.info("sntp", "时间同步成功", "RTC时钟(UTC时间)", json.encode(rtc.get()))
  75. -- os.time(rtc.get()) 需要 2023.07.21 之后的版本, 因为月份的命名差异mon/month
  76. -- log.info("sntp", "时间同步成功", "utc时间戳", os.time(rtc.get()))
  77. log.info("sntp", "时间同步成功", "本地时间戳", os.time())
  78. local t = os.date("*t")
  79. log.info("sntp", "时间同步成功", "本地时间os.date() json格式", json.encode(t))
  80. log.info("sntp", "时间同步成功", "本地时间os.date(os.time())", os.time(t))
  81. -- log.info("sntp", "时间同步成功", "本地时间", os.time())
  82. -- 正常使用, 一小时一次, 已经足够了, 甚至1天一次也可以
  83. -- sys.wait(3600000)
  84. -- 这里为了演示, 用5秒一次
  85. sys.wait(5000)
  86. else
  87. log.info("sntp", "时间同步失败")
  88. sys.wait(60000) -- 1分钟后重试
  89. end
  90. -- 时间戳, 精确到毫秒. 2023.11.15 新增
  91. -- 注意, 至少成功完成2次sntp,该时间戳才比较准确
  92. -- 如果仅完成了一次sntp, 时间戳比标准时间会慢一个网络延时的时长(10~500ms)不等
  93. if socket.ntptm then
  94. local tm = socket.ntptm()
  95. log.info("tm数据", json.encode(tm))
  96. log.info("时间戳", string.format("%u.%03d", tm.tsec, tm.tms))
  97. sys.wait(5000)
  98. end
  99. end
  100. end)
  101. sys.subscribe("NTP_ERROR", function()
  102. log.info("socket", "sntp error")
  103. -- socket.sntp()
  104. end)
  105. -- 用户代码已结束---------------------------------------------
  106. -- 结尾总是这一句
  107. sys.run()
  108. -- sys.run()之后后面不要加任何语句!!!!!