lua读取redis数据的null判断

最近在配合移动端调试的时候,被抓去debug一个在清除redis缓存之后才会出现的网关错误。于是打开服务器上的log定位到类似错误:

1  
[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)  

—|—

该段代码的主要作用是在openrestylua读取redis中数据并解码为json

1  
2  
3  
4  
5  
6  
7  
8  
local access_token = redis_client:read_by_key(token_key)  
   if access_token == nil then  
         
       return false  
   end  
  
   local obj_token = cjson.decode(access_token)  
   -- do something  

—|—

通过查询资料得知原因: lua读取redis数据返回结果为空时,返回的结果不是nil而是userdata类型的ngx.null


为什么要这么设计?

因为nillua中有特殊的意义,如果一个变量被设置为nil相当于告知该变量未定义(不存在)一样,如果把redis查询的结果为空设置为nil,而该查询的key对应在redis中又是存在的,就无法把查询为空未定义区分开来了,这样显然是不合理的。所以必须使用一个userdata类型的值来表示这个查询记录为空,但是又不等同于未定义变量(ngx.null)。


因此,代码做如下修改即可:

1  
2  
3  
4  
5  
6  
7  
8  
local access_token = redis_client:read_by_key(token_key)  
   if access_token == ngx.null or access_token == nil then  
         
       return false  
   end  
  
   local obj_token = cjson.decode(access_token)  
   -- do something  

—|—

糖果

糖果
LUA教程

Lapis框架的常用处理方法

Lapis框架的常用处理方法 Continue reading

MoonScript实现选择排序

Published on February 26, 2017

MoonScript与Redis客户端

Published on January 19, 2017