Use esta aplicación de esqueleto para configurar rápidamente y comenzar a trabajar en una nueva aplicación Slim Framework 3 (probada con Slim 3.12). Esta aplicación maneja HTTP y solicitudes de línea de comandos. Esta aplicación se envía con algunos proveedores de servicios y un middleware de sesión fuera de la caja. Soporte para la resolución del contenedor y el cableado automático.
Para eliminar un proveedor de servicios, comente en el archivo config/app.php y elimínelo de composer.json, actualice el compositor.
Proveedores de servicios disponibles:
Middleware disponible:
Ejecute este comando desde el directorio en el que desea instalar su nueva aplicación Slim Framework.
php composer.phar create-project jupitern/slim3-skeleton [my-app-name]
Reemplace [my-app-name] con el nombre del directorio deseado para su nueva aplicación. Querrás:
public/ directorio de su nueva aplicación.storage/ sea web en la web.$ cd [my-app-name]public$ php -S localhost:8080 o $ composer serveapp : Código de aplicación (modelos, controladores, comandos de CLI, manejadores, middleware, proveedores de servicios y otros)config : archivos de configuración como DB, correo, rutas ...lib : Otras clases de proyectos como UTILS, Lógica de negocios y extensiones de marcostorage : archivos de registro, archivos de caché y sus activos sin procesar y no compilados como Less, Sass o JavaScript.public : el directorio público contiene archivo index.php , activos como imágenes, javascript y CSSviews : Vistas Archivos de plantilla.vendor : dependencias del compositorLa clase de aplicaciones tiene un método de resolución de ruta que:
Ejemplo de definición de dos rutas para un sitio web y carpetas de backend:
use Psr Http Message ServerRequestInterface as Request ;
use Psr Http Message ResponseInterface as Response ;
// simple route example
$ app -> get ( ' /welcome/{name} ' , function ( Request $ request , Response $ response , $ args ) {
$ name = $ request -> getAttribute ( ' name ' );
$ response -> getBody ()-> write ( " Hello, $ name " );
return $ response ;
});
// example route to resolve request to uri '/' to AppHttpSiteWelcome::index
$ app -> any ( ' / ' , function ( $ request , $ response , $ args ) use ( $ app ) {
return $ app -> resolveRoute ([ App Http Welcome::class, " index " ], $ args );
});
// example calling http://localhost:8080/index.php/test/nuno with the route bellow
// injects the :name param value into the method $name parameter
// Other parameters in the method will be searched in the container by classname or automatically resolved
// in this example the resolveRoute method will create a user instance and inject it in the controller method
$ app -> any ( ' /test[/{name}] ' , function ( $ request , $ response , $ args ) use ( $ app ) {
return $ app -> resolveRoute ([ App Http Welcome::class, " method " ], $ args );
});
namespace App Http ;
use Jupitern Slim3 App Http Controller ;
class Welcome extends Controller
{
public function method ( $ name , App Model User $ user )
{
return get_class ( $ user ). " <br/>name = { $ name }" ;
}
}Cómo crear un nuevo comando:
Ejemplo:
Clase de comando:
namespace App Console ;
class Test extends Command
{
public function method ( $ a , $ b = ' foobar ' )
{
return
"n Entered console command with params: n" .
" a= { $ a }n" .
" b= { $ b }n" ;
}
}Ejecutar la clase: Método desde la línea de comandos:
// since param "b" is optional you can use one of the following commands
> php cli.php Test method a=foo b=bar
> php cli.php Test method a=fooObtener una instancia de aplicación
$ app = Lib Framework App:: instance ();
// or simpler using a helper function
$ app = app ();Depurar una variable, matriz u objeto utilizando la función de depuración
debug ([ ' a ' , ' b ' , ' c ' ]);
// or debug and exit passing true as second param
debug ([ ' a ' , ' b ' , ' c ' ], true );Lea un usuario de DB utilizando el proveedor de servicios de Laravel elocuente
$ user = App Model User:: find ( 1 );
echo $ user -> Name ;Envíe un correo electrónico utilizando el servicio de proveedor de servicios de PhPMailer llamado 'Mail' en el archivo de configuración
/* @var $mail PHPMailerPHPMailerPHPMailer */
$ mail = app ()-> resolve ( ' mail ' );
$ mail -> addAddress ( ' [email protected] ' );
$ mail -> Subject = " test " ;
$ mail -> Body = " <b>test body</b> " ;
$ mail -> AltBody = " alt body " ;
$ mail -> send ();Enumere un contenido de directorio con el proveedor de servicios de FlySystem llamado 'FS_LOCAL' en el archivo de configuración
$ filesystem = app ()-> resolve ( ' fs_local ' );
$ contents = $ filesystem -> listContents ( STORAGE_PATH , true );
var_dump ( $ contents );Escriba y lea de la sesión utilizando la clase Session Helper
// save user info in session
Jupitern Slim3 Utils Session:: set ( ' user ' , [ ' id ' => ' 1 ' ]);
// get user info from session
$ uservar = Jupitern Slim3 Utils Session:: get ( ' user ' );
var_dump ( $ uservar );Escriba y lea desde Cache con el proveedor de servicios de Redis llamado 'Redis' en el archivo de configuración
/** @var JupiternSlim3UtilsRedis $cache */
$ cache = app ()-> resolve ( ' redis ' );
$ cache -> set ( " cacheKey " , " some test value " );
echo $ cache -> get ( " cacheKey " );V3.0
v2.6
V2.5
Jupitern/Slim3-Skeleton se libera bajo la licencia MIT.