百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

【LUA】只需花费你半天时间

wptr33 2025-01-21 21:56 23 浏览

前言:有一段时间使用OpenResty写Waf防护模块的时候使用到了Lua。Lua 是一种轻量小巧的脚本语言,用标准C语言编写并以源代码形式开放, 其设计目的是为了嵌入应用程序中,从而为应用程序提供灵活的扩展和定制功能。

学习Lua代码,从变量到跑路

x=1    --全局变量  
local x=1 --局部变量

function a()  
b=2     --全局变量  
local c=2 --局部变量  
end

print(b,c)    --  2,nil

local _M = {}    --空tabel 也叫空数组  
_M["key"] = "value" --填充值  
--给tabel增加方法
_M.Find = function()  
print("local")  
end

d,d2 = 2,3 -- 定义值,多个  
d,d2 = d2,d   --swap交换值  
print(d,d2)  --3,2

--条件语句
if true then  
print(xxx)  
end

if true then  
print(xx)  
else  
if false then  
print(x)  
end  
end

--遍历tabel
for k,v in ipairs(_M) do  
print(k,v)  
end  
--ipairs和pairs都是的迭代器,区别,
--ipairs遇到tabel内容为nil的时候,终止循环
--注意:lua迭代器下标是从1开始
for k,v in pairs(_M) do  
print(k,v)  
end

--循环
--x=初始值,最大值,步长值     步长值代表每次递增多少数
for x=1,10,3 do  
print(x)  
end  
--while循环
local a = 10  
while(a<100)  
do  
a = a+10  
print(a)  
end

--repeat-until循环,先执行,后判断,类似语言do---while
local b = 10  
repeat  
print(b)  
b = b+1  
until(b>15)    --当b大于15的时候结束循环

