简介
Usage: APPLICATION COMMAND [OPTIONS]
mojo version
mojo generate lite_app
./myapp.pl daemon -m production -l http://*:8080
./myapp.pl get /foo
./myapp.pl routes -v
Tip: CGI and PSGI environments can be automatically detected very often and
work without commands.
Options (for all commands):
-h, --help Get more information on a specific command
--home Path to home directory of your application, defaults to
the value of MOJO_HOME or auto-detection
-m, --mode Operating mode for your application, defaults to the
value of MOJO_MODE/PLACK_ENV or "development"
Mojolicious::Commands是Mojolicious框架的交互式命令接口。它将自动检测Mojolicious命名空间中的所有可用命令。
可用命令介绍
默认情况下在Mojolicious框架中已经实现的命令会在接下来一一进行简单的介绍。
cgi
$ ./myapp.pl cgi
使用Mojolicious::Command::cgi对象中的CGI 支持启动应用程序,通过是自动检测。
cpanify
$ mojo cpanify -u sri -p secr3t Mojolicious-Plugin-Fun-0.1.tar.gz
使用Mojolicious::Command::cpanify将文件上传到CPAN。
daemon
$ ./myapp.pl daemon
使用Mojolicious::Command::deamon可启动独立的HTTP和WebSocket服务器应用。
eval
$ ./myapp.pl eval 'say app->home'
使用Mojolicious::Command::eval来运行应用程序的代码。
generate
$ mojo generate
$ mojo generate help
$ ./myapp.pl generate help
列出可用的“生成器”命令,和简短的描述。
$ mojo generate help
$ ./myapp.pl generate help
列出具有简短说明的“生成器”命令的可用选项。
generate app
$ mojo generate app
使用Mojolicious::Command::generate::app为全功能的Mojolicious应用程序生成应用程序目录结构。
generate lite_app
$ mojo generate lite_app
使用Mojolicious::Command::generate::lite_app生成一个功能完整的Mojolicious::Lite应用程序。
generate makefile
$ mojo generate makefile
$ ./myapp.pl generate makefile
使用Mojolicious::Command::generate::makefile生成Makefile.PL应用程序文件。
generate plugin
$ mojo generate plugin
使用Mojolicious::Command::generate::plugin来生成一个功能完整的Mojolicious插件的目录结构。
get
$ mojo get http://mojolicious.org
$ ./myapp.pl get /foo
使用Mojolicious::Command::get来执行远程主机或本地应用程序的请求。
help
$ mojo
$ mojo help
$ ./myapp.pl help
列出可用的命令和简短描述。
$ mojo help
$ ./myapp.pl help
列出具有简短描述的命令的可用选项。
inflate
$ ./myapp.pl inflate
使用Mojolicious::Command::inflate将嵌入在应用程序DATA段中的模板和静态文件转换为真实文件。
prefork
$ ./myapp.pl prefork
使用Mojolicious::Command::prefork启动支持pre-forking 的 HTTP和WebSocket服务器。
psgi
$ ./myapp.pl psgi
使用Mojolicious::Command::psgi对象中的PSGI 支持启动应用程序,通过是自动检测。
routes
$ ./myapp.pl routes
使用Mojolicious::Command::routes列出应用程序路由。
test
$ ./myapp.pl test
$ ./myapp.pl test t/fun.t
使用Mojolicious::Command::test从t目录运行应用程序的测试。
version
$ mojo version
$ ./myapp.pl version
使用Mojolicious::Command::version显示可用的核心和可选模块的版本信息,对调试非常有用。
属性
hint
my $hint = $commands->hint;
$commands = $commands->hint('Foo');
列出可用命令后显示的简短提示。
message
my $msg = $commands->message;
$commands = $commands->message('Hello World!');
列出可用命令之前显示的短使用信息。
namespaces
my $namespaces = $commands->namespaces;
$commands = $commands->namespaces(['MyApp::Command']);
从哪个命令空间来加载命令,默认为Mojolicious::Command。
# Add another namespace to load commands from
push @{$commands->namespaces}, 'MyApp::Command';
方法
Mojolicious::Commands继承Mojolicious::Command中的所有方法,并实现以下方法。
detect
my $env = $commands->detect;
尝试检测运行环境,如果没有检测到的话返回undef。
run
$commands->run;
$commands->run(@ARGV);
加载并运行命令。可以使用MOJO_NO_DETECT环境变量禁用自动部署环境检测。
start_app
Mojolicious::Commands->start_app('MyApp');
Mojolicious::Commands->start_app(MyApp => @ARGV);
从指定的类中加载应用程序,并从命令行中启动它。
注:选项-h/ --help,--home和-m/ --mode,被所有命令共享,将在编译时从解析@ARGV得到。
# Always start daemon for application
Mojolicious::Commands->start_app('MyApp', 'daemon', '-l', 'http://*:8080');