Lua是高度靈活的語(yǔ)言,它往往是在多個(gè)平臺(tái),包括Web應(yīng)用程序中使用。成立2004年的Kepler社區(qū)提供Lua的Web組件開放源碼。
雖然,也有使用Lua已經(jīng)開發(fā)了其他的web框架,我們將主要集中在Kepler社區(qū)提供的組件。
應(yīng)用程序和框架
- Orbit 是一個(gè)lua的MVC Web框架,它是基于WSAPI。
- WSAPI是從Lua的Web應(yīng)用程序抽象的Web主機(jī)服務(wù)器,是基于許多項(xiàng)目的API。
- Xavante是一個(gè)Lua的Web服務(wù)器,提供了一個(gè)WSAPI接口。
- Sputnik是一個(gè)wiki/CMS開發(fā)過WSAPI的Kepler項(xiàng)目用于娛樂和搞笑。
- CGILua提供LuaPages和LuaScripts網(wǎng)頁(yè)制作的基礎(chǔ)上的WSAPI,但不再支持。使用Orbit, Sputnik 或WSAPI 代替。
在本教程中,我們會(huì)盡量讓你可以做更多地了解Lua,它的安裝和使用方法,請(qǐng)參考kepler網(wǎng)站
Orbit
Orbit是lua一個(gè)MVC Web框架。它徹底拋棄CGILua 的應(yīng)用,每個(gè)應(yīng)用程序Orbit可以容納一個(gè)單一文件“腳本”的CGILua模式,但是如果想讓它分割成多個(gè)文件也可以。
所有Orbit應(yīng)用程序遵循WSAPI協(xié)議,所以他們目前正在與Xavante,CGI和FastCGI的一起結(jié)合工作。它包括一個(gè)發(fā)射器,可以很容易推出Xavante實(shí)例進(jìn)行開發(fā)。
安裝Orbit的最簡(jiǎn)單方法是使用LuaRocks。 luarocks安裝Orbit的安裝命令。對(duì)于這一點(diǎn),首先需要先安裝LuaRocks。
如果還沒有安裝所有的依賴,這是應(yīng)遵循在的Unix / Linux環(huán)境設(shè)置Orbit的步驟。
安裝Apache
連接到服務(wù)器。安裝Apache2,它支持的模塊和能使用所需的Apache2模塊:
$ sudo apt-get install apache2 libapache2-mod-fcgid libfcgi-dev build-essential
$ sudo a2enmod rewrite
$ sudo a2enmod fcgid
$ sudo /etc/init.d/apache2 force-reload
安裝 LUAROCKS
$ sudo apt-get install luarocks
安裝WSAPI, FCGI, ORBIT, AND XAVANTE
$ sudo luarocks install orbit
$ sudo luarocks install wsapi-xavante
$ sudo luarocks install wsapi-fcgi
建立APACHE2
$ sudo raj /etc/apache2/sites-available/default
添加下面的 Directory /var/www/>部分配置文件的這些內(nèi)容。如果這個(gè)部分有一個(gè)“AllowOverride None”,那么需要的“None”改為“All”,這樣htaccess文件可以覆蓋配置。
復(fù)制代碼 代碼如下:
IfModule mod_fcgid.c>
AddHandler fcgid-script .lua
AddHandler fcgid-script .ws
AddHandler fcgid-script .op
FCGIWrapper "/usr/local/bin/wsapi.fcgi" .ws
FCGIWrapper "/usr/local/bin/wsapi.fcgi" .lua
FCGIWrapper "/usr/local/bin/op.fcgi" .op
#FCGIServer "/usr/local/bin/wsapi.fcgi" -idle-timeout 60 -processes 1
#IdleTimeout 60
#ProcessLifeTime 60
/IfModule>
重新啟動(dòng)服務(wù)器,以確保變化生效。
為了使可以訪問應(yīng)用程序,需要+ ExecCGI添加到htaccess文件中的Orbit 應(yīng)用程序的根- 在這種情況下,設(shè)置為 /var/www。
復(fù)制代碼 代碼如下:
Options +ExecCGI
DirectoryIndex index.ws
簡(jiǎn)單的例子- Orbit
復(fù)制代碼 代碼如下:
#!/usr/bin/env index.lua
-- index.lua
require"orbit"
-- declaration
module("myorbit", package.seeall, orbit.new)
-- handler
function index(web)
return my_home_page()
end
-- dispatch
myorbit:dispatch_get(index, "/", "/index")
-- Sample page
function my_home_page()
return [[
head>/head>
html>
h2>First Page/h2>
/html>
]]
end
現(xiàn)在,應(yīng)該可以啟動(dòng)Web瀏覽器并轉(zhuǎn)到http://localhost:8080/ ,應(yīng)該看到
復(fù)制代碼 代碼如下:
First Page
Orbit 提供了另一種選擇,那就是Lua代碼可以生成html。
復(fù)制代碼 代碼如下:
#!/usr/bin/env index.lua
-- index.lua
require"orbit"
function generate()
return html {
head{title "HTML Example"},
body{
h2{"Here we go again!"}
}
}
end
orbit.htmllify(generate)
print(generate())
創(chuàng)建表單
一種簡(jiǎn)單形式的例子如下所示。
復(fù)制代碼 代碼如下:
#!/usr/bin/env index.lua
require"orbit"
function wrap (inner)
return html{ head(), body(inner) }
end
function test ()
return wrap(form (H'table' {
tr{td"First name",td( input{type='text', name='first'})},
tr{td"Second name",td(input{type='text', name='second'})},
tr{ td(input{type='submit', value='Submit!'}),
td(input{type='submit',value='Cancel'})
},
}))
end
orbit.htmllify(wrap,test)
print(test())
你可以在官方網(wǎng)站上找到一個(gè)很長(zhǎng)的orbit教程
WSAPI
如前面提到的,WSAPI充當(dāng)基礎(chǔ)由許多項(xiàng)目嵌入其中的多個(gè)特征??梢允褂肳ASAPI并支持以下平臺(tái),
- Windows
- UNIX-based systems
支持的服務(wù)器和接口由WSAPI包括:
WSAPI提供了大量的使用Lua庫(kù),這使得我們更容易在網(wǎng)絡(luò)編程。一些支持的功能在Lua包括,
- Request processing
- Output buffering
- Authentication
- File uploads
- Request isolation
- Multiplexing
WSAPI一個(gè)簡(jiǎn)單的例子如下所示。
復(fù)制代碼 代碼如下:
#!/usr/bin/env wsapi.cgi
module(..., package.seeall)
function run(wsapi_env)
local headers = { ["Content-type"] = "text/html" }
local function hello_text()
coroutine.yield("html>body>")
coroutine.yield("p>Hello Wsapi!/p>")
coroutine.yield("p>PATH_INFO: " .. wsapi_env.PATH_INFO .. "/p>")
coroutine.yield("p>SCRIPT_NAME: " .. wsapi_env.SCRIPT_NAME .. "/p>")
coroutine.yield("/body>/html>")
end
return 200, headers, coroutine.wrap(hello_text)
end
你可以在一個(gè)簡(jiǎn)單的HTML頁(yè)面組成,回到上面的代碼中看到??梢钥吹絽f(xié)程的使用,使得它可以通過語(yǔ)句返回語(yǔ)句來(lái)調(diào)用函數(shù)。最后HTML狀態(tài)碼(200),頭和HTML頁(yè)面返回。
Xavante
Xavante是使用基于URI的模塊化架構(gòu)一個(gè)Lua1.1的HTTP Web服務(wù)器映射處理程序。 Xavante目前提供,
- File handler
- Redirect handler
- WSAPI handler
文件處理程序是用于一般文件。重定向處理enabes的URI重新映射和WSAPI處理與WSAPI申請(qǐng)。
一個(gè)簡(jiǎn)單的例子如下所示。
復(fù)制代碼 代碼如下:
require "xavante.filehandler"
require "xavante.cgiluahandler"
require "xavante.redirecthandler"
-- Define here where Xavante HTTP documents scripts are located
local webDir = XAVANTE_WEB
local simplerules = {
{ -- URI remapping example
match = "^[^%./]*/$",
with = xavante.redirecthandler,
params = {"index.lp"}
},
{ -- cgiluahandler example
match = {"%.lp$", "%.lp/.*$", "%.lua$", "%.lua/.*$" },
with = xavante.cgiluahandler.makeHandler (webDir)
},
{ -- filehandler example
match = ".",
with = xavante.filehandler,
params = {baseDir = webDir}
},
}
xavante.HTTP{
server = {host = "*", port = 8080},
defaultHost = {
rules = simplerules
},
}
若要使用Xavante虛擬主機(jī),調(diào)用xavante.HTTP將改為類似。
復(fù)制代碼 代碼如下:
xavante.HTTP{
server = {host = "*", port = 8080},
defaultHost = {},
virtualhosts = {
["www.sitename.com"] = simplerules
}
}
Lua Web組件
- Copas,基于協(xié)程調(diào)度器可以使用通過TCP/IP協(xié)議的服務(wù)器。
- Cosmo, “安全模板”引擎,它可以防止在模板中任意代碼的應(yīng)用程序。
- Coxpcall Lua封裝原生pcall和xpcall與協(xié)程相容的。
- LuaFileSystem, 可移植的方式來(lái)訪問底層的目錄結(jié)構(gòu)和文件屬性。
- Rings, 一個(gè)庫(kù),它提供了一種從內(nèi)Lua創(chuàng)建新的Lua狀態(tài)。
截至注意
有這么多Lua基于web框架,并提供給我們,并根據(jù)需要組成部分,它可以作為選件。還有包括其他可用的Web框架,
- Moonstalk 能夠有效地開發(fā)和托管建成Lua語(yǔ)言動(dòng)態(tài)生成基于網(wǎng)絡(luò)的項(xiàng)目;從基本的網(wǎng)頁(yè)到復(fù)雜的應(yīng)用程序
- Lapis, 構(gòu)建用MoonScript(或LUA)Web應(yīng)用程序的框架運(yùn)行的Nginx的定制版名為OpenResty。
- Lua Server Pages, 一個(gè)Lua腳本引擎插件任何其他方法,以嵌入式網(wǎng)絡(luò)的發(fā)展,提供了一個(gè)戲劇性的捷徑傳統(tǒng)的C服務(wù)器頁(yè)面。
這些Web框架可以利用Web應(yīng)用程序,并幫助在做強(qiáng)大的操作。