源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

Lua下基本的网络编程示例

  • 时间:2022-05-19 21:32 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:Lua下基本的网络编程示例
 Lua是高度灵活的语言,它往往是在多个平台,包括Web应用程序中使用。成立2004年的Kepler社区提供Lua的Web组件开放源码。 虽然,也有使用Lua已经开发了其他的web框架,我们将主要集中在Kepler社区提供的组件。 [b]应用程序和框架[/b] [list] [*]    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 代替。[/*] [/list] 在本教程中,我们会尽量让你可以做更多地了解Lua,它的安装和使用方法,请参考kepler网站 [b]Orbit[/b] Orbit是lua一个MVC Web框架。它彻底抛弃CGILua 的应用,每个应用程序Orbit可以容纳一个单一文件“脚本”的CGILua模式,但是如果想让它分割成多个文件也可以。 所有Orbit应用程序遵循WSAPI协议,所以他们目前正在与Xavante,CGI和FastCGI的一起结合工作。它包括一个发射器,可以很容易推出Xavante实例进行开发。 安装Orbit的最简单方法是使用LuaRocks。 luarocks安装Orbit的安装命令。对于这一点,首先需要先安装LuaRocks。 如果还没有安装所有的依赖,这是应遵循在的Unix / Linux环境设置Orbit的步骤。 [b]安装Apache[/b] 连接到服务器。安装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

[b]安装 LUAROCKS[/b]
$ sudo apt-get install luarocks

安装WSAPI, FCGI, ORBIT, AND XAVANTE
$ sudo luarocks install orbit
$ sudo luarocks install wsapi-xavante
$ sudo luarocks install wsapi-fcgi

[b]建立APACHE2[/b]
$ sudo raj /etc/apache2/sites-available/default

添加下面的 <Directory /var/www/>部分配置文件的这些内容。如果这个部分有一个“AllowOverride None”,那么需要的“None”改为“All”,这样htaccess文件可以覆盖配置。
[u]复制代码[/u] 代码如下:
<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。
[u]复制代码[/u] 代码如下:
Options +ExecCGI DirectoryIndex index.ws
[b]简单的例子- Orbit[/b]
[u]复制代码[/u] 代码如下:
#!/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/ ,应该看到
[u]复制代码[/u] 代码如下:
First Page
Orbit 提供了另一种选择,那就是Lua代码可以生成html。
[u]复制代码[/u] 代码如下:
#!/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())
[b]创建表单[/b] 一种简单形式的例子如下所示。
[u]复制代码[/u] 代码如下:
#!/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教程 [b]WSAPI[/b] 如前面提到的,WSAPI充当基础由许多项目嵌入其中的多个特征。可以使用WASAPI并支持以下平台, [list] [*]    Windows[/*] [*]    UNIX-based systems[/*] [/list] 支持的服务器和接口由WSAPI包括: [list] [*]    CGI[/*] [*]    FastCGI[/*] [*]    Xavante[/*] [/list] WSAPI提供了大量的使用Lua库,这使得我们更容易在网络编程。一些支持的功能在Lua包括, [list] [*]    Request processing[/*] [*]    Output buffering[/*] [*]    Authentication[/*] [*]    File uploads[/*] [*]    Request isolation[/*] [*]    Multiplexing[/*] [/list] WSAPI一个简单的例子如下所示。
[u]复制代码[/u] 代码如下:
#!/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页面返回。 [b]Xavante[/b] Xavante是使用基于URI的模块化架构一个Lua1.1的HTTP Web服务器映射处理程序。 Xavante目前提供, [list] [*]    File handler[/*] [*]    Redirect handler[/*] [*]    WSAPI handler[/*] [/list] 文件处理程序是用于一般文件。重定向处理enabes的URI重新映射和WSAPI处理与WSAPI申请。 一个简单的例子如下所示。
[u]复制代码[/u] 代码如下:
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将改为类似。
[u]复制代码[/u] 代码如下:
xavante.HTTP{     server = {host = "*", port = 8080},         defaultHost = {},          virtualhosts = {         ["www.sitename.com"] = simplerules     } }
[b]Lua Web组件[/b] [list] [*]    Copas,基于协程调度器可以使用通过TCP/IP协议的服务器。[/*] [*]    Cosmo, “安全模板”引擎,它可以防止在模板中任意代码的应用程序。[/*] [*]    Coxpcall Lua封装原生pcall和xpcall与协程相容的。[/*] [*]    LuaFileSystem, 可移植的方式来访问底层的目录结构和文件属性。[/*] [*]    Rings, 一个库,它提供了一种从内Lua创建新的Lua状态。[/*] [/list] [b]截至注意[/b] 有这么多Lua基于web框架,并提供给我们,并根据需要组成部分,它可以作为选件。还有包括其他可用的Web框架, [list] [*]    Moonstalk 能够有效地开发和托管建成Lua语言动态生成基于网络的项目;从基本的网页到复杂的应用程序[/*] [*]    Lapis, 构建用MoonScript(或LUA)Web应用程序的框架运行的Nginx的定制版名为OpenResty。[/*] [*]    Lua Server Pages, 一个Lua脚本引擎插件任何其他方法,以嵌入式网络的发展,提供了一个戏剧性的捷径传统的C服务器页面。[/*] [/list] 这些Web框架可以利用Web应用程序,并帮助在做强大的操作。
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部