コントローラーに次の 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
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
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
'.$msg.'
'; } 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
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
get('https://jsonplaceholder.typicode.com/users'); $stream = $response->getJson(); $this->set('response',$stream); } } ?>
src/TemplateにディレクトリRequestsを作成し、そのディレクトリの下にindex.php.という名前のViewファイルを作成します。そのファイル内の次のコード。
src/Template/Requests/index.php
All Users from url : https://jsonplaceholder.typicode.com/users
$val) { echo 'Name: '.$val["name"].' Email -'.$val["email"].'
'; } } ?>
次の URL にアクセスして、上記の例を実行します -
http://localhost/cakephp4/getData
何も入力せずに送信ボタンをクリックしてください。次の出力が表示されます。
ポストを操作するには、次のように $http クライアントを呼び出す必要があります -
$response = $http->post('yoururl', data);
同じ例を 1 つ見てみましょう。
次のプログラムに示すように、config/routes.php ファイルを変更します。
config/routes.php
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
post('https://postman-echo.com/post', [ 'name'=> 'ABC', 'email' => 'xyz@gmail.com' ]); } } ?>
src/TemplateにディレクトリRequestsを作成し、そのディレクトリの下に、index.php という名前のViewファイルを作成します。そのファイルに次のコードをコピーします。
src/Template/Requests/index.php
Testing Post Method
次の 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 サイトの他の関連記事を参照してください。