CakePHP - 建立驗證器



可以透過在控制器中新增以下兩行程式碼來建立驗證器。

use Cake\Validation\Validator;
$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->data());

使用 `$validator` 物件,首先呼叫了 `notEmpty()` 方法,這將確保使用者名稱不能為空。之後,我們鏈式呼叫了 `add()` 方法來新增另一個驗證,用於檢查正確的電子郵件格式。

之後,我們為密碼欄位添加了 `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` 的檔案。將以下程式碼複製到控制器檔案中。

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` 的檢視檔案。將以下程式碼複製到該檔案中。

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 來執行上述示例:

https:///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

<?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` 的檔案。將以下程式碼複製到控制器檔案中。

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` 的檢視檔案。將以下程式碼複製到該檔案中。

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 來執行上述示例:

https:///cakephp4/getData

輸出

單擊提交按鈕而不輸入任何內容。您將收到以下輸出。

Users URL

HTTP POST 方法

要使用 POST 方法,您需要按如下方式呼叫 `$http` 客戶端:

$response = $http->post('yoururl', data);

讓我們來看一個相同的例子。

示例

按照以下程式所示更改 `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` 的檔案。將以下程式碼複製到控制器檔案中。如果已建立,則忽略。

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` 的檢視檔案。將以下程式碼複製到該檔案中。

src/Template/Requests/index.php

<h3>Testing Post Method</h3>

訪問以下 URL 來執行上述示例:

https:///cakephp4/postData

輸出

以下是程式碼的輸出:

Post Method

同樣,您可以嘗試 PUT 方法。

$http = new Client();
$response = $http->put('https://postman-echo.com/post', [
   'name'=> 'ABC',
   'email' => 'xyz@gmail.com'
]);
廣告
© . All rights reserved.