찾다
PHP 프레임워크LaravelLaravel 5.1 프레임워크에서 커스텀 Artisan 콘솔 명령을 생성하는 방법

laravel 초보자의 경우 laravel에서 사용자 정의 Artisan 콘솔 명령을 생성하는 방법에 대해 잘 알지 못할 수도 있습니다. 다음 기사에서는 laravel 프레임워크에서 사용자 정의 Artisan 콘솔 명령을 생성하는 예를 공유합니다.

1. 시작하기

Laravel은 브라우저가 아닌 비즈니스 로직을 처리하기 위해 Artisan을 통해 강력한 콘솔 명령을 제공합니다. Laravel에서 모든 Artisan 명령을 보려면 프로젝트 루트 디렉터리에서 실행할 수 있습니다:

php artisan list

해당 출력은 다음과 같습니다(일부 스크린샷):

Laravel 5.1 프레임워크에서 커스텀 Artisan 콘솔 명령을 생성하는 방법

우리는 마이그레이션 make:migration 생성 및 마이그레이션 마이그레이션 실행, 모델 make:model 생성, 컨트롤러 make:controller 생성 등과 같은 일부 이름에 이미 익숙합니다.

특정 명령어의 구체적인 사용법을 확인하고 싶다면, 예를 들어 Artisan 명령어 make:console의 구체적인 사용법을 확인하고 싶다면 다음 명령어를 사용할 수 있습니다: #🎜🎜 #

php artisan help make:console

해당 출력은 다음과 같습니다.

Laravel 5.1 프레임워크에서 커스텀 Artisan 콘솔 명령을 생성하는 방법

2 명령 생성 # 🎜🎜#Artisan은 풍부한 콘솔 명령을 제공하는 것 외에도 make:console 명령을 통해 자체 콘솔 명령을 생성할 수도 있습니다. 위에서 우리는 make:console의 사용법을 확인하기 위해 help 명령을 사용했습니다. 이 경로로 가서 알아봅시다: 명령을 생성하고 실행하여 원하는 다양한 결과를 얻습니다.

먼저 다음과 같이 Artisan 명령을 사용하여 Hello LaravelAcademy를 ​​인쇄하는 가장 간단한 명령을 만듭니다:

php artisan make:console HelloLaravelAcademy --command=laravel:academy

여기서 HelloLaravelAcademy는 명령 이름이고 laravel:academy는 다음에 의해 실행되는 명령입니다. make:console과 유사한 콘솔입니다.

실행이 완료된 후 HelloLaravelAcademy.php 파일이 app/Console/Commands 디렉터리에 생성됩니다:

<?php
namespace App\Console\Commands;
use Illuminate\Console\Command;
class HelloLaravelAcademy extends Command
{
    /**
     * The name and signature of the console command.
     *
     * @var string
     */
    protected $signature = &#39;laravel:academy&#39;;
    /**
     * The console command description.
     *
     * @var string
     */
    protected $description = &#39;Command description.&#39;;
    /**
     * Create a new command instance.
     *
     * @return void
     */
    public function __construct()
    {
        parent::__construct();
    }
    /**
     * Execute the console command.
     *
     * @return mixed
     */
    public function handle()
    {
        //
    }
}

여기서 $signature는 실행된 명령의 이름입니다. 콘솔에서 $description은 명령 설명이고, 핸들 메서드는 명령을 실행할 때 호출되는 메서드입니다.

다음으로 핸들 메소드를 다음과 같이 작성합니다:

public function handle()
{
    echo "Hello LaravelAcademy\n";
}

좋아요, 가장 간단한 명령이 작성되었습니다. 이를 실행하고 콘솔에 출력하는 방법은 " 안녕하세요 라라벨 아카데미"?

3. 명령 실행

명령을 실행하기 전에 AppConsoleKernel의 $commands 속성에 등록해야 합니다.

protected $commands = [
     ...  //其他命令类
     \App\Console\Commands\HelloLaravelAcademy::class
];
# 🎜🎜#다음으로 콘솔에서 다음 Artisan 명령을 실행할 수 있습니다:

php artisan laravel:academy

터미널은 다음을 인쇄할 것입니다:

Hello LaravelAcademy

매우 간단하지 않나요?

4. 더 다양한 입출력

