Maison  >  Article  >  cadre php  >  Comment implémenter l'artisan de Laravel

Comment implémenter l'artisan de Laravel

藏色散人
藏色散人avant
2020-10-22 17:47:432297parcourir

下面由Laravel教程栏目给大家介绍实现 laravel 的artisan 的方法,希望对需要的朋友有所帮助!

laravel 的 artisan 命令行太好用了,换个框架没有这个功能,于是自己学习实现一些,直接上代码

新建目录

-artisan

--bin

--src

进入artisan composer init    

composer require symfony/console

#!/usr/bin/env php
<?php

use Symfony\Component\Console\Application;
use Symfony\Component\Console\Input\InputInterface;
use Symfony\Component\Console\Output\OutputInterface;

require_once __DIR__.&#39;/../vendor/autoload.php&#39;;

$app = new Application(&#39;artisan&#39;,&#39;1.1.1&#39;);

$app->register(&#39;artisan&#39;)->setCode(function(InputInterface $input, OutputInterface $output){
    $output->writeln(&#39;artisan start&#39;);
});

$app->run();

exit();

以上是简单的实现
#!/usr/bin/env php
<?php

use Symfony\Component\Console\Application;
use Symfony\Component\Console\Input\InputInterface;
use Symfony\Component\Console\Output\OutputInterface;
use Symfony\Component\Console\Input\InputArgument;

require_once __DIR__ . &#39;/../vendor/autoload.php&#39;;

$app = new Application(&#39;artisan&#39;, &#39;1.1.1&#39;);

$app->register(&#39;artisan&#39;)
    ->setDescription(&#39;myself artisan description&#39;)
    ->setCode(
        function (InputInterface $input, OutputInterface $output) {
            $name = $input->getArgument(&#39;name&#39;);
            $output->writeln("hello {$name}");
        }
    )->addArgument(&#39;name&#39;, InputArgument::REQUIRED, &#39;please input your name&#39;);

$app->run();

exit();

这里演示了如何接收参数
#!/usr/bin/env php
<?php

use Symfony\Component\Console\Application;
use Symfony\Component\Console\Input\InputInterface;
use Symfony\Component\Console\Output\OutputInterface;
use Symfony\Component\Console\Input\InputArgument;
use Symfony\Component\Console\Input\InputOption;

require_once __DIR__ . &#39;/../vendor/autoload.php&#39;;

$app = new Application(&#39;artisan&#39;, &#39;1.1.1&#39;);

$app->register(&#39;artisan&#39;)
    ->setDescription(&#39;myself artisan description&#39;)
    ->setCode(
        function (InputInterface $input, OutputInterface $output) {
            $string = $input->getOption(&#39;string&#39;);
            $name = $input->getArgument(&#39;name&#39;);
            if($string == &#39;lower&#39;){
                $name = strtolower($name);
            }
            if($string == &#39;upper&#39;){
                $name = strtoupper($name);
            }
            $output->writeln("hello {$name}");
        }
    )->addArgument(&#39;name&#39;, InputArgument::REQUIRED, &#39;please input your name&#39;)
    ->addOption(&#39;string&#39;,null,InputOption::VALUE_OPTIONAL,&#39;转换字符串大小&#39;,&#39;lower&#39;)
;

$app->run();

exit();

这里演示了如何给命令行添加选项 ./bin/artisan.php artisan ffff --string=&#39;upper&#39;   echo  FFFF
$output->writeln("<info>hello {$name}</info>");
$output->writeln("<error>hello {$name}</error>");
$output->writeln("<comment>hello {$name}</comment>");
$output->writeln("hello {$name}");

可以给它们加上颜色

接下来将命令行拆分为文件

bin/artisan.php

ArtisanCommand.php

#!/usr/bin/env php
<?php

use Symfony\Component\Console\Application;
use Artisan\ArtisanCommand;
require_once __DIR__ . &#39;/../vendor/autoload.php&#39;;

$app = new Application(&#39;artisan&#39;, &#39;1.1.1&#39;);

$app->add(new ArtisanCommand());

$app->run();

exit();


ArtisanCommand.php
f7184d4e9c8be36f7965d1cbce408c7bsetName('artisan');
        $this->setDescription('myself artisan description')
        ->addArgument('name', InputArgument::REQUIRED, 'please input your name')
        ->addOption('string',null,InputOption::VALUE_OPTIONAL,'转换字符串大小','lower');
    }

    public function execute(InputInterface $input, OutputInterface $output)
    {
        $string = $input->getOption('string');
        $name = $input->getArgument('name');
        if($string == 'lower'){
            $name = strtolower($name);
        }
        if($string == 'upper'){
            $name = strtoupper($name);
        }
        $output->writeln("861e5d1625be16cce5a3569e3482b67ehello {$name}bbc97313deb00a409dd479bbec5543a1");
        $output->writeln("bbbcc7d749ec7f3e0fb2ba5af34b74a7hello {$name}4c8d80f29f204b22c4490983d39ebac7");
        $output->writeln("6f015a708a781f34e0698e64f5bd90f4hello {$name}ae21f3e2b2506a19cbde269e161e0250");
        $output->writeln("hello {$name}");
    }
}
composer.json
{
    "name": "baidu/artisan",
    "authors": [
        {
            "name": "gaobingbing",
            "email": "v_gaobingbing01@baidu.com"
        }
    ],
    "require": {
        "symfony/console": "^4.3"
    },
    "autoload":  {
        "psr-4": {
            "Artisan\\": "src"
        }
    }
}

至此大功告成,还有其他功能可以去看Symfony文档

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer