The tutorial column of Laravel will take you through the pipeline in Laravel and share an example of using the pipeline in Laravel. I hope it will be helpful to everyone!
Introduces the actual use of pipelines from a code perspective. There is a lot of information about pipelines on the Internet, so check it out by yourself. This blog uses pipelines to process names to achieve unified processing.
background: There are many introductions to the use of pipelines that can be found at present. Most of them only focus on introduction and guidance, and there are not many parts that really go deep into the code. According to the introduction, there are certain obstacles to using pipelines. Here is a detailed code example on using pipelines for reference only. This introduction is a code excerpt of the process that I actually used. I tested it myself and it is actually usable. Just to attract attention, don't criticize if you don't like it.
Router part
Route::get('/pipe', ['as'=>'pipe', 'uses'=>'PipeController@index']);
Control code
<?php namespace App\Http\Controllers; use App\Pipes\LeftWords; use App\Pipes\RightWords; use App\Pipes\BothSidesWords; use Illuminate\Http\Request; use Illuminate\Pipeline\Pipeline; use App\User; use Illuminate\Support\Str; use Illuminate\Support\Facades\Hash; class PipeController extends Controller { /* 定义管道 * * 第一步处理 * 第二部处理 * 第三部处理 * */ protected $pipes = [ LeftWords::class, RightWords::class, BothSidesWords::class, ]; // 首页 public function index(Request $request){ $name = $request->input('name'); // $name = Str::random(10); return app(Pipeline::class) ->send($name) ->through($this->pipes) ->then(function ($content) { return User::create([ 'name' => $content, 'email'=>Str::random(10).'@gmail.com', 'password'=>Hash::make('password'), ]); }); } }
The directory structure is as follows:
├─app │ │ User.php │ ├─Http │ │ ... │ │ │ ├─Models │ │ ... │ │ │ ├─Pipes │ │ │ BothSidesWords.php │ │ │ LeftWords.php │ │ │ RightWords.php │ │ │ │ │ └─Contracts │ │ PipeContracts.php
code of interface
The code under the path app/Pipes/Contracts/Pipe.php
is as follows:
<?php namespace App\Pipes\Contracts; use Closure; interface PipeContracts { public function handle($body, Closure $next); }
The code of the three pipe classesLeftWords.php
The code of
<?php namespace App\Pipes; use App\Pipes\Contracts\PipeContracts; use Closure; class LeftWords implements PipeContracts{ public function handle($body, Closure $next) { // TODO: Implement handle() method. $body = 'left-'.$body; return $next($body); } }
LeftWords.php
The code of <?php namespace App\Pipes; use App\Pipes\Contracts\PipeContracts; use Closure; class RightWords implements PipeContracts{ public function handle($body, Closure $next) { // TODO: Implement handle() method. $body = $body.'-right'; return $next($body); } }
BothSidesWords.php
The code of <?php namespace App\Pipes; use App\Pipes\Contracts\PipeContracts; use Closure; class BothSidesWords implements PipeContracts{ public function handle($body, Closure $next) { // TODO: Implement handle() method. $body = '['.$body.']'; return $next($body); } }
Here we use the pipe default methodhandle
, you can customize the method name. Define myHandleMethod
as the name of the processing method as follows.
return app(Pipeline::class) ->send($name) ->through($this->pipes) ->via('myHandleMethod') ->then(function ($content) { return User::create([ 'name' => $content, 'email'=>Str::random(10).'@gmail.com', 'password'=>Hash::make('password'), ]); });
After you define it like this, modify your interface
and modify your implementation class at the same time.
After accessing http://localhost/pipe?name=lisa
, the obtained results can be successfully printed. User
In the table, there is data saved successfully.
{ "name": "[left-lisa-right]", "email": "3riSrDuBFv@gmail.com", "updated_at": "2020-09-05T05:57:14.000000Z", "created_at": "2020-09-05T05:57:14.000000Z", "id": 15 }
For more programming-related knowledge, please visit: Programming Video! !
The above is the detailed content of Learn how to use pipelines in Laravel through examples. For more information, please follow other related articles on the PHP Chinese website!