Lua是高度靈活的語言,它往往是在多個平臺,包括Web應用程序中使用。成立2004年的Kepler社區(qū)提供Lua的Web組件開放源碼。
雖然,也有使用Lua已經(jīng)開發(fā)了其他的web框架,我們將主要集中在Kepler社區(qū)提供的組件。
Orbit 是一個lua的MVC Web框架,它是基于WSAPI。
WSAPI是從Lua的Web應用程序抽象的Web主機服務器,是基于許多項目的API。
Xavante是一個Lua的Web服務器,提供了一個WSAPI接口。
Sputnik是一個wiki/CMS開發(fā)過WSAPI的Kepler項目用于娛樂和搞笑。
CGILua提供LuaPages和LuaScripts網(wǎng)頁制作的基礎(chǔ)上的WSAPI,但不再支持。使用Orbit, Sputnik 或WSAPI 代替。
在本教程中,我們會盡量讓你可以做更多地了解Lua,它的安裝和使用方法,請參考kepler網(wǎng)站
Orbit是lua一個MVC Web框架。它徹底拋棄CGILua 的應用,每個應用程序Orbit可以容納一個單一文件“腳本”的CGILua模式,但是如果想讓它分割成多個文件也可以。
所有Orbit應用程序遵循WSAPI協(xié)議,所以他們目前正在與Xavante,CGI和FastCGI的一起結(jié)合工作。它包括一個發(fā)射器,可以很容易推出Xavante實例進行開發(fā)。
安裝Orbit的最簡單方法是使用LuaRocks。 luarocks安裝Orbit的安裝命令。對于這一點,首先需要先安裝LuaRocks。
如果還沒有安裝所有的依賴,這是應遵循在的Unix / Linux環(huán)境設(shè)置Orbit的步驟。
連接到服務器。安裝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
$ sudo apt-get install luarocks
$ sudo luarocks install orbit $ sudo luarocks install wsapi-xavante $ sudo luarocks install wsapi-fcgi
$ sudo raj /etc/apache2/sites-available/default
添加下面的 <Directory /var/www/>部分配置文件的這些內(nèi)容。如果這個部分有一個“AllowOverride None”,那么需要的“None”改為“All”,這樣htaccess文件可以覆蓋配置。
<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>
重新啟動服務器,以確保變化生效。
為了使可以訪問應用程序,需要+ ExecCGI添加到htaccess文件中的Orbit 應用程序的根- 在這種情況下,設(shè)置為 /var/www。
Options +ExecCGI DirectoryIndex index.ws
#!/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)在,應該可以啟動Web瀏覽器并轉(zhuǎn)到http://localhost:8080/ ,應該看到
First Page
Orbit 提供了另一種選擇,那就是Lua代碼可以生成html。
#!/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())
一種簡單形式的例子如下所示。
#!/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)站上找到一個很長的orbit教程
如前面提到的,WSAPI充當基礎(chǔ)由許多項目嵌入其中的多個特征??梢允褂肳ASAPI并支持以下平臺,
Windows
UNIX-based systems
支持的服務器和接口由WSAPI包括:
CGI
FastCGI
Xavante
WSAPI提供了大量的使用Lua庫,這使得我們更容易在網(wǎng)絡(luò)編程。一些支持的功能在Lua包括,
Request processing
Output buffering
Authentication
File uploads
Request isolation
Multiplexing
WSAPI一個簡單的例子如下所示。
#!/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
你可以在一個簡單的HTML頁面組成,回到上面的代碼中看到??梢钥吹絽f(xié)程的使用,使得它可以通過語句返回語句來調(diào)用函數(shù)。最后HTML狀態(tài)碼(200),頭和HTML頁面返回。
Xavante是使用基于URI的模塊化架構(gòu)一個Lua1.1的HTTP Web服務器映射處理程序。 Xavante目前提供,
File handler
Redirect handler
WSAPI handler
文件處理程序是用于一般文件。重定向處理enabes的URI重新映射和WSAPI處理與WSAPI申請。
一個簡單的例子如下所示。
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虛擬主機,調(diào)用xavante.HTTP將改為類似。
xavante.HTTP{ server = {host = "*", port = 8080}, defaultHost = {}, virtualhosts = { ["www.sitename.com"] = simplerules } }
Copas,基于協(xié)程調(diào)度器可以使用通過TCP/IP協(xié)議的服務器。
Cosmo, “安全模板”引擎,它可以防止在模板中任意代碼的應用程序。
Coxpcall Lua封裝原生pcall和xpcall與協(xié)程相容的。
LuaFileSystem, 可移植的方式來訪問底層的目錄結(jié)構(gòu)和文件屬性。
Rings, 一個庫,它提供了一種從內(nèi)Lua創(chuàng)建新的Lua狀態(tài)。
有這么多Lua基于web框架,并提供給我們,并根據(jù)需要組成部分,它可以作為選件。還有包括其他可用的Web框架,
Moonstalk 能夠有效地開發(fā)和托管建成Lua語言動態(tài)生成基于網(wǎng)絡(luò)的項目;從基本的網(wǎng)頁到復雜的應用程序
Lapis, 構(gòu)建用MoonScript(或LUA)Web應用程序的框架運行的Nginx的定制版名為OpenResty。
Lua Server Pages, 一個Lua腳本引擎插件任何其他方法,以嵌入式網(wǎng)絡(luò)的發(fā)展,提供了一個戲劇性的捷徑傳統(tǒng)的C服務器頁面。
這些Web框架可以利用Web應用程序,并幫助在做強大的操作。