mobile - 蜂窝网络#
示例
-- 简单演示
log.info("imei", mobile.imei())
log.info("imsi", mobile.imsi())
local sn = mobile.sn()
if sn then
log.info("sn", sn:toHex())
end
log.info("muid", mobile.muid())
log.info("iccid", mobile.iccid())
log.info("csq", mobile.csq())
log.info("rssi", mobile.rssi())
log.info("rsrq", mobile.rsrq())
log.info("rsrp", mobile.rsrp())
log.info("snr", mobile.snr())
log.info("simid", mobile.simid())
常量#
常量 |
类型 |
解释 |
---|---|---|
mobile.UNREGISTER |
number |
未注册 |
mobile.REGISTERED |
number |
已注册 |
mobile.SEARCH |
number |
正在搜索中 |
mobile.DENIED |
number |
注册被拒绝 |
mobile.UNKNOW |
number |
未知 |
mobile.REGISTERED_ROAMING |
number |
已注册,漫游 |
mobile.SMS_ONLY_REGISTERED |
number |
已注册,仅SMS |
mobile.SMS_ONLY_REGISTERED_ROAMING |
number |
已注册,漫游,仅SMS |
mobile.EMERGENCY_REGISTERED |
number |
已注册,紧急服务 |
mobile.CSFB_NOT_PREFERRED_REGISTERED |
number |
已注册,非主要服务 |
mobile.CSFB_NOT_PREFERRED_REGISTERED_ROAMING |
number |
已注册,非主要服务,漫游 |
mobile.CONF_RESELTOWEAKNCELL |
number |
小区重选信号差值门限,需要飞行模式设置 |
mobile.CONF_STATICCONFIG |
number |
网络静态模式优化,需要飞行模式设置 |
mobile.CONF_QUALITYFIRST |
number |
网络切换以信号质量优先,需要飞行模式设置,0不开,1开启,2开启并加速切换,功耗会增加 |
mobile.CONF_USERDRXCYCLE |
number |
LTE跳paging,需要飞行模式设置,谨慎使用,0是不设置,1~7增大或减小DrxCycle周期倍数,1:1/8倍 2:1/4倍 3:1/2倍 4:2倍 5:4倍 6:8倍 7:16倍,8~12配置固定的DrxCycle周期,仅当该周期大于网络分配的DrxCycle周期时该配置才会生效,8:320ms 9:640ms 10:1280ms 11:2560ms 12:5120ms |
mobile.CONF_T3324MAXVALUE |
number |
PSM模式中的T3324时间,单位S |
mobile.CONF_PSM_MODE |
number |
PSM模式开关,0关,1开 |
mobile.CONF_CE_MODE |
number |
attach模式,0为EPS ONLY 2为混合,遇到IMSI detach脱网问题,设置为0,注意设置为EPS ONLY时会取消短信功能 |
mobile.CONF_SIM_WC_MODE |
number |
SIM写入次数的配置和读取 |
mobile.CONF_FAKE_CELL_BARTIME |
number |
伪基站禁止接入的时间,取值为0时取消,0xffff永久 |
mobile.CONF_RESET_TO_FACTORY |
number |
删除已保存的协议栈参数,重启后会使用默认配置 |
mobile.CONF_USB_ETHERNET |
number |
蜂窝网络模块的usb以太网卡控制,bit0开关1,开0关,bit1模式1NAT,0独立IP(在usb以太网卡开启前可以修改,开启过就不行),bit2协议1ECM,0RNDIS,飞行模式里设置 |
mobile.CONF_DISABLE_NCELL_MEAS |
number |
关闭邻区测量 1关,0开,除了功耗测试外不建议使用 |
mobile.CONF_MAX_TX_POWER |
number |
设置最大发射功率,0~23,必须在每次RRC=1时调用,RRC=0后会自动清除配置 |
mobile.PIN_VERIFY |
number |
验证PIN码操作 |
mobile.PIN_CHANGE |
number |
更换PIN码操作 |
mobile.PIN_ENABLE |
number |
使能PIN码验证 |
mobile.PIN_DISABLE |
number |
关闭PIN码验证 |
mobile.PIN_UNBLOCK |
number |
解锁PIN码 |
mobile.imei(index)#
获取IMEI
参数
传入值类型 |
解释 |
---|---|
int |
编号,默认0. 在支持双卡的模块上才会出现0或1的情况 |
返回值
返回值类型 |
解释 |
---|---|
string |
当前的IMEI值,若失败返回nil |
例子
无
mobile.imsi(index)#
获取IMSI
参数
传入值类型 |
解释 |
---|---|
int |
编号,默认0. 在支持双卡的模块上才会出现0或1的情况 |
返回值
返回值类型 |
解释 |
---|---|
string |
当前的IMSI值,若失败返回nil |
例子
无
mobile.sn()#
获取SN
参数
无
返回值
返回值类型 |
解释 |
---|---|
string |
当前的SN值,若失败返回nil. 注意, SN可能包含不可见字符 |
例子
-- 注意, 出厂未必有写SN
-- 一般用途的唯一id, 可以用mobile.imei()代替
-- 如需要真正的唯一ID, 使用 mcu.unique_id()
mobile.muid()#
获取MUID
参数
无
返回值
返回值类型 |
解释 |
---|---|
string |
当前的MUID值,若失败返回nil |
例子
无
mobile.iccid(id)#
获取或设置ICCID
参数
传入值类型 |
解释 |
---|---|
int |
SIM卡的编号, 例如0, 1, 默认0 |
返回值
返回值类型 |
解释 |
---|---|
string |
ICCID值,若失败返回nil |
例子
无
mobile.number(id)#
获取手机卡号,注意,只有写入了手机号才能读出,因此有可能读出来是空的
参数
传入值类型 |
解释 |
---|---|
int |
SIM卡的编号, 例如0, 1, 默认0 |
返回值
返回值类型 |
解释 |
---|---|
string |
number值,若失败返回nil |
例子
无
mobile.simid(id)#
获取当前SIM卡槽,或者切换卡槽
参数
传入值类型 |
解释 |
---|---|
int |
SIM卡的编号, 例如0, 1, 如果支持双卡,比如EC618,可以填2来自适应,但是会占用掉4个IO(gpio4/5/6/23)。如果不填就直接读取当前卡槽 |
boolean |
是否优先用SIM0,只有SIM卡编号写2自适应才有用!!!。true优先用SIM0,false则由具体平台决定,支持双卡双待SIM0优先,不支持的是上一次检测到的优先,默认是false,必须在开机就配置,否则就无效了 |
返回值
返回值类型 |
解释 |
---|---|
int |
当前sim卡槽编号,若失败返回-1 |
例子
mobile.simid(0) -- 固定使用SIM0
mobile.simid(1) -- 固件使用SIM1
mobile.simid(2) -- 自动识别SIM0, SIM1, 优先级看具体平台
mobile.simid(2, true) -- -- 自动识别SIM0, SIM1, 且SIM0优先
-- 提醒, 自动识别是会增加时间的
mobile.simPin(id,operation,pin1,pin2)#
检测当前SIM卡是否准备好,对SIM卡的PIN码做相关操作
参数
传入值类型 |
解释 |
---|---|
int |
SIM卡的编号, 例如0, 1, 支持双卡双待的才需要选择 |
int |
PIN码操作类型,只能是mobile.PIN_XXXX,不操作就留空 |
string |
更换pin时操作的pin码,或者验证操作的pin码,或者解锁pin码时的PUK,4~8字节 |
string |
更换pin码操作时的新的pin码,解锁pin码时的新PIN,4~8字节 |
返回值
返回值类型 |
解释 |
---|---|
boolean |
当无PIN操作时,返回SIM卡是否准备好,有PIN操作时,返回是否成功 |
例子
local cpin_is_ready = mobile.simPin() -- 当前sim卡是否准备好,一般返回false就是没卡
local succ = mobile.simPin(0, mobile.PIN_VERIFY, "1234") -- 输入pin码验证
mobile.rtime(time, auto_reset_stack, data_first)#
设置RRC自动释放时间间隔,当开启时后,遇到极弱信号+频繁数据操作可能会引起网络严重故障,因此需要额外设置自动重启协议栈
参数
传入值类型 |
解释 |
---|---|
int |
RRC自动释放时间,等同于Air724的AT+RTIME,单位秒,写0或者不写则是停用,不要超过20秒,没有意义 |
boolean |
网络遇到严重故障时尝试自动恢复,和飞行模式/SIM卡切换冲突,true开启,false关闭,留空时,如果设置了时间则自动开启。本参数于2023年9月14日已废弃 |
boolean |
是否启用数据传输优化,true启用,false关闭,留空为false,开启后必须等到TCP数据ACK或者超时失败,或者socket CONNECT完成(无论成功或者失败)才允许RRC提前释放,可能会增加功耗。本参数于2024年8月12日启用 |
返回值
返回值类型 |
解释 |
---|---|
nil |
无返回值 |
例子
mobile.rtime(3) --与基站无数据交互3秒后提前释放RRC
mobile.rtime(3,nil,true) --启用数据传输优化,与基站无数据交互3秒后,提前释放RRC
mobile.setAuto(check_sim_period, get_cell_period, search_cell_time, auto_reset_stack, network_check_period)#
设置一些辅助周期性或者自动功能,目前支持SIM卡暂时脱离后恢复,周期性获取小区信息,网络遇到严重故障时尝试自动恢复
参数
传入值类型 |
解释 |
---|---|
int |
SIM卡自动恢复时间,单位毫秒,建议5000~10000,和飞行模式/SIM卡切换冲突,不能再同一时间使用,必须错开执行。写0或者不写则是关闭功能 |
int |
周期性获取小区信息的时间间隔,单位毫秒。获取小区信息会增加部分功耗。写0或者不写则是关闭功能 |
int |
每次搜索小区时最大搜索时间,单位秒。不要超过8秒 |
boolean |
网络遇到严重故障时尝试自动恢复,和飞行模式/SIM卡切换冲突,true开启,false关闭,开始状态是false,留空则不做改变 |
int |
设置定时检测网络是否正常并且在检测到长时间无网时通过重启协议栈来恢复,无网恢复时长,单位ms,建议60000以上,为网络搜索网络保留足够的时间,留空则不做更改 |
返回值
返回值类型 |
解释 |
---|---|
nil |
无返回值 |
例子
无
mobile.apn(index, cid, new_apn_name, user_name, password, ip_type, protocol)#
获取或设置APN,设置APN必须在入网前就设置好,比如在SIM卡识别完成前就设置好
参数
传入值类型 |
解释 |
---|---|
int |
编号,默认0. 在支持双卡的模块上才会出现0或1的情况 |
int |
cid, 默认0,如果要用非默认APN来激活,必须>0 |
string |
新的APN,不填就是获取APN, 填了就是设置APN, 是否支持设置取决于底层实现 |
string |
新的APN的username,如果APN不是空,那必须填写,如果没有留个空字符串””。如果APN是空的,那可以nil |
string |
新的APN的password,如果APN不是空,那必须填写,如果没有留个空字符串””。如果APN是空的,那可以nil |
int |
激活APN时的IP TYPE,1=IPV4 2=IPV6 3=IPV4V6,默认是1 |
int |
激活APN时,如果需要username和password,就要写鉴权协议类型,1~3,默认3,代表1和2都尝试一下。不需要鉴权的写0 |
boolean |
是否删除APN,true是,其他都否,只有参数3新的APN不是string的时候才有效果 |
返回值
返回值类型 |
解释 |
---|---|
string |
如果网络注册成功,返回注册用的APN值,反之是nil。设置好不会立刻有返回值,需要等网络注册成功 |
例子
mobile.apn(0,1,"cmiot","","",nil,0) -- 移动公网卡设置APN为cmiot,一般不用设置
mobile.apn(0,1,"name","user","password",nil,3) -- 专网卡设置的demo,name,user,password联系卡商获取
mobile.ipv6(onff)#
是否默认开启IPV6功能,必须在LTE网络连接前就设置好
参数
传入值类型 |
解释 |
---|---|
boolean |
开关 true开启 false 关闭 |
返回值
返回值类型 |
解释 |
---|---|
boolean |
true 当前是开启的,false 当前是关闭的 |
例子
-- 注意, 开启ipv6后, 开机联网会慢2~3秒
mobile.csq()#
获取csq
参数
无
返回值
返回值类型 |
解释 |
---|---|
int |
当前CSQ值, 若失败返回0. 范围 0 - 31, 越大越好 |
例子
-- 注意, 4G模块的CSQ值仅供参考, rsrp/rsrq才是真正的信号强度指标
mobile.rssi()#
获取rssi
参数
无
返回值
返回值类型 |
解释 |
---|---|
int |
当前rssi值,若失败返回0. 范围 0 到 -114, 越小越好 |
例子
无
mobile.rsrp()#
获取rsrp,参考信号接收功率
参数
无
返回值
返回值类型 |
解释 |
---|---|
int |
当前rsrp值,若失败返回0. 取值范围: -44 ~ -140 ,值越大越好 |
例子
无
mobile.rsrq()#
获取rsrq,参考信号发送功率
参数
无
返回值
返回值类型 |
解释 |
---|---|
int |
当前rsrq值,若失败返回0. 取值范围: -3 ~ -19.5 ,值越大越好 |
例子
无
mobile.snr()#
获取snr,信噪比
参数
无
返回值
返回值类型 |
解释 |
---|---|
int |
当前snq值,若失败返回0.范围 0 - 30, 越大越好 |
例子
无
mobile.eci()#
获取当前服务小区的ECI(E-UTRAN Cell Identifier)
参数
无
返回值
返回值类型 |
解释 |
---|---|
int |
当前eci值,若失败返回-1 |
例子
无
mobile.tac()#
获取当前服务小区的TAC或者LAC
参数
无
返回值
返回值类型 |
解释 |
---|---|
int |
当前eci值,若失败返回-1. 如果尚未注册到网络,会返回0 |
例子
-- 本API于 2023.7.9 新增
mobile.enbid()#
获取当前服务小区的eNBID(eNodeB Identifier)
参数
无
返回值
返回值类型 |
解释 |
---|---|
int |
当前enbid值,若失败返回-1 |
例子
无
mobile.scell()#
获取当前服务小区更详细的信息
参数
无
返回值
返回值类型 |
解释 |
---|---|
table |
服务小区的信息 |
例子
-- 本API于 2024.9.12 新增
log.info("cell", json.encode(mobile.scell()))
-- 返回值示例
{
"mnc": 11,
"mcc": 460,
"rssi": -78,
"pci": 115,
"rsrp": -107,
"tac": 30005,
"eci": 124045360,
"cid": 124045360,
"rsrq": -9,
"snr": 15,
"earfcn": 1850
}
mobile.flymode(index, enable)#
进出飞行模式
参数
传入值类型 |
解释 |
---|---|
int |
编号,默认0. 在支持双卡的模块上才会出现0或1的情况 |
bool |
是否设置为飞行模式,true为设置, false为退出,可选 |
返回值
返回值类型 |
解释 |
---|---|
bool |
原飞行模式的状态 |
例子
无
mobile.syncTime(enable)#
配置基站同步时间开关,默认开启
参数
传入值类型 |
解释 |
---|---|
bool |
开启,true开启, false关闭, nil不设置 |
返回值
返回值类型 |
解释 |
---|---|
bool |
当前开关状态 |
例子
mobile.syncTime() --获取当前开关状态
mobile.syncTime(false) --关闭基站同步时间
mobile.status()#
获取网络状态
参数
无
返回值
返回值类型 |
解释 |
---|---|
int |
当前网络状态 |
例子
-- 状态描述
-- 0:网络未注册
-- 1:网络已注册
-- 2:正在搜网中
-- 3:网络注册被拒绝
-- 4:网络状态未知
-- 5:漫游,且已注册
-- 6:仅SMS可用
-- 7:仅SMS可用,且漫游状态
-- 8:仅紧急呼叫. 注意, 国内不支持此状态,模块也不支持紧急呼叫
-- 不推荐使用本API判断联网状态, 建议使用socket.localIP()来判断
mobile.getCellInfo()#
获取基站信息
参数
无
返回值
返回值类型 |
解释 |
---|---|
table |
包含基站数据的数组 |
例子
-- 注意: 从2023.06.20开始, 需要主动请求一次reqCellInfo才会有基站数据.
--示例输出(原始数据是table, 下面是json格式化后的内容)
--[[
[
{"rsrq":-10,"rssi":-55,"cid":124045360,"mnc":17,"pci":115,"earfcn":1850,"snr":15,"rsrp":-85,"mcc":1120,"tdd":0},
{"pci":388,"rsrq":-11,"mnc":17,"earfcn":2452,"snr":5,"rsrp":-67,"mcc":1120,"cid":124045331},
{"pci":100,"rsrq":-9,"mnc":17,"earfcn":75,"snr":17,"rsrp":-109,"mcc":1120,"cid":227096712}
]
]]
mobile.reqCellInfo(60)
-- 订阅
sys.subscribe("CELL_INFO_UPDATE", function()
log.info("cell", json.encode(mobile.getCellInfo()))
end)
-- 定期轮训式
sys.taskInit(function()
sys.wait(3000)
while 1 do
mobile.reqCellInfo(15)
sys.waitUntil("CELL_INFO_UPDATE", 15000)
log.info("cell", json.encode(mobile.getCellInfo()))
end
end)
mobile.reqCellInfo(timeout)#
发起基站信息查询,含临近小区
参数
传入值类型 |
解释 |
---|---|
int |
超时时长,单位秒,默认15. 最少5, 最高60 |
返回值
返回值类型 |
解释 |
---|---|
nil |
无返回值 |
例子
-- 参考 mobile.getCellInfo 函数
mobile.lockCell(mode, earfcn, pci)#
锁定/解锁小区,仅用于外场测试,没接触过的,或者生产环境中请勿使用
参数
传入值类型 |
解释 |
---|---|
int |
操作码 0删除优先的频点,1设置优先频点,2锁定小区,3解锁小区 |
int |
下行频点 |
int |
phycellid |
返回值
返回值类型 |
解释 |
---|---|
bool |
成功true 失败false |
例子
mobile.lockCell(2,1860,32) --锁定小区
mobile.lockCell(3) --解锁小区
mobile.reset()#
重启协议栈
参数
无
返回值
返回值类型 |
解释 |
---|---|
nil |
无返回值 |
例子
-- 重启LTE协议栈
mobile.reset()
mobile.dataTraffic(clearUplink, clearDownlink)#
数据量流量处理
参数
传入值类型 |
解释 |
---|---|
boolean |
清空上行流量累计值,true清空,其他忽略 |
boolean |
清空下行流量累计值,true清空,其他忽略 |
返回值
返回值类型 |
解释 |
---|---|
int |
上行流量GB |
int |
上行流量B |
int |
下行流量GB |
int |
下行流量B |
例子
-- 获取上下行流量累计值
-- 上行流量值Byte = uplinkGB * 1024 * 1024 * 1024 + uplinkB
-- 下行流量值Byte = downlinkGB * 1024 * 1024 * 1024 + downlinkB
local uplinkGB, uplinkB, downlinkGB, downlinkB = mobile.dataTraffic()
-- 清空上下行流量累计值
mobile.dataTraffic(true, true)
-- 仅记录开机后的流量,复位/重启会归零
mobile.config(item, value)#
网络特殊配置
参数
传入值类型 |
解释 |
---|---|
int |
配置项目,看mobile.CONF_XXX |
int |
配置值,根据具体配置的item决定 |
返回值
返回值类型 |
解释 |
---|---|
boolean |
是否成功 |
例子
--针对不同平台有不同的配置,谨慎使用,目前只有EC618/EC718系列
-- EC618配置小区重选信号差值门限,不能大于15dbm,必须在飞行模式下才能用
mobile.flymode(0,true)
mobile.config(mobile.CONF_RESELTOWEAKNCELL, 15)
mobile.config(mobile.CONF_STATICCONFIG, 1) --开启网络静态优化
mobile.flymode(0,false)
-- EC618设置SIM写入次数的统计
-- 关闭统计
mobile.config(mobile.CONF_SIM_WC_MODE, 0)
-- 开启统计, 默认也是开启的.
mobile.config(mobile.CONF_SIM_WC_MODE, 1)
-- 读取统计值,异步, 需要通过系统消息SIM_IND获取
sys.subscribe("SIM_IND", function(stats, value)
log.info("SIM_IND", stats)
if stats == "SIM_WC" then
log.info("sim", "write counter", value)
end
end)
mobile.config(mobile.CONF_SIM_WC_MODE, 2)
-- 清空统计值
mobile.config(mobile.CONF_SIM_WC_MODE, 3)
mobile.getBand(band, is_default)#
获取当前使用/支持的band
参数
传入值类型 |
解释 |
---|---|
zbuff |
输出band |
boolean |
true默认支持,false当前支持的,默认是false,当前是预留功能,不要写true |
返回值
返回值类型 |
解释 |
---|---|
boolean |
成功返回true,失败放回false |
例子
local buff = zbuff.create(40)
mobile.getBand(buff) --输出当前使用的band,band号放在buff内,buff[0],buff[1],buff[2] .. buff[buff:used() - 1]
mobile.setBand(band, num)#
设置使用的band
参数
传入值类型 |
解释 |
---|---|
zbuff |
输入使用的band |
int |
band数量 |
返回值
返回值类型 |
解释 |
---|---|
boolean |
成功返回true,失败放回false |
例子
local buff = zbuff.create(40)
buff[0] = 3
buff[1] = 5
buff[2] = 8
buff[3] = 40
mobile.setBand(buff, 4) --设置使用的band一共4个,为3,5,8,40
mobile.nstOnOff(onoff, uart_id)#
RF测试开关和配置
参数
传入值类型 |
解释 |
---|---|
boolean |
true开启测试模式,false关闭 |
int |
串口号 |
返回值
返回值类型 |
解释 |
---|---|
nil |
无返回值 |
例子
mobile.nstOnOff(true, uart.VUART_0) --打开测试模式,并且用虚拟串口发送结果
mobile.nstOnOff(false) --关闭测试模式
mobile.nstInput(data)#
RF测试数据输入
参数
传入值类型 |
解释 |
---|---|
string |
or zbuff 用户从串口获取的数据,注意,当获取完所有数据后,需要再传一个nil来作为传输结束 |
返回值
返回值类型 |
解释 |
---|---|
nil |
无返回值 |
例子
mobile.nstInput(uart_data)
mobile.nstInput(nil)
mobile.vsimInit()#
初始化内置默认虚拟卡功能(不可用)
参数
无
返回值
返回值类型 |
解释 |
---|---|
nil |
无返回值 |
例子
mobile.vsimInit()
mobile.vsimOnOff(enable)#
切换内置虚拟卡和外置实体卡,2024年8月13日启用,虚拟卡需要固件支持,否则切换后无网络,需要在飞行模式下切换,或者切换后重启协议栈
参数
传入值类型 |
解释 |
---|---|
bool |
开启,true开启, false关闭 |
返回值
返回值类型 |
解释 |
---|---|
nil |
无返回值 |
例子
mobile.vsimOnOff(true) --使用内置虚拟卡
mobile.vsimOnOff(false) --使用外置实体卡
mobile.apnTableInit()#
初始化自定义APN列表,主要用于海外SIM卡
参数
无
返回值
返回值类型 |
解释 |
---|---|
nil |
无返回值 |
例子
mobile.apnTableInit()
mobile.apnTableAdd(mcc, mnc, ip_type, protocol, apn_name, user_name, password)#
往自定义APN列表添加一条APN信息,主要用于海外SIM卡
参数
传入值类型 |
解释 |
---|---|
int |
MCC码,16进制BCD码 |
int |
MNC码,16进制BCD码 |
int |
激活APN时的IP TYPE,1=IPV4 2=IPV6 3=IPV4V6,默认是1 |
int |
激活APN时,如果需要username和password,就要写鉴权协议类型,1~3,默认3,代表1和2都尝试一下。不需要鉴权的写0 |
string |
APN name,不能为空 |
string |
APN的username |
string |
APN的password |
返回值
返回值类型 |
解释 |
---|---|
nil |
无返回值 |
例子
mobile.apnTableInit() -- 先初始化,必须放在SIM卡识别完成前加入,最好就是写在开头
mobile.apnTableAdd(0x460,0x00,3,0,"cmiot","","") -- 单独添加一条APN信息,必须放在SIM卡识别完成前加入,最好就是写在开头,移动公网卡设置APN为cmiot(一般不用设置,这里只是举个例子)
mobile.apnTablePrint(mcc, mnc)#
打印自定义APN列表里的一条信息,在没有拿到卡的情况下,测试一下对应的APN信息是否和运营商提供的匹配
参数
传入值类型 |
解释 |
---|---|
int |
MCC码,16进制BCD码 |
int |
MNC码,16进制BCD码 |
返回值
返回值类型 |
解释 |
---|---|
nil |
无返回值 |
例子
mobile.apnTableInit()
mobile.apnTablePrint(0x202, 0x01)