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

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

liebian365 2024-10-29 15:53 25 浏览 0 评论

前言:有一段时间使用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也可以实现...


相关推荐

精品博文嵌入式6410中蓝牙的使用

BluetoothUSB适配器拥有一个BluetoothCSR芯片组,并使用USB传输器来传输HCI数据分组。因此,LinuxUSB层、BlueZUSB传输器驱动程序以及B...

win10跟这台计算机连接的前一个usb设备工作不正常怎么办?

前几天小编闲来无事就跑到网站底下查看粉丝朋友给小编我留言询问的问题,还真的就给小编看到一个问题,那就是win10跟这台计算机连接的一个usb设备运行不正常怎么办,其实这个问题的解决方法时十分简单的,接...

制作成本上千元的键盘,厉害在哪?

这是稚晖君亲自写的开源资料!下方超长超详细教程预警!!全文导航:项目简介、项目原理说明、硬件说明、软件说明项目简介瀚文智能键盘是一把我为自己设计的——多功能、模块化机械键盘。键盘使用模块化设计。左侧的...

E-Marker芯片,USB数据线的“性能中枢”?

根据线缆行业的研究数据,在2019年搭载Type-C接口的设备出货量已达到20亿台,其中80%的笔记本电脑和台式电脑采用Type-C接口,50%的智能手机和平板电脑也使用Type-C接口。我们都知道,...

ZQWL-USBCANFD二次开发通讯协议V1.04

修订历史:1.功能介绍1.1型号说明本文档适用以下型号:  ZQWL-CAN(FD)系列产品,USB通讯采用CDC类实现,可以在PC机上虚拟出一个串口,串口参数N,8,1格式,波特率可以根据需要设置(...

win10系统无法识别usb设备怎么办(win10不能识别usb)

从驱动入手,那么win10系统无法识别usb设备怎么办呢?今天就为大家分享win10系统无法识别usb设备的解决方法。1、右键选择设备管理器,如图:  2、点击更新驱动程序,如图:  3、选择浏览...

微软七月Win8.1可选补丁有内涵,含大量修复

IT之家(www.ithome.com):微软七月Win8.1可选补丁有内涵,含大量修复昨日,微软如期为Win7、Win8.1发布7月份安全更新,累计为6枚安全补丁,分别修复总计29枚安全漏洞,其中2...

如何从零开始做一个 USB 键盘?(怎么制作usb)

分两种情况:1、做一个真正的USB键盘,这种设计基本上不涉及大量的软件编码。2、做一个模拟的USB键盘,实际上可以没有按键功能,这种的需要考虑大量的软件编码,实际上是一个单片机。第一种设计:买现成的U...

电脑识别U盘失败?5个实用小技巧,让你轻松搞定USB识别难题

电脑识别U盘失败?5个实用小技巧,让你轻松搞定USB识别难题注意:有些方法会清除USB设备里的数据,请谨慎操作,如果不想丢失数据,可以先连接到其他电脑,看能否将数据复制出来,或者用一些数据恢复软件去扫...

未知usb设备设备描述符请求失败怎么解决

出现未知daousb设备设备描述符请求失du败解决办zhi法如下:1、按下Windows+R打开【运行】;2、在版本运行的权限输入框中输入:services.msc按下回车键打开【服务】;2、在服务...

读《飘》47章20(飘每章概括)

AndAhwouldn'tleaveMissEllen'sgrandchildrenfornotrashystep-patobringup,never.Here,Ah...

英翻中 消失的过去 37(消失的英文怎么说?)

翻译(三十七):消失的过去/茱迪o皮考特VanishingActs/JodiPicoult”我能做什么?“直到听到了狄利亚轻柔的声音,我才意识到她已经在厨房里站了好一会儿了。当她说话的时候,...

RabbitMQ 延迟消息实战(rabbitmq如何保证消息不被重复消费)

现实生活中有一些场景需要延迟或在特定时间发送消息,例如智能热水器需要30分钟后打开,未支付的订单或发送短信、电子邮件和推送通知下午2:00开始的促销活动。RabbitMQ本身没有直接支持延迟...

Java对象拷贝原理剖析及最佳实践(java对象拷贝方法)

作者:宁海翔1前言对象拷贝,是我们在开发过程中,绕不开的过程,既存在于Po、Dto、Do、Vo各个表现层数据的转换,也存在于系统交互如序列化、反序列化。Java对象拷贝分为深拷贝和浅拷贝,目前常用的...

如何将 Qt 3D 渲染与 Qt Quick 2D 元素结合创建太阳系行星元素?

Qt组件推荐:QtitanRibbon:遵循MicrosoftRibbonUIParadigmforQt技术的RibbonUI组件,致力于为Windows、Linux和MacOSX提...

取消回复欢迎 发表评论: