前言
Artisan 是 Laravel 附带的命令行接口。Artisan 以 artisan
脚本的形式存在于应用的根目录,并提供了许多有用的命令,这些命令可以在构建应用时为你提供帮助。
除 Artisan 提供的命令外,你也可以编写自己的自定义命令。 命令在多数情况下位于 app/Console/Commands 目录中; 不过,只要你的命令可以由 Composer 加载,你就可以自由选择自己的存储位置。
前期工作
在开始之前,我们要准备相应的目录和文件。
我们可以使用以下命令快速生成 ServiceMakeCommand.PHP
文件:
PHP artisan make:command ServiceMakeCommand
执行完后会在你的 Console
文件夹下生成 Commands
文件夹和 Commands/ServiceMakeCommand.PHP
文件。
我们还需要在 Commands
文件夹下添加一些文件夹和文件:
结构如下:
- app - Console + - Commands + - stubs + - service.plain.stub + - ServiceMakeCommand.PHP - Kernel.PHP - . - . - .
service.plain.stub
代码:
app/Console/Commands/stubs/service.plain.stub
<?PHP namespace {{ namespace }}; class {{ class }} { // }
我们的前期准备就此结束,是不是很简单?哈哈。
快速开始
接下来我们就直接一把梭哈了,注意改动的代码噢。
我们主要是对着 ServiceMakeCommand.PHP
文件一把梭哈,所以:
app/Console/Commands/ServiceMakeCommand.PHP
<?PHP namespace App\Console\Commands; use Illuminate\Console\GeneratorCommand; class ServiceMakeCommand extends GeneratorCommand { /** * The name and signature of the console command. * * @var string */ protected $signature = 'make:service {name}'; /** * The console command description. * * @var string */ protected $description = 'Create a new service class'; /** * The type of class being generated. * * @var string */ protected $type = 'Service'; /** * Get the stub file for the generator. * * @return string */ protected function getStub() { return __DIR__ . '/stubs/service.plain.stub'; } /** * Get the default namespace for the class. * * @param string $rootNamespace * @return string */ protected function getDefaultNamespace ( $rootnamespace ) { return $rootnamespace . '\Services'; } }
最后,我们执行以下命令快速生成 UserService.PHP
文件:
PHP artisan make:service UserService
结构如下:
- app - Console - Commands - stubs - service.plain.stub - ServiceMakeCommand.PHP - Kernel.PHP + - Services + - UserService.PHP - . - . - .
让我们查看 UserService.PHP
和我们想象中的代码是否一致:
app/Services/UserService.PHP
<?PHP namespace App\Services; class UserService{ // }
恭喜,我们已经做到我们想要的结果了。
总结
虽然我们做得比较简陋,但我们只需稍加改进,就可以让它变得更完善。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。