Lua - programowanie internetowe

Lua to bardzo elastyczny język i często jest używany na wielu platformach, w tym w aplikacjach internetowych. Społeczność Kepler, która powstała w 2004 roku w celu dostarczania komponentów internetowych typu open source w Lua.

Chociaż istnieją inne frameworki internetowe wykorzystujące Lua, które zostały opracowane, skupimy się głównie na komponentach dostarczonych przez społeczność Kepler.

Aplikacje i ramy

  • Orbit jest frameworkiem sieciowym MVC dla Lua, opartym na WSAPI.

  • WSAPI jest interfejsem API, który oddziela serwer hosta WWW od aplikacji internetowych Lua i jest podstawą wielu projektów.

  • Xavante to serwer WWW Lua, który oferuje interfejs WSAPI.

  • Sputnik jest wiki / CMS stworzonym przez WSAPI w Kepler Project, używanym do humoru i rozrywki.

  • CGILuaoferuje tworzenie stron internetowych LuaPages i LuaScripts w oparciu o WSAPI, ale nie jest już obsługiwane. Zamiast tego użyj Orbit, Sputnik lub WSAPI.

W tym samouczku postaramy się, abyś zrozumiał, co może zrobić Lua i aby dowiedzieć się więcej o jego instalacji i użytkowaniu, polecić keplerowi stronę internetową

Orbita

Orbit to platforma internetowa MVC dla Lua. Całkowicie rezygnuje z modelu „skryptów” CGILua na rzecz aplikacji, w których każda aplikacja Orbit może zmieścić się w jednym pliku, ale jeśli chcesz, możesz podzielić ją na wiele plików.

Wszystkie aplikacje Orbit są zgodne z protokołem WSAPI, więc obecnie współpracują z Xavante, CGI i Fastcgi. Zawiera program uruchamiający, który ułatwia uruchamianie instancji Xavante w celu rozwoju.

Najłatwiejszym sposobem zainstalowania Orbit jest użycie LuaRocks. Luarocks install orbit to polecenie instalacji. W tym celu musisz najpierw zainstalować LuaRocks .

Jeśli nie zainstalowałeś wszystkich zależności, oto kroki, które należy wykonać, aby skonfigurować Orbit w środowisku Unix / Linux.

Instalowanie Apache

Połącz się ze swoim serwerem. Zainstaluj Apache2, jego moduły pomocnicze i włącz wymagane moduły Apache2 za pomocą -

$ 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

Zainstaluj LuaRocks

$ sudo apt-get install luarocks

Zainstaluj WSAPI, FCGI, Orbit i Xavante

$ sudo luarocks install orbit
$ sudo luarocks install wsapi-xavante
$ sudo luarocks install wsapi-fcgi

Konfigurowanie Apache2

$ sudo raj /etc/apache2/sites-available/default

Dodaj tę sekcję poniżej sekcji <Directory / var / www /> pliku konfiguracyjnego. Jeśli w tej sekcji znajduje się opcja „AllowOverride None”, należy zmienić „None” na „All”, aby plik .htaccess mógł lokalnie zastąpić konfigurację.

<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>

Zrestartuj serwer, aby upewnić się, że wprowadzone zmiany zostały wprowadzone.

Aby włączyć swoją aplikację, musisz dodać + ExecCGI do pliku .htaccess w katalogu głównym aplikacji Orbit - w tym przypadku / var / www.

Options +ExecCGI
DirectoryIndex index.ws

Prosty przykład - orbita

#!/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

Teraz powinieneś być w stanie uruchomić przeglądarkę internetową. Idź do http: // localhost: 8080 / i powinieneś zobaczyć następujące dane wyjściowe -

First Page

Orbit udostępnia inną opcję, tj. Kod Lua może generować 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())

Tworzenie formularzy

Poniżej przedstawiono prosty przykład formularza -

#!/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

Jak wspomniano wcześniej, WSAPI działa jako baza dla wielu projektów i zawiera wiele wbudowanych funkcji. Możesz używać WSAPI i obsługiwać następujące platformy,

  • Windows
  • Systemy oparte na UNIX

Obsługiwane serwery i interfejsy przez WSAPI obejmują,

  • CGI
  • FastCGI
  • Xavante

WSAPI udostępnia szereg bibliotek, co ułatwia nam programowanie w sieci przy użyciu Lua. Niektóre z obsługiwanych funkcji w Lua obejmują:

  • Przetwarzanie żądania
  • Buforowanie wyjściowe
  • Authentication
  • Przesyłanie plików
  • Poproś o izolację
  • Multiplexing

Poniżej przedstawiono prosty przykład 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

Możesz zobaczyć w powyższym kodzie, że tworzona i zwracana jest prosta strona HTML. Możesz zobaczyć użycie coroutines, które umożliwiają zwracanie instrukcji po instrukcji do funkcji wywołującej. Na koniec zwracany jest kod statusu html (200), nagłówki i strona html.

Xavante

Xavante to serwer WWW Lua HTTP 1.1, który wykorzystuje architekturę modułową opartą na obsłudze mapowanych na URI. Xavante obecnie oferuje,

  • Obsługa plików
  • Moduł obsługi przekierowań
  • Program obsługi WSAPI

Obsługa plików jest używana dla plików ogólnych. Moduł obsługi przekierowań umożliwia ponowne mapowanie URI i obsługę WSAPI do obsługi aplikacji WSAPI.

Poniżej przedstawiono prosty przykład.

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
   },
}

Aby używać wirtualnych hostów z Xavante, wywołanie xavante.HTTP zostanie zmienione na coś takiego:

xavante.HTTP{
   server = {host = "*", port = 8080},
    
   defaultHost = {},
    
   virtualhosts = {
      ["www.sitename.com"] = simplerules
   }
}

Lua Web Components

  • Copas, dyspozytor oparty na programach, które mogą być używane przez serwery TCP / IP.

  • Cosmo, mechanizm „bezpiecznych szablonów”, który chroni aplikację przed dowolnym kodem w szablonach.

  • Coxpcall hermetyzuje natywne lua pcall i xpcall z kompatybilnymi z coroutine.

  • LuaFileSystem, przenośny sposób dostępu do podstawowej struktury katalogów i atrybutów plików.

  • Rings, biblioteka umożliwiająca tworzenie nowych stanów Lua z poziomu Lua.

Uwaga końcowa

Dostępnych jest tak wiele frameworków internetowych i komponentów opartych na Lua, które w zależności od potrzeb można wybrać. Dostępne są inne frameworki internetowe, które obejmują:

  • Moonstalkumożliwia wydajne tworzenie i hosting dynamicznie generowanych projektów internetowych zbudowanych w języku Lua; od podstawowych stron po złożone aplikacje.

  • Lapis, framework do tworzenia aplikacji internetowych przy użyciu MoonScript (lub Lua), który działa w dostosowanej wersji Nginx o nazwie OpenResty.

  • Lua Server Pages, wtyczka do silnika skryptów Lua, która odrzuca wszelkie inne podejście do wbudowanego tworzenia stron internetowych, oferuje radykalne skróty do tradycyjnych stron serwera C.

Te platformy internetowe mogą wykorzystywać aplikacje internetowe i pomagać w wykonywaniu zaawansowanych operacji.