コントローラーに次の 2 行を追加することでバリデータを作成できます。
use Cake\Validation\Validator; $validator = new Validator();
バリデータを作成したら、バリデータ オブジェクトを使用してデータを検証できます。次のコードは、ログイン Web ページのデータを検証する方法を説明しています。
$validator->notEmpty('username', 'We need username.')->add( 'username', 'validFormat', ['rule' => 'email','message' => 'E-mail must be valid']); $validator->notEmpty('password', 'We need password.'); $errors = $validator->errors($this->request->data());
$validator オブジェクトを使用して、最初に notEmpty() メソッドを呼び出します。これにより、ユーザー名が空であってはいけないことが保証されます。その後、add() メソッドを連鎖させて、適切な電子メール形式の検証をもう 1 つ追加しました。
その後、notEmpty() メソッドを使用してパスワード フィールドの検証を追加しました。これにより、パスワード フィールドが空であってはいけないことが確認されます。
次のプログラムに示すように、config/routes.php ファイルを変更します。
config/routes.php
<?php use Cake\Http\Middleware\CsrfProtectionMiddleware; use Cake\Routing\Route\DashedRoute; use Cake\Routing\RouteBuilder; $routes->setRouteClass(DashedRoute::class); $routes->scope('/', function (RouteBuilder $builder) { $builder->registerMiddleware('csrf', new CsrfProtectionMiddleware([ 'httpOnly' => true, ])); $builder->applyMiddleware('csrf'); //$builder->connect('/pages',['controller'=>'Pages','action'=>'display', 'home']); $builder->connect('validation',['controller'=>'Valids','action'=>'index']); $builder->fallbacks(); });
src/Controller/ValidsController.php に ValidsController.php ファイルを作成します。 コントローラー ファイルに次のコードをコピーします。
src/Controller/ValidsController.php
<?php namespace App\Controller; use App\Controller\AppController; use Cake\Validation\Validator; class ValidsController extends AppController{ public function index(){ $validator = new Validator(); $validator->notEmpty('username', 'We need username.')->add( 'username', 'validFormat', ['rule' => 'email','message' => 'E-mail must be valid']); $validator->notEmpty('password', 'We need password.'); $errors = $validator->errors($this->request->getData()); $this->set('errors',$errors); } } ?>
src/Template にディレクトリ Valids を作成し、そのディレクトリの下に index.php. という名前の View ファイルを作成します。そのファイル内の次のコード。
src/Template/Valids/index.php
<?php if($errors) { foreach($errors as $error) foreach($error as $msg) echo '<font color="red">'.$msg.'</font><br>'; } else { echo "No errors."; } echo $this->Form->create(NULL,array('url'=>'/validation')); echo $this->Form->control('username'); echo $this->Form->control('password'); echo $this->Form->button('Submit'); echo $this->Form->end(); ?>
次の URL にアクセスして、上記の例を実行します -
http://localhost/cakephp4/validation
何も入力せずに送信ボタンをクリックしてください。次の出力が表示されます。
http クライアントは、GET、POST、PUT などのリクエストを行うために使用できます。
http クライアントを使用するには、次の行を追加します -
use Cake\Http\Client;
HTTP クライアントの動作を理解するために例に取り組んでみましょう。
指定した http URL からデータを取得するには、次のように実行できます -
$response = $http->get('https://jsonplaceholder.typicode.com/users');
いくつかのクエリパラメータを渡す必要がある場合は、次のように渡すことができます -
$response = $http->get('https://jsonplaceholder.typicode.com/users', ["id", 1]);
応答を取得するには、次のように実行できます-
通常のテキストデータの場合 −
$response->getBody();
Json −
の場合$response->getJson();
Xml −
の場合$response->getXml()
次のプログラムに示すように、config/routes.php ファイルを変更します。
config/routes.php
<?php use Cake\Http\Middleware\CsrfProtectionMiddleware; use Cake\Routing\Route\DashedRoute; use Cake\Routing\RouteBuilder; $routes->setRouteClass(DashedRoute::class); $routes->scope('/', function (RouteBuilder $builder) { $builder->registerMiddleware('csrf', new CsrfProtectionMiddleware([ 'httpOnly' => true, ])); $builder->applyMiddleware('csrf'); //$builder->connect('/pages',['controller'=>'Pages','action'=>'display', 'home']); $builder->connect('getData',['controller'=>'Requests','action'=>'index']); $builder->fallbacks(); });
src/Controller/RequestsController.php に RequestsController.php ファイルを作成します。 コントローラー ファイルに次のコードをコピーします。
src/Controller/RequestsController.php
<?php namespace App\Controller; use App\Controller\AppController; use Cake\Http\Client; class RequestsController extends AppController{ public function index(){ $http = new Client(); $response = $http->get('https://jsonplaceholder.typicode.com/users'); $stream = $response->getJson(); $this->set('response',$stream); } } ?>
src/Template にディレクトリ Requests を作成し、そのディレクトリの下に index.php. という名前の View ファイルを作成します。そのファイル内の次のコード。
src/Template/Requests/index.php
<h3>All Users from url : https://jsonplaceholder.typicode.com/users</h3> <?php if($response) { foreach($response as $res => $val) { echo '<font color="gray">Name: '.$val["name"].' Email -'.$val["email"].'</font><br>'; } } ?>
次の URL にアクセスして、上記の例を実行します -
http://localhost/cakephp4/getData
何も入力せずに送信ボタンをクリックしてください。次の出力が表示されます。
ポストを操作するには、次のように $http クライアントを呼び出す必要があります -
$response = $http->post('yoururl', data);
同じ例を 1 つ見てみましょう。
次のプログラムに示すように、config/routes.php ファイルを変更します。
config/routes.php
<?php use Cake\Http\Middleware\CsrfProtectionMiddleware; use Cake\Routing\Route\DashedRoute; use Cake\Routing\RouteBuilder; $routes->setRouteClass(DashedRoute::class); $routes->scope('/', function (RouteBuilder $builder) { $builder->registerMiddleware('csrf', new CsrfProtectionMiddleware([ 'httpOnly' => true, ])); $builder->applyMiddleware('csrf'); //$builder->connect('/pages',['controller'=>'Pages','action'=>'display', 'home']); $builder->connect('postData',['controller'=>'Requests','action'=>'index']); $builder->fallbacks(); });
src/Controller/RequestsController.php. に RequestsController.php ファイルを作成します。コントローラー ファイルに次のコードをコピーします。すでに作成されている場合は無視します。
src/Controller/RequestsController.php
<?php namespace App\Controller; use App\Controller\AppController; use Cake\Http\Client; class RequestsController extends AppController{ public function index(){ $http = new Client(); $response = $http->post('https://postman-echo.com/post', [ 'name'=> 'ABC', 'email' => 'xyz@gmail.com' ]); } } ?>
src/Template にディレクトリ Requests を作成し、そのディレクトリの下に、index.php という名前の View ファイルを作成します。そのファイルに次のコードをコピーします。
src/Template/Requests/index.php
<h3>Testing Post Method</h3>
次の URL にアクセスして、上記の例を実行します -
http://localhost/cakephp4/postData
以下はコードの出力です -
同様に、PUT メソッドでも試すことができます。
$http = new Client(); $response = $http->put('https://postman-echo.com/post', [ 'name'=> 'ABC', 'email' => 'xyz@gmail.com' ]);
以上がCakePHP バリデータの作成の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。