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

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

suiw9 2024-11-05 12:37 27 浏览 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也可以实现...


相关推荐

俄罗斯的 HTTPS 也要被废了?(俄罗斯网站关闭)

发布该推文的ScottHelme是一名黑客,SecurityHeaders和ReportUri的创始人、Pluralsight作者、BBC常驻黑客。他表示,CAs现在似乎正在停止为俄罗斯域名颁发...

如何强制所有流量使用 HTTPS一网上用户

如何强制所有流量使用HTTPS一网上用户使用.htaccess强制流量到https的最常见方法可能是使用.htaccess重定向请求。.htaccess是一个简单的文本文件,简称为“.h...

https和http的区别(https和http有何区别)

“HTTPS和HTTP都是数据传输的应用层协议,区别在于HTTPS比HTTP安全”。区别在哪里,我们接着往下看:...

快码住!带你十分钟搞懂HTTP与HTTPS协议及请求的区别

什么是协议?网络协议是计算机之间为了实现网络通信从而达成的一种“约定”或“规则”,正是因为这个“规则”的存在,不同厂商的生产设备、及不同操作系统组成的计算机之间,才可以实现通信。简单来说,计算机与网络...

简述HTTPS工作原理(简述https原理,以及与http的区别)

https是在http协议的基础上加了一层SSL(由网景公司开发),加密由ssl实现,它的目的是为用户提供对网站服务器的身份认证(需要CA),以至于保护交换数据的隐私和完整性,原理如图示。1、客户端发...

21、HTTPS 有几次握手和挥手?HTTPS 的原理什么是(高薪 常问)

HTTPS是3次握手和4次挥手,和HTTP是一样的。HTTPS的原理...

一次安全可靠的通信——HTTPS原理

为什么HTTPS协议就比HTTP安全呢?一次安全可靠的通信应该包含什么东西呢,这篇文章我会尝试讲清楚这些细节。Alice与Bob的通信...

为什么有的网站没有使用https(为什么有的网站点不开)

有的网站没有使用HTTPS的原因可能涉及多个方面,以下是.com、.top域名的一些见解:服务器性能限制:HTTPS使用公钥加密和私钥解密技术,这要求服务器具备足够的计算能力来处理加解密操作。如果服务...

HTTPS是什么?加密原理和证书。SSL/TLS握手过程

秘钥的产生过程非对称加密...

图解HTTPS「转」(图解http 完整版 彩色版 pdf)

我们都知道HTTPS能够加密信息,以免敏感信息被第三方获取。所以很多银行网站或电子邮箱等等安全级别较高的服务都会采用HTTPS协议。...

HTTP 和 HTTPS 有何不同?一文带你全面了解

随着互联网时代的高速发展,Web服务器和客户端之间的安全通信需求也越来越高。HTTP和HTTPS是两种广泛使用的Web通信协议。本文将介绍HTTP和HTTPS的区别,并探讨为什么HTTPS已成为We...

HTTP与HTTPS的区别,详细介绍(http与https有什么区别)

HTTP与HTTPS介绍超文本传输协议HTTP协议被用于在Web浏览器和网站服务器之间传递信息,HTTP协议以明文方式发送内容,不提供任何方式的数据加密,如果攻击者截取了Web浏览器和网站服务器之间的...

一文让你轻松掌握 HTTPS(https详解)

一文让你轻松掌握HTTPS原文作者:UC国际研发泽原写在最前:欢迎你来到“UC国际技术”公众号,我们将为大家提供与客户端、服务端、算法、测试、数据、前端等相关的高质量技术文章,不限于原创与翻译。...

如何在Spring Boot应用程序上启用HTTPS?

HTTPS是HTTP的安全版本,旨在提供传输层安全性(TLS)[安全套接字层(SSL)的后继产品],这是地址栏中的挂锁图标,用于在Web服务器和浏览器之间建立加密连接。HTTPS加密每个数据包以安全方...

一文彻底搞明白Http以及Https(http0)

早期以信息发布为主的Web1.0时代,HTTP已可以满足绝大部分需要。证书费用、服务器的计算资源都比较昂贵,作为HTTP安全扩展的HTTPS,通常只应用在登录、交易等少数环境中。但随着越来越多的重要...

取消回复欢迎 发表评论: