Categories
Lua

Lua-Web编程

Lua-网络编程


Lua是一种高度灵活的语言,通常在包括Web应用程序在内的多个平台中使用。开普勒社区成立于2004年,旨在在Lua中提供开源Web组件。

即使使用Lua开发了其他Web框架,我们也将主要关注开普勒社区提供的组件。

应用程序和框架

  • Orbit是基于WSAPI的Lua的MVC Web框架。

  • WSAPI是从Lua Web应用程序抽象Web主机服务器的API,并且是许多项目的基础。

  • Xavante是提供WSAPI接口的Lua Web服务器。

  • Sputnik是在Kepler Project上通过WSAPI开发的Wiki / CMS,用于幽默和娱乐。

  • CGILua提供了基于WSAPI的LuaPages和LuaScripts网页创建功能,但不再受支持。请改用Orbit,Sputnik或WSAPI。

在本教程中,我们将尝试使您了解Lua可以做什么,并进一步了解Lua的安装和使用方法,请访问kepler网站。

轨道

Orbit是Lua的MVC Web框架。它完全放弃了CGILua的“脚本”模型,而使用了应用程序,每个Orbit应用程序都可以放在一个文件中,但是您可以根据需要将其拆分为多个文件。

所有Orbit应用程序都遵循WSAPI协议,因此它们当前与Xavante,CGI和Fastcgi一起使用。它包含一个启动器,可轻松启动Xavante实例进行开发。

安装Orbit的最简单方法是使用LuaRocks。 Luarocks install 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和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添加到Orbit应用程序根目录中的.htaccess文件中-在本例中为/ 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 [[
      
      
         <h2>First Page</h2>
      
   ]]
    
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.htmlify(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.htmlify(wrap,test)

print(test())

WSAPI

如前所述,WSAPI是许多项目的基础,并且内嵌了多个功能。您可以使用WSAPI并支持以下平台,

  • 视窗
  • 基于UNIX的系统

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

  • CGI
  • 快速CGI
  • Xavante

WSAPI提供了许多库,这使我们使用Lua进行Web编程更加容易。 Lua支持的某些功能包括:

  • 要求处理
  • 输出缓冲
  • 认证方式
  • 文件上传
  • 请求隔离
  • 多路复用

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页面已形成并返回。您会看到协程的用法,这使得可以将逐条语句返回给调用函数。最后,返回html状态码(200),标题和html页面。

Xavante

Xavante是一个Lua HTTP 1.1 Web服务器,它使用基于URI映射处理程序的模块化体系结构。 Xavante当前提供,

  • 文件处理程序
  • 重定向处理程序
  • WSAPI处理程序

文件处理程序用于常规文件。重定向处理程序启用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语言构建的动态生成的基于Web的项目;从基本页面到复杂的应用程序。

  • Lapis是使用MoonScript(或Lua)构建Web应用程序的框架,该框架在Nginx的自定义版本OpenResty中运行。

  • Lua Server Pages是一个Lua脚本引擎插件,它取代了任何其他嵌入式Web开发方法,它为传统的C服务器页面提供了一个显着的捷径。

这些Web框架可以利用您的Web应用程序并帮助您进行强大的操作。

蜀ICP备20006366号
error: 内容受到保护 !!