Openresty编写Lua代码一例

1.前段时间纠结了很久,一直弄不清lua和tomcat的联系。一直认为是lua调用tomcat的接口才可使用,后面才明白过来,进入了一个误区,lua本身就是一门独立的脚本语言。在openresty里面配置好,即可编写映射和响应。

下面是自己编写的lua代码一例,仅供参考。还有些不完善,要开始忙项目了,等有空再继续更新。

2.下面是lua代码,记得在nginx.conf写好配置。

local request_method = ngx.var.request_method
local cjson = require("cjson")
local mysql = require("resty.mysql")
local quote = ngx.quote_sql_str
local db,err = mysql:new()
local function close_db(db)  
    if not db then  
        return  
    end  
    db:close()  
end 
if not db 
then
	nax.say("new mysql error",err)
end

local args = nil
local username = nil
local pwd = nil
if "GET" == request_method
then
	args = ngx.req.get_uri_args()
elseif "POST" == ngx.request_method
then
	ngx.req.read_body()
	args = ngx.req.get_post_args()
end
username = tostring(args["username"])
pwd = tostring(args["pwd"])
if username == nil then
	ngx.say("username not nil")
	return
elseif username == '' then
	ngx.say("username not nil")
	return
elseif pwd == nil then
	ngx.say("password not nil")
	return;
elseif pwd == '' then
	ngx.say("password not nil")
	return;
end

db:set_timeout(1000)  

local props = {  
    host = "127.0.0.1",  
    port = 3306,  
    database = "hwc_hello",  
    user = "root",  
    password = "hwc123456"  
}  

local res, err, errno, sqlstate = db:connect(props) 
if not res then  
   ngx.say("connect to mysql error : ", err, " , errno : ", errno, " , sqlstate : ", sqlstate)  
   return close_db(db)  
end 

local select_name = "select username from user_table where username="..quote(username)
res, err, errno, sqlstate = db:query(select_name)  
if not res then  
   ngx.exec("/vi/404.html")  
   return close_db(db)  
end  
local result = {}
result.success = true;
result.info = "登录成功"
ngx.say(cjson.encode(result))

 

转载于:https://www.cnblogs.com/dslx/p/9208622.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值