内容简介:最近在配合移动端调试的时候,被抓去debug一个在清除redis缓存之后才会出现的网关错误。于是打开服务器上的log定位到类似错误:该段代码的主要作用是在通过查询资料得知原因:
最近在配合移动端调试的时候,被抓去debug一个在清除 redis 缓存之后才会出现的网关错误。于是打开服务器上的log定位到类似错误:
[error] 7#7: *12030 lua entry thread aborted: runtime error: /data/share/apps/lua/access_check.lua:133: bad argument #1 to 'decode' (string expected, got userdata)
该段代码的主要作用是在 openresty
中 lua
读取 redis
中数据并解码为 json
:
local access_token = redis_client:read_by_key(token_key) if access_token == nil then -- do something... return false end local obj_token = cjson.decode(access_token) -- do something
通过查询资料得知原因:
lua
读取 redis
数据返回结果为空时,返回的结果不是 nil
而是 userdata
类型的 ngx.null
。
因为 nil
在 lua
中有特殊的意义,如果一个变量被设置为 nil
相当于告知该变量 未定义
(不存在)一样,如果把 redis
查询的结果为空设置为 nil
,而该查询的 key
对应在 redis
中又是存在的,就无法把 查询为空
和 未定义
区分开来了,这样显然是不合理的。所以必须使用一个 userdata
类型的值来表示这个查询记录为空,但是又不等同于 未定义变量
(ngx.null)。
因此,代码做如下修改即可:
local access_token = redis_client:read_by_key(token_key) if access_token == ngx.null or access_token == nil then -- do something... return false end local obj_token = cjson.decode(access_token) -- do something
以上所述就是小编给大家介绍的《lua读取redis数据的null判断》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- 你有没有想过: Java 虚拟机是如何判断两个对象是否相同的?判断的流程是什么?
- iOS Rotation 判断
- 判断是否是闰年
- 数值类型(金额)限制与判断
- ansible笔记(26):条件判断
- 判断Golang接口是否实现
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。