물론 위의 경우는 입력이 없고 하드코딩된 출력이 있는 가장 간단한 경우입니다. 실제 환경에서는 더 복잡한 요구 사항과 더 다양한 입력 및 출력이 있습니다. 아래에서 하나씩 논의해 보겠습니다.

입력 정의

위에서 언급했듯이 $signature 속성을 수정하여 입력 매개변수와 옵션을 정의할 수 있습니다. 위의 Hello를 사용하십시오. 다음 문자열은 입력 매개변수에 의해 제어되도록 조정됩니다. $signature를 다음과 같이 수정할 수 있습니다.

protected $signature = &#39;laravel:academy {name}&#39;;

이 정의는 name이 필수 매개변수임을 의미합니다. #🎜🎜 #
{name?} //可选参数
{name=LaravelAcademy} //默认name值为LaravelAcademy

프로그램의 견고성을 높이기 위해 이름을 기본값으로 수정했습니다.

protected $signature = &#39;laravel:academy {name=LaravelAcademy}&#39;;

때때로 다음과 같은 경우 몇 가지 옵션도 전달합니다. 구두점을 표시할지 여부와 같은 명령을 실행하면(쓸모없지만 테스트용일 뿐임) 다음과 같이 $signature 속성을 수정할 수 있습니다.

protected $signature = &#39;laravel:academy {name=LaravelAcademy} {--mark}&#39;;

If --mark가 전달됩니다. 명령을 호출하면 값이 true이고 그렇지 않으면 false라는 의미입니다. 입력 시 사용자가 옵션 값을 설정하면 $signature는 다음과 같이 정의할 수 있습니다.

protected $signature = &#39;laravel:academy {name=LaravelAcademy} {--mark=}&#39;;

이런 식으로 , 사용자는 옵션을 전달할 때 =를 통해 옵션에 값을 할당할 수 있습니다. 물론 매개변수와 마찬가지로 옵션에 대한 기본값을 지정할 수도 있습니다.

protected $signature = &#39;laravel:academy {name=LaravelAcademy} {--mark=!}&#39;;

입력 받기

입력 매개변수와 옵션을 정의한 후 해당 값을 어떻게 얻나요? Laravel은 이에 상응하는 메소드를 제공합니다. IlluminateConsoleCommand의 인수 메서드를 통해 매개변수 값을 얻을 수 있습니다.

