CakePHP バリデータの作成

PHPz
リリース: 2024-09-10 17:26:58
オリジナル
407 人が閲覧しました

コントローラーに次の 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

出力

何も入力せずに送信ボタンをクリックしてください。次の出力が表示されます。

Click PHP

HTTP - クライアント

http クライアントは、GET、POST、PUT などのリクエストを行うために使用できます。

http クライアントを使用するには、次の行を追加します -

use Cake\Http\Client;
ログイン後にコピー

HTTP クライアントの動作を理解するために例に取り組んでみましょう。

HTTP GET メソッド

指定した 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
ログイン後にコピー

出力

何も入力せずに送信ボタンをクリックしてください。次の出力が表示されます。

Users URL

HTTP POST メソッド

ポストを操作するには、次のように $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

出力

以下はコードの出力です -

Post Method

同様に、PUT メソッドでも試すことができます。

$http = new Client(); $response = $http->put('https://postman-echo.com/post', [ 'name'=> 'ABC', 'email' => 'xyz@gmail.com' ]);
ログイン後にコピー

以上がCakePHP バリデータの作成の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!