服务器的加密通讯详细操作方法解析

北冰洋以北  金牌会员 | 2024-12-6 11:49:41 | 来自手机 | 显示全部楼层 | 阅读模式
打印 上一主题 下一主题

主题 904|帖子 904|积分 2712

一、编写脚本

1.1 准备资料

Air780E开发板
LuatOS-Air780E/网络加密通讯程序源码demo
合宙的 TCP/UDP 测试服务器
API先容说明
1.2 程序解释

1.2.1 配置联网配置
-- 测试网站 https://netlab.luatos.com/ 点击 打开TCP 获取测试端口号
-- 要按实际环境修改
local host = "112.125.89.8" -- 服务器ip大概域名, 都可以的
local port = 45186 -- 服务器端口号
local is_udp = false -- 假如是UDP, 要改成true, false就是TCP
local is_tls = true -- 加密与否, 要看服务器的实际环境
--=============================================================
1.2.2 联网创建联网成功后,对收发数据变乱的处置惩罚函数
local function sockettest()
-- 等候联网
sys.waitUntil("IP_READY")
-- 时间同步
socket.sntp()
-- 开始正在的逻辑, 发起socket链接,等候数据/上报心跳
local taskName = "sc"
local topic = taskName .. "_txrx"
log.info("topic", topic)
local txqueue = {}
--[[创建一个任务线程
@param1 function 任务函数名,用于resume唤醒时调用
@param2 string 任务名称,用于唤醒任务id
@param3 function 接收到非目标消息时的回调函数
@param4 any 任务函数fun的可变参数
@return number 返回该任务的线程号
]]
sysplus.taskInitEx(sockettask, taskName, netCB, taskName, txqueue, topic)
while 1 do
  1. local result, tp, data = sys.waitUntil(topic, 30000)
  2.    log.info("event", result, tp, data)
  3.    if not result then
  4.        -- 等很久了,没数据上传/下发, 发个日期心跳包吧
  5.        table.insert(txqueue, os.date())
  6.        sys_send(taskName, socket.EVENT, 0)
  7.    elseif tp == "uplink" then
  8.        -- 上行数据, 主动上报的数据,那就发送呀
  9.        table.insert(txqueue, data)
  10.        sys_send(taskName, socket.EVENT, 0)
  11.    elseif tp == "downlink" then
  12.        -- 下行数据,接收的数据, 从ipv6task来的
  13.        -- 其他代码可以通过 sys.publish()
  14.        log.info("socket", "收到下发的数据了", #data,"data:",data)
  15.    end
复制代码
end
end
1.2.3 联网函数
function sockettask(d1Name, txqueue, rxtopic)
-- 打印准备毗连的服务器信息
log.info("socket", host, port, is_udp and "UDP" or "TCP", is_tls and "TLS" or "RAW")
-- 准备好所需要的接收缓冲区
local rx_buff = zbuff.create(1024)
local netc = socket.create(nil, d1Name)
socket.config(netc, nil, is_udp, is_tls)
log.info("任务id", d1Name)
while true do
  1. -- 连接服务器, 15秒超时
  2.    log.info("socket", "开始连接服务器")
  3.    sysplus.cleanMsg(d1Name)
  4.    local result = libnet.connect(d1Name, 15000, netc, host, port)
  5.    if result then
  6.        log.info("socket", "服务器连上了")
  7.        --向服务器发送数据
  8.        libnet.tx(d1Name, 0, netc, "helloworld")
  9.    else
  10.        log.info("socket", "服务器没连上了!!!")
  11.    end
  12.    while result do
  13.        -- 连接成功之后, 先尝试接收
  14.        -- log.info("socket", "调用rx接收数据")
  15.        local succ, param = socket.rx(netc, rx_buff)
  16.        if not succ then
  17.            log.info("服务器断开了", succ, param, ip, port)
  18.            break
  19.        end
  20.        -- 如果服务器有下发数据, used()就必然大于0, 进行处理
  21.        if rx_buff:used() > 0 then
  22.            log.info("socket", "收到服务器数据,长度", rx_buff:used())
  23.            local data = rx_buff:query() -- 获取数据
  24.            sys.publish(rxtopic, "downlink", data)
  25.            rx_buff:del()
  26.        end
  27.        -- log.info("libnet", "调用wait开始等待消息")
  28.        -- 等待事件, 例如: 服务器下发数据, 有数据准备上报, 服务器断开连接
  29.        result, param, param2 = libnet.wait(d1Name, 15000, netc)
  30.        log.info("libnet", "wait", result, param, param2)
  31.        if not result then
  32.            -- 网络异常了, 那就断开了, 执行清理工作
  33.            log.info("socket", "服务器断开了", result, param)
  34.            break
  35.        elseif #txqueue > 0 then
  36.            -- 有待上报的数据,处理之
  37.            while #txqueue > 0 do
  38.                local data = table.remove(txqueue, 1)
  39.                if not data then
  40.                    break
  41.                end
  42.                result,param = libnet.tx(d1Name, 15000, netc,data)
  43.                log.info("libnet", "发送数据的结果", result, param)
  44.                if not result then
  45.                    log.info("socket", "数据发送异常", result, param)
  46.                    break
  47.                end
  48.            end
  49.        end
  50.        -- 循环尾部, 继续下一轮循环
  51.    end
  52.    -- 能到这里, 要么服务器断开连接, 要么上报(tx)失败, 或者是主动退出
  53.    libnet.close(d1Name, 5000, netc)
  54.    -- log.info(rtos.meminfo("sys"))
  55.    sys.wait(30000) -- 这是重连时长, 自行调整
复制代码
end
end
二、烧录代码到硬件

2.1 毗连电脑、4G模组电路板

使用带有数据通讯功能的数据线,不要使用仅有充电功能的数据线;
2.2 识别4G模组的boot引脚

在下载之前,要用模组的boot引脚触发下载, 也就是说,要把4G模组的boot引脚拉到 1.8v,大概直接把boot引脚和VDD_EXT引脚相连。我们要在按下BOOT按键时让模块开机,就可以进入下载模式了。
(1)当模块没开机时,按着BOOT键然后长按PWR开机。
(2)当模块开机时,按着BOOT键然后点按重启键即可。



2.3 识别电脑正确端口

判断是否进入BOOT模式:模块上电,此时在电脑的设备管理器中,检察串口设备, 会出现一个端口表示进入了boot下载模式,如下图所示:



当设备管理器出现了3个一连数字的com端口,并且每个数字都大于4,这时候, 硬件毗连上停当状态,恭喜你,可以进行烧录了!
2.4 新建项目

起首,确保你的 LuaTools 的版本,上大于 2.2.13 版本的。
在 LuaTools 的左上角上有版本显示的,如图所示:


LuaTools 版本没标题标话, 就点击 LuaTOols 右上角的“项目管理测试”按钮,如下图所示:


这时会弹出项目管理和烧录管理的对话框,如下图:
新建一个项目
注意:这里截图使用的hello world项目标烧录教程,烧录的时候要将脚本换成本次demo的。



2.5 烧录

选择780E板子对应的底层core和刚改的main.lua脚本文件。下载到板子中。




点击下载后,我们需要进入boot模式才气正常下载,在(3)(4)末节已经先容了如何进入boot模式。


三、验证功能

3.1 打开TCPSSL,毗连测试工具。



3.2 配置端口、tcp毗连,是否加密。




3.3 成功毗连,发送数据



四、常见标题解答

4.1 可以与mqtt库同时使用吗?

支持。
4.2 最多同时支持多少个毗连?

socket支持多个毗连的, 通常最多支持8个。
加密毗连(TLS/SSL)需要更多内存, 这意味着能容纳的毗连数会小很多, 同时也更慢。
以上就是本日的全部内容,合宙低功耗4G模组Air780E快速入门之跟服务器之间的加密通讯,你学会了吗?

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

正序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

北冰洋以北

金牌会员
这个人很懒什么都没写!
快速回复 返回顶部 返回列表