站长资源脚本专栏

Lua下基本的网络编程示例

整理:jimmy2025/1/11浏览2
简介Lua是高度灵活的语言,它往往是在多个平台,包括Web应用程序中使用。成立2004年的Kepler社区提供Lua的Web组件开放源码。虽然,也有使用Lua已经开发了其他的web框架,我们将主要集中在Kepler社区提供的组件。应用程序和框架 Orbit 是一个lua的MVC Web框架,

 Lua是高度灵活的语言,它往往是在多个平台,包括Web应用程序中使用。成立2004年的Kepler社区提供Lua的Web组件开放源码。

虽然,也有使用Lua已经开发了其他的web框架,我们将主要集中在Kepler社区提供的组件。
应用程序和框架

  •     Orbit 是一个lua的MVC Web框架,它是基于WSAPI。
  •     WSAPI是从Lua的Web应用程序抽象的Web主机服务器,是基于许多项目的API。
  •     Xavante是一个Lua的Web服务器,提供了一个WSAPI接口。
  •     Sputnik是一个wiki/CMS开发过WSAPI的Kepler项目用于娱乐和搞笑。
  •     CGILua提供LuaPages和LuaScripts网页制作的基础上的WSAPI,但不再支持。使用Orbit, Sputnik 或WSAPI 代替。

在本教程中,我们会尽量让你可以做更多地了解Lua,它的安装和使用方法,请参考kepler网站
Orbit

Orbit是lua一个MVC Web框架。它彻底抛弃CGILua 的应用,每个应用程序Orbit可以容纳一个单一文件“脚本”的CGILua模式,但是如果想让它分割成多个文件也可以。

所有Orbit应用程序遵循WSAPI协议,所以他们目前正在与Xavante,CGI和FastCGI的一起结合工作。它包括一个发射器,可以很容易推出Xavante实例进行开发。

安装Orbit的最简单方法是使用LuaRocks。 luarocks安装Orbit的安装命令。对于这一点,首先需要先安装LuaRocks。

如果还没有安装所有的依赖,这是应遵循在的Unix / Linux环境设置Orbit的步骤。
安装Apache

连接到服务器。安装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/>部分配置文件的这些内容。如果这个部分有一个“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 应用程序的根- 在这种情况下,设置为 /var/www。

复制代码 代码如下:Options +ExecCGI
DirectoryIndex index.ws

简单的例子- Orbit

复制代码 代码如下:#!/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

现在,应该可以启动Web浏览器并转到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())

你可以在官方网站上找到一个很长的orbit教程
WSAPI

如前面提到的,WSAPI充当基础由许多项目嵌入其中的多个特征。可以使用WASAPI并支持以下平台,

  •     Windows
  •     UNIX-based systems

支持的服务器和接口由WSAPI包括:

  •     CGI
  •     FastCGI
  •     Xavante

WSAPI提供了大量的使用Lua库,这使得我们更容易在网络编程。一些支持的功能在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页面组成,回到上面的代码中看到。可以看到协程的使用,使得它可以通过语句返回语句来调用函数。最后HTML状态码(200),头和HTML页面返回。
Xavante

Xavante是使用基于URI的模块化架构一个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虚拟主机,调用xavante.HTTP将改为类似。

复制代码 代码如下:xavante.HTTP{
    server = {host = "*", port = 8080},
   
    defaultHost = {},
    
    virtualhosts = {
        ["www.sitename.com"] = simplerules
    }
}

Lua Web组件

  •     Copas,基于协程调度器可以使用通过TCP/IP协议的服务器。
  •     Cosmo, “安全模板”引擎,它可以防止在模板中任意代码的应用程序。
  •     Coxpcall Lua封装原生pcall和xpcall与协程相容的。
  •     LuaFileSystem, 可移植的方式来访问底层的目录结构和文件属性。
  •     Rings, 一个库,它提供了一种从内Lua创建新的Lua状态。

截至注意

有这么多Lua基于web框架,并提供给我们,并根据需要组成部分,它可以作为选件。还有包括其他可用的Web框架,

  •     Moonstalk 能够有效地开发和托管建成Lua语言动态生成基于网络的项目;从基本的网页到复杂的应用程序
  •     Lapis, 构建用MoonScript(或LUA)Web应用程序的框架运行的Nginx的定制版名为OpenResty。
  •     Lua Server Pages, 一个Lua脚本引擎插件任何其他方法,以嵌入式网络的发展,提供了一个戏剧性的捷径传统的C服务器页面。

这些Web框架可以利用Web应用程序,并帮助在做强大的操作。