$name = $this->argument(&#39;name&#39;);

인수 메서드가 매개변수 없이 호출되면 모든 매개변수 값의 배열이 됩니다. 돌아왔다.

IlluminateConsoleCommand의 옵션 메소드를 통해 옵션 값을 얻을 수 있습니다:

$mark = $this->option(&#39;mark&#39;);

마찬가지로 매개변수 없이 옵션 메소드를 호출하면 모든 옵션 값의 배열이 반환됩니다.

이 방법으로 HelloLaravelAcademy의 핸들 메소드를 다음과 같이 수정할 수 있습니다:

public function handle()
{
    $name = $this->argument(&#39;name&#39;);
    $mark = $this->option(&#39;mark&#39;);
    $string = 'Hello '.$name;
    if($mark)
        $string .= $mark;
    echo $string."\n";
}

이 방법으로 콘솔에 다음 Artisan 명령을 입력합니다:

php artisan laravel:academy
# 🎜🎜#해당 출력은 다음과 같습니다:

Hello LaravelAcademy!

그런 다음 다음 Artisan 명령을 실행합니다:

php artisan laravel:academy Laravel --mark=?

해당 출력은 다음과 같습니다:

Hello Laravel?

#🎜🎜 #Input 프롬프트

#🎜🎜 #

사용자가 콘솔에 이름을 입력하여 입력 매개변수를 얻도록 허용할 수도 있습니다. 먼저 핸들 방법을 다음과 같이 수정합니다.

public function handle()
{
    $name = $this->ask(&#39;What do you want to say Hello?&#39;);
    echo "Hello ".$name."\n";
}

그런 다음 Enter를 입력합니다. php artisan laravel:academy 터미널의 대화형 페이지는 다음과 같습니다.

비밀번호 등 민감한 정보를 입력하는 경우에는 Ask 메소드 대신 secret을 사용할 수 있습니다.

때때로 사용자의 희망에 따라 계속하거나 중단하도록 선택합니다:

public function handle()
{
    if($this->confirm(&#39;Do you want to continue?[y|n]&#39;)){
        $this->info("Continue");
    }else{
        $this->error("Interrupt");
    }
}

해당 출력은 다음과 같습니다: Laravel 5.1 프레임워크에서 커스텀 Artisan 콘솔 명령을 생성하는 방법

Laravel 5.1 프레임워크에서 커스텀 Artisan 콘솔 명령을 생성하는 방법

除了让用户手动输入外,还可以使用anticipate方法实现自动完成功能:

public function handle()
{
    $name = $this->anticipate(&#39;What is your name?&#39;, [&#39;Laravel&#39;, &#39;Academy&#39;]);
    $this->info($name);
}

当然还可以使用choice方法为用户提供选择避免手动输入,用户只需选择对应索引即可:

public function handle()
{
    $name = $this->choice(&#39;What is your name?&#39;, [&#39;Laravel&#39;, &#39;Academy&#39;]);
    $this->info($name);
}

对应交互页面如下:

Laravel 5.1 프레임워크에서 커스텀 Artisan 콘솔 명령을 생성하는 방법

编写输出

关于输出字符串,上面我们简单使用了echo语句,其实Laravel提供了更为强大和多样化的方法:

public function handle()
{
    $this->info("Successful!");
    $this->error("Something Error!");
    $this->question("What do you want to do?");
    $this->comment("Just Comment it!");
}

执行php artisan laravel:academy对应输出如下:

Laravel 5.1 프레임워크에서 커스텀 Artisan 콘솔 명령을 생성하는 방법

表格

Artisan甚至可以输出表格:

public function handle()
{
    $headers = [&#39;Name&#39;, &#39;Email&#39;];
    $users = \App\User::all([&#39;name&#39;, &#39;email&#39;])->toArray();
    $this->table($headers, $users);
}

执行php artisan laravel:academy对应输出为:

Laravel 5.1 프레임워크에서 커스텀 Artisan 콘솔 명령을 생성하는 방법

进度条

当然对于复杂耗时的命令,进度条是必不可少的,

public function handle()
{
    $this->output->progressStart(10);
    for ($i = 0; $i < 10; $i++) {
        sleep(1);
        $this->output->progressAdvance();
    }
    $this->output->progressFinish();
}

执行php artisan laravel:academy对应输出为:

Laravel 5.1 프레임워크에서 커스텀 Artisan 콘솔 명령을 생성하는 방법

5、从CLI之外调用Artisan

除了在控制台执行Artisan命令之外,还可以通过代码在别处调用Artisan命令,比如其它Artisan命令、控制器、路由或其他。

路由

在路由闭包中我们可以通过Artisan门面的call方法来调用本节创建的命令:

//在路由中调用Artisan命令
Route::get(&#39;testArtisan&#39;,function(){
    $exitCode = Artisan::call(&#39;laravel:academy&#39;, [
        &#39;name&#39; => &#39;Laravel学院&#39;, &#39;--mark&#39; => &#39;!&#39;
    ]);
});

其它Artisan命令

在一个Artisan命令中也可以调用另一个Artisan命令,还是通过call方法:

public function handle()
{
    $this->call(&#39;inspire&#39;);
}

如果想要调用一个Artisan命令并阻止其所有输出,可以使用callSilent方法:

public function handle()
{
    $this->callSilent(&#39;inspire&#39;);
}

除此之外,关于Artisan命令你还应该知道的是我们可以在创建的命令类的控制器或方法中注入任何依赖。这就意味着我们可以在命令类中使用注册到服务容器的所有类。

相关推荐:

laravel框架的启动过程分析

Laravel框架内置的Broadcast功能如何实现与客户端实时通信

위 내용은 Laravel 5.1 프레임워크에서 커스텀 Artisan 콘솔 명령을 생성하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
포용의 환상 : 원격 작업의 고립과 외로움 해결포용의 환상 : 원격 작업의 고립과 외로움 해결Apr 25, 2025 am 12:28 AM

TocombatisolationandloneLinessInremotwork, componiesshouldimplementregular, meignmentfortuncations, andusetechnologyeftically

풀 스택 개발을위한 Laravel : 포괄적 인 가이드풀 스택 개발을위한 Laravel : 포괄적 인 가이드Apr 25, 2025 am 12:27 AM

laravelispopularforfull-stackdevelopmentBecauseItOffersAMESAMLESSEAMLESTBBOCKENDPOWERANDFRONDENDFLECTION.1) itsBackEndCapabilities, likeeloquentorm, simplifydatabaseintercations.2) theBladetemplatingEngineallowsforclean, dynamichtmltemplates.3) larvelmix

화상 회의 대결 : 원격 회의에 적합한 플랫폼 선택화상 회의 대결 : 원격 회의에 적합한 플랫폼 선택Apr 25, 2025 am 12:26 AM

화상 회의 플랫폼을 선택할 때의 주요 요소에는 사용자 인터페이스, 보안 및 기능이 포함됩니다. 1) 사용자 인터페이스는 줌과 같은 직관적이어야합니다. 2) 보안에주의를 기울여야하며 Microsoft Teams는 엔드 투 엔드 암호화를 제공합니다. 3) 기능은 요구 사항을 일치시키기 위해 필요하며 Googlemeet은 짧은 회의에 적합하며 Ciscowebex는 고급 협업 도구를 제공합니다.

최신 Laravel과 호환되는 데이터베이스 버전은 무엇입니까?최신 Laravel과 호환되는 데이터베이스 버전은 무엇입니까?Apr 25, 2025 am 12:25 AM

Laravel10의 최신 버전은 MySQL 5.7 이상, PostgreSQL 9.6 이상, SQLite 3.8.8 이상, SQLServer 2017 이상과 호환됩니다. 이러한 버전은 JSON 데이터 유형 MySQL5.7과 같은 Laravel의 ORM 기능을 지원하여 쿼리 및 스토리지 효율성을 향상시키기 때문에 선택됩니다.

Laravel을 풀 스택 프레임 워크로 사용하는 이점Laravel을 풀 스택 프레임 워크로 사용하는 이점Apr 25, 2025 am 12:24 AM

laravelisanexcellentchoiceforfull-stackdevelopmentduetoitsrobustfeaturesandeaseofuse.1) 1) itsimplifiescomplextaskswithitsmodernphpsyntaxandtoolslakeforfront-endandeloquentormforback-end.2) laravel'secosystem, entercancesancancesancancessancancesancancesancesancesancancesnan

Laravel의 최신 버전은 무엇입니까?Laravel의 최신 버전은 무엇입니까?Apr 24, 2025 pm 05:17 PM

LARAVEL10, RELEARTESTERSION. ISTHELATESTVERSION. ISTHELATESTERSION.ITFEATURES : 1) 개선 된 오류가 개선 된 사람을 사용하여 개선되었습니다.

최신 Laravel 버전은 개발을 어떻게 단순화합니까?최신 Laravel 버전은 개발을 어떻게 단순화합니까?Apr 24, 2025 pm 05:01 PM

thelatestlaravelversionenhancesdevelopmentwith : 1) simplifiedroutingusingiMplicitModelBinding, 2) enloquentCapabilities withNeweRyMethods, 및 3) 개선 된 개선 된 개선 된 kepportOndHefeatureslikeNameDarguments,

최신 Laravel 버전의 릴리스 노트는 어디에서 찾을 수 있습니까?최신 Laravel 버전의 릴리스 노트는 어디에서 찾을 수 있습니까?Apr 24, 2025 pm 04:53 PM

laravel.com/docs에서 최신 Laravel 버전의 릴리스 노트를 찾을 수 있습니다. 1) 릴리스 노트는 새로운 기능, 버그 수정 및 개선에 대한 자세한 정보를 제공합니다. 2) 새로운 기능의 적용을 이해하는 데 도움이되는 예와 설명이 포함되어 있습니다. 3) 새로운 기능의 잠재적 복잡성과 후진 호환성 문제에주의하십시오. 4) 릴리스 노트를 정기적으로 검토하면 업데이트를 유지하고 혁신을 고무시킬 수 있습니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

WebStorm Mac 버전

WebStorm Mac 버전

유용한 JavaScript 개발 도구

SublimeText3 Linux 새 버전

SublimeText3 Linux 새 버전

SublimeText3 Linux 최신 버전

MinGW - Windows용 미니멀리스트 GNU

MinGW - Windows용 미니멀리스트 GNU

이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.