--函数定义,系统默认是全局
function a() do  
print("all in")  
end  
--局部函数使用local,也支持向tabel添加方法
local func = function()  
print("local")  
end  
--可变参数,接受未知个参数
funciton args(...)  
local result = 0  
---将参数写入tabel
local arg = {...}  
for k,v = ipairs(arg) do  
print(k,v)  
end  
--#arg代表统计有多少个参数
print("参数总数:",#arg)  
end  
--Demo(当传入为nil参数的时候,是不算个数):
function fun(...)  
    local x={...}
    print(#x)
end  
fun(1,2,3,4,5,nil)   --5  
fun(1,2,3,4,5,0)     --6


---#xx 统计坑,取决于最大的索引值,如果有越标行为,则按越标前一位计算总数
local xx = {}  
xx[1] = 2  
xx[2] = 3  
print(#xx)  
local xx = {}  
xx[1] = 2  
xx[8] = 3  
print(#xx)

--字符串
local x = "aaaaa"  
local x = ’aaaaa‘  
local x = [[  
一组模板数据
]]
--字符串连接 ..
local c = x..b


--模块与包
--定义a.lua文件
a = {}  
a.constant = "常量"  
a.func1 = function()  
print("a模块 1方法")  
end  
a.func2 = function()  
print("a模块 2方法")  
end  
return a  
--定义b.lua文件
--require("a")
require("a")  
a.func1()  
--local m = require("a")
m.func1()

--lua加载c库
local path = "/usr/local/lua/lib/libluasocket.so"  
-- 或者 path = "C:\\windows\\luasocket.dll",这是 Window 平台下
local f = assert(loadlib(path, "luaopen_socket"))  
f()  -- 真正打开库


--协同程序
function foo (a)  
    print("foo 函数输出", a)
    return coroutine.yield(2 * a) -- 返回  2*a 的值
end  
co = coroutine.create(function (a , b)  
    print("第一次协同程序执行输出", a, b) -- co-body 1 10
    local r = foo(a + 1)     
    print("第二次协同程序执行输出", r)
    local r, s = coroutine.yield(a + b, a - b)  -- a,b的值为第一次调用协同程序时传入     
    print("第三次协同程序执行输出", r, s)
    return b, "结束协同程序"                   -- b的值为第二次调用协同程序时传入
end)  
print("main", coroutine.resume(co, 1, 10)) -- true, 4  
print("--分割线----")  
print("main", coroutine.resume(co, "r")) -- true 11 -9  
print("---分割线---")  
print("main", coroutine.resume(co, "x", "y")) -- true 10 end  
print("---分割线---")  
print("main", coroutine.resume(co, "x", "y")) -- cannot resume dead coroutine  
print("---分割线---")  
--[[
第一次运行之后,挂起yield
第二运行,先执行上次的yield输出,再执行本次调用
第三次运行,执行上一次yield输出,再执行本次
结束协同程序
第四次就提示dead了
]]


--文件操作,基于io类
--打开
file = io.open("文件名","打开方式") --r w a r+ w+ a+ b  
--读取
io.input(file)  
io.read()  
--写入
io.output(file)  
io.write("hhhhh")  
--关闭
io.close(file)


--面向对象
A = {t=0}  
A.func1 = function()  
print(A.t)  
end

--继承
B = {area=0}  
--基础类
B:new =function(o,p2)  
o = o or {}  
setmetatable(o, self)  
self.__index = self  
side = side or 0  
self.area = side*side;  
return o  
end  
-- 基础类方法 printArea
function B:printArea()  
  print("面积为 ",self.area)
end

-- 创建对象
myshape = Shape:new(nil,10)  
myshape:printArea()

Square = Shape:new()  
-- 派生类方法 new
function Square:new (o,side)  
  o = o or Shape:new(o,side)
  setmetatable(o, self)
  self.__index = self
  return o
end

-- 派生类方法 printArea
function Square:printArea ()  
  print("正方形面积为 ",self.area)
end

-- 创建对象
mysquare = Square:new(nil,10)  
mysquare:printArea()

Rectangle = Shape:new()  
-- 派生类方法 new
function Rectangle:new (o,length,breadth)  
  o = o or Shape:new(o)
  setmetatable(o, self)
  self.__index = self
  self.area = length * breadth
  return o
end

-- 派生类方法 printArea
function Rectangle:printArea ()  
  print("矩形面积为 ",self.area)
end

-- 创建对象
myrectangle = Rectangle:new(nil,10,20)  
myrectangle:printArea()

总结

如果你有用到openresty作一个补丁包开发,建议使用lua脚本方式,随然c也可以实现...


前言:有一段时间使用OpenResty写Waf防护模块的时候使用到了Lua。Lua 是一种轻量小巧的脚本语言,用标准C语言编写并以源代码形式开放, 其设计目的是为了嵌入应用程序中,从而为应用程序提供灵活的扩展和定制功能。

学习Lua代码,从变量到跑路

x=1    --全局变量  
local x=1 --局部变量

function a()  
b=2     --全局变量  
local c=2 --局部变量  
end

print(b,c)    --  2,nil

local _M = {}    --空tabel 也叫空数组  
_M["key"] = "value" --填充值  
--给tabel增加方法
_M.Find = function()  
print("local")  
end

d,d2 = 2,3 -- 定义值,多个  
d,d2 = d2,d   --swap交换值  
print(d,d2)  --3,2

--条件语句
if true then  
print(xxx)  
end

if true then  
print(xx)  
else  
if false then  
print(x)  
end  
end

--遍历tabel
for k,v in ipairs(_M) do  
print(k,v)  
end  
--ipairs和pairs都是的迭代器,区别,
--ipairs遇到tabel内容为nil的时候,终止循环
--注意:lua迭代器下标是从1开始
for k,v in pairs(_M) do  
print(k,v)  
end

--循环
--x=初始值,最大值,步长值     步长值代表每次递增多少数
for x=1,10,3 do  
print(x)  
end  
--while循环
local a = 10  
while(a<100)  
do  
a = a+10  
print(a)  
end

--repeat-until循环,先执行,后判断,类似语言do---while
local b = 10  
repeat  
print(b)  
b = b+1  
until(b>15)    --当b大于15的时候结束循环

--函数定义,系统默认是全局
function a() do  
print("all in")  
end  
--局部函数使用local,也支持向tabel添加方法
local func = function()  
print("local")  
end  
--可变参数,接受未知个参数
funciton args(...)  
local result = 0  
---将参数写入tabel
local arg = {...}  
for k,v = ipairs(arg) do  
print(k,v)  
end  
--#arg代表统计有多少个参数
print("参数总数:",#arg)  
end  
--Demo(当传入为nil参数的时候,是不算个数):
function fun(...)  
    local x={...}
    print(#x)
end  
fun(1,2,3,4,5,nil)   --5  
fun(1,2,3,4,5,0)     --6


---#xx 统计坑,取决于最大的索引值,如果有越标行为,则按越标前一位计算总数
local xx = {}  
xx[1] = 2  
xx[2] = 3  
print(#xx)  
local xx = {}  
xx[1] = 2  
xx[8] = 3  
print(#xx)

--字符串
local x = "aaaaa"  
local x = ’aaaaa‘  
local x = [[  
一组模板数据
]]
--字符串连接 ..
local c = x..b


--模块与包
--定义a.lua文件
a = {}  
a.constant = "常量"  
a.func1 = function()  
print("a模块 1方法")  
end  
a.func2 = function()  
print("a模块 2方法")  
end  
return a  
--定义b.lua文件
--require("a")
require("a")  
a.func1()  
--local m = require("a")
m.func1()

--lua加载c库
local path = "/usr/local/lua/lib/libluasocket.so"  
-- 或者 path = "C:\\windows\\luasocket.dll",这是 Window 平台下
local f = assert(loadlib(path, "luaopen_socket"))  
f()  -- 真正打开库


--协同程序
function foo (a)  
    print("foo 函数输出", a)
    return coroutine.yield(2 * a) -- 返回  2*a 的值
end  
co = coroutine.create(function (a , b)  
    print("第一次协同程序执行输出", a, b) -- co-body 1 10
    local r = foo(a + 1)     
    print("第二次协同程序执行输出", r)
    local r, s = coroutine.yield(a + b, a - b)  -- a,b的值为第一次调用协同程序时传入     
    print("第三次协同程序执行输出", r, s)
    return b, "结束协同程序"                   -- b的值为第二次调用协同程序时传入
end)  
print("main", coroutine.resume(co, 1, 10)) -- true, 4  
print("--分割线----")  
print("main", coroutine.resume(co, "r")) -- true 11 -9  
print("---分割线---")  
print("main", coroutine.resume(co, "x", "y")) -- true 10 end  
print("---分割线---")  
print("main", coroutine.resume(co, "x", "y")) -- cannot resume dead coroutine  
print("---分割线---")  
--[[
第一次运行之后,挂起yield
第二运行,先执行上次的yield输出,再执行本次调用
第三次运行,执行上一次yield输出,再执行本次
结束协同程序
第四次就提示dead了
]]


--文件操作,基于io类
--打开
file = io.open("文件名","打开方式") --r w a r+ w+ a+ b  
--读取
io.input(file)  
io.read()  
--写入
io.output(file)  
io.write("hhhhh")  
--关闭
io.close(file)


--面向对象
A = {t=0}  
A.func1 = function()  
print(A.t)  
end

--继承
B = {area=0}  
--基础类
B:new =function(o,p2)  
o = o or {}  
setmetatable(o, self)  
self.__index = self  
side = side or 0  
self.area = side*side;  
return o  
end  
-- 基础类方法 printArea
function B:printArea()  
  print("面积为 ",self.area)
end

-- 创建对象
myshape = Shape:new(nil,10)  
myshape:printArea()

Square = Shape:new()  
-- 派生类方法 new
function Square:new (o,side)  
  o = o or Shape:new(o,side)
  setmetatable(o, self)
  self.__index = self
  return o
end

-- 派生类方法 printArea
function Square:printArea ()  
  print("正方形面积为 ",self.area)
end

-- 创建对象
mysquare = Square:new(nil,10)  
mysquare:printArea()

Rectangle = Shape:new()  
-- 派生类方法 new
function Rectangle:new (o,length,breadth)  
  o = o or Shape:new(o)
  setmetatable(o, self)
  self.__index = self
  self.area = length * breadth
  return o
end

-- 派生类方法 printArea
function Rectangle:printArea ()  
  print("矩形面积为 ",self.area)
end

-- 创建对象
myrectangle = Rectangle:new(nil,10,20)  
myrectangle:printArea()

总结

如果你有用到openresty作一个补丁包开发,建议使用lua脚本方式,随然c也可以实现...


相关推荐

redis的八种使用场景

前言:redis是我们工作开发中,经常要打交道的,下面对redis的使用场景做总结介绍也是对redis举报的功能做梳理。缓存Redis最常见的用途是作为缓存,用于加速应用程序的响应速度。...

基于Redis的3种分布式ID生成策略

在分布式系统设计中,全局唯一ID是一个基础而关键的组件。随着业务规模扩大和系统架构向微服务演进,传统的单机自增ID已无法满足需求。高并发、高可用的分布式ID生成方案成为构建可靠分布式系统的必要条件。R...

基于OpenWrt系统路由器的模式切换与网页设计

摘要:目前商用WiFi路由器已应用到多个领域,商家通过给用户提供一个稳定免费WiFi热点达到吸引客户、提升服务的目标。传统路由器自带的Luci界面提供了工厂模式的Web界面,用户可通过该界面配置路...

这篇文章教你看明白 nginx-ingress 控制器

主机nginx一般nginx做主机反向代理(网关)有以下配置...

如何用redis实现注册中心

一句话总结使用Redis实现注册中心:服务注册...

爱可可老师24小时热门分享(2020.5.10)

No1.看自己以前写的代码是种什么体验?No2.DooM-chip!国外网友SylvainLefebvre自制的无CPU、无操作码、无指令计数器...No3.我认为CS学位可以更好,如...

Apportable:拯救程序员,IOS一秒变安卓

摘要:还在为了跨平台使用cocos2d-x吗,拯救objc程序员的奇葩来了,ApportableSDK:FreeAndroidsupportforcocos2d-iPhone。App...

JAVA实现超买超卖方案汇总,那个最适合你,一篇文章彻底讲透

以下是几种Java实现超买超卖问题的核心解决方案及代码示例,针对高并发场景下的库存扣减问题:方案一:Redis原子操作+Lua脚本(推荐)//使用Redis+Lua保证原子性publicbo...

3月26日更新 快速施法自动施法可独立设置

2016年3月26日DOTA2有一个79.6MB的更新主要是针对自动施法和快速施法的调整本来内容不多不少朋友都有自动施法和快速施法的困扰英文更新日志一些视觉BUG修复就不翻译了主要翻译自动施...

Redis 是如何提供服务的

在刚刚接触Redis的时候,最想要知道的是一个’setnameJhon’命令到达Redis服务器的时候,它是如何返回’OK’的?里面命令处理的流程如何,具体细节怎么样?你一定有问过自己...

lua _G、_VERSION使用

到这里我们已经把lua基础库中的函数介绍完了,除了函数外基础库中还有两个常量,一个是_G,另一个是_VERSION。_G是基础库本身,指向自己,这个变量很有意思,可以无限引用自己,最后得到的还是自己,...

China&#39;s top diplomat to chair third China-Pacific Island countries foreign ministers&#39; meeting

BEIJING,May21(Xinhua)--ChineseForeignMinisterWangYi,alsoamemberofthePoliticalBureau...

移动工作交流工具Lua推出Insights数据分析产品

Lua是一个适用于各种职业人士的移动交流平台,它在今天推出了一项叫做Insights的全新功能。Insights是一个数据平台,客户可以在上面实时看到员工之间的交流情况,并分析这些情况对公司发展的影响...

Redis 7新武器:用Redis Stack实现向量搜索的极限压测

当传统关系型数据库还在为向量相似度搜索的性能挣扎时,Redis7的RedisStack...

Nginx/OpenResty详解,Nginx Lua编程,重定向与内部子请求

重定向与内部子请求Nginx的rewrite指令不仅可以在Nginx内部的server、location之间进行跳转,还可以进行外部链接的重定向。通过ngx_lua模块的Lua函数除了能实现Nginx...