Use este aplicativo esqueleto para configurar rapidamente e começar a trabalhar em um novo aplicativo Slim Framework 3 (testado com o Slim 3.12). Este aplicativo lida com solicitações de linha HTTP e de comando. Este aplicativo é enviado com alguns provedores de serviços e um middleware de sessão pronta para uso. Suporte para resolução de contêineres e fiação automática.
Para remover um provedor de serviços, comente no arquivo config/app.php e remova -o do composer.json, atualize o Composer.
Provedores de serviço disponíveis:
Middleware disponível:
Execute este comando no diretório no qual deseja instalar seu novo aplicativo Slim Framework.
php composer.phar create-project jupitern/slim3-skeleton [my-app-name]
Substitua [my-app-name] pelo nome do diretório desejado para o seu novo aplicativo. Você vai querer:
public/ diretório do seu novo aplicativo.storage/ é gravável na Web.$ cd [my-app-name]public$ php -S localhost:8080 ou $ composer serveapp : Código do aplicativo (modelos, controladores, comandos da CLI, manipuladores, middleware, provedores de serviços e outros)config : arquivos de configuração como DB, correio, rotas ...lib : Outras classes de projeto, como UTILS, Lógica de negócios e extensões de estruturastorage : arquivos de log, arquivos de cache e seus ativos brutos e não compilados, como menos, SASS ou JavaScript.public : O Diretório Público contém arquivo index.php , ativos como imagens, JavaScript e CSSviews : visualizações de arquivos de modelo.vendor : dependências do compositorA classe App possui um método de resolvedor de rota que:
Exemplo definindo duas rotas para um site e pastas de back -end:
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 }" ;
}
}Como criar um novo comando:
Exemplo:
Classe 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" ;
}
}Execute a classe: Método da linha de comando:
// 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=fooObtenha a instância do aplicativo
$ app = Lib Framework App:: instance ();
// or simpler using a helper function
$ app = app ();Depure uma variável, matriz ou objeto usando a função de auxiliar de depuração
debug ([ ' a ' , ' b ' , ' c ' ]);
// or debug and exit passing true as second param
debug ([ ' a ' , ' b ' , ' c ' ], true );Leia um usuário do DB usando o provedor de serviços eloqüentes do Laravel
$ user = App Model User:: find ( 1 );
echo $ user -> Name ;Envie um email usando o serviço de provedor de serviços Phpmailer chamado 'Mail' no arquivo de configuração
/* @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 ();Liste um conteúdo de diretório com o provedor de serviços do FlySystem chamado 'fs_local' no arquivo de configuração
$ filesystem = app ()-> resolve ( ' fs_local ' );
$ contents = $ filesystem -> listContents ( STORAGE_PATH , true );
var_dump ( $ contents );Escreva e leia na sessão usando a classe auxiliar de sessão
// 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 );Escreva e leia no cache com o provedor de serviços Redis chamado 'redis' no arquivo de configuração
/** @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-Skleton é liberação sob a licença do MIT.