次に、ThinkPHP の create() メソッドの自動検証の例を示します。内容がとても良かったので、参考としてシェアさせていただきます。
自動検証は、ThinkPHP モデル層によって提供されるデータ検証方法であり、create を使用してデータ オブジェクトを作成するときにデータ検証を自動的に実行できます。
原則:
##create() メソッドは、フォーム ($_POST) 情報を収集して返します。同時に、フォームの自動検証をトリガーし、不正なフィールドをフィルタリングします。
コントローラーで create() メソッドを使用すると (戻り値は true/false)、モデル クラスの $_validate 属性が自動的にトリガーされます (これは、親クラス Model、サブクラス Rewrite in Model) で、create() メソッドにデータがなく戻り値が false の場合、$_validate で検証ルールをカスタマイズします (検証ルールについては後で詳しく説明します)。エラーメッセージ!
自動検証の使用は、次のルール形式に従って定義する必要があります:
protected $_validate = array(
array(验证字段1,验证规则,错误提示,[验证条件,附加规则,验证时间]),
array(验证字段2,验证规则,错误提示,[验证条件,附加规则,验证时间]),
......
);
ログイン後にコピー
ここで検証フィールド、検証ルール、エラー プロンプトは必須です。検証条件、追加ルール、および検証時間はオプションです。
検証フィールド (必須): フォームフィールド。
検証ルール (必須): 必須フィールドには、電子メール アドレス、URL URL アドレス、および番号を含める必要があります。追加のルールと組み合わせて使用することもできます。
エラー プロンプト (必須): 検証が失敗した場合に返されるプロンプト メッセージ。
検証条件 (オプション): 0、1、2 の 3 つのタイプがあります。0: _POST に存在するフィールド検証、デフォルト。1: 検証ルールが定義されている場合は検証が必要です。値は空ではありません。検証、定義済み 検証ルールは正規表現です (デフォルト)
function 関数検証、定義済みの検証ルールは関数名です
callbackメソッド検証、定義された検証ルールが現在のモデル クラスのメソッドである | |
confirm2 つのメソッドが一致しているかどうかを検証します。フォーム内のフィールド 同じです。定義された検証ルールはフィールド名 | |
equal であり、特定の値と等しいかどうかを検証します。この値は、以前の検証ルール | |
notequal以前の検証ルール (バージョン 3.1.2 の新機能) で定義された特定の値と等しくないかどうかを検証します。 | | ##in
定義された検証ルールは、配列またはカンマ区切りの文字列にすることができます。 | | notin
特定の範囲内にあるかどうかを検証します。特定の範囲内では、定義された検証ルールは配列またはカンマ区切りの文字列 (バージョン 3.1.2 の新機能) | | length
検証の長さ、定義 検証ルールは、数値 (固定長を表す) または数値の範囲 (たとえば、3,12 は長さの範囲を表す) にすることができます。 3 から 12 までの長さ) | | between
Validation range 、定義された検証ルールは範囲を表し、1、31、または 1、31 などの文字列または配列を使用できます。 array(1,31) | | notbetween
検証は特定の範囲内にありません。定義された検証ルールは範囲を表します。文字列または配列を使用できます (新機能)バージョン 3.1.2) | | expire
有効期間内であるかどうかを検証します。定義された検証ルールは、その時点までの時間範囲を示します。たとえば、2012-1-15、2013-1-15 を使用して、現在の送信有効期間が 2012-1-15 から 2013-1-15 までであることを示すこともできます。また、タイムスタンプ定義 # を使用することもできます。 | ##ip_allow |
IP が許可されているかどうかを確認します。定義された検証ルールは、201.12.2.5,201.12.2.6 のように、カンマで区切られた許可された IP アドレスのリストを表します。 | ip_deny |
IP が禁止されているかどうかを確認します。定義された検証ルールは、201.12.2.5,201.12.2.6## のように、カンマで区切られた禁止された IP アドレスのリストを表します。 | #unique | 一意であるかどうかを確認するために、システムはフィールドの現在の値に基づいてデータベースにクエリを実行し、フォーム データに同じ値が存在するかどうかを判断します。主キー フィールドが含まれています。unique を使用して主キー フィールド自体を決定することはできません
| 验证时间(可选):共有1,2,3三种,1:新增数据时候验证;2:编辑数据时候验证;3:全部情况下验证(默认);也可以可以根据业务需要增加其他的验证时间
下面附上代码:以注册为例
前台页面比较简单,代码就不贴出来了,下面是前台注册界面截图

控制器代码:
//注册
public function register(){
$user = new \Model\UserModel();
//两个逻辑:收集,展示
if (!empty($_POST)) {
//create()方法收集表单($_POST)信息并返回,同时触发表单自动验证,过滤非法字段
$date = $user->create();
//通过create()方法的返回值$date判断验证是否成功
if ($date) { //返回实在数据的时候才进行添加
//implode()把数组变为字符串
$date['user_hobby'] = implode(',', $date['user_hobby']);
$info = $user->add($date);
if ($info) {
//跳转首页
$this->redirect('Index/index');
}
}else{
//把错误信息分配到前台模板
$error = $user->getError();
$this->assign('error',$error);
}
}
//调用view视图
$this->display();
}
ログイン後にコピー
模型类代码:
class UserModel extends Model{
//是否批量处理验证,批量获取全部的错误验证信息
protected $patchValidate = true; //默认为false
//自动验证定义
protected $_validate = array(
//array(字段,验证规则,错误提示,验证条件,附加规则,验证时间)
//①用户名验证,不能为空
array('username','require','用户名不能为空'),
array('username','','该用户名已经被占用','0','unique'),
//②密码验证,不为空
array('password','require','密码不能为空'),
//③验证确认密码,必须填写,与密码保持一致
array('password2','require','确认密码必须填写'),
array('password2','password','两次密码保持一致',0,'confirm'),
//④邮箱验证
array('user_email','email','邮箱格式不正确',2),
//⑤qq验证,数字组成,5-12位
array('user_qq','number','qq必须是数字'),
array('user_qq','5,12','位数在5-12位之间',0,'length'),
//⑥学历验证,必须选一个
array('user_xueli','2,5','学位必须选择一个',0,'between'),
//⑦爱好验证,必须选择二个以上
//因为爱好返回的是数组,附加规则中没有可以直接用的规则,所以需自定义方法,用callback方法验证
array('user_hobby','check_hobby','爱好必须选两项或以上',1,'callback'),
);
//定义方法进行爱好验证
//参数$arg代表被验证的表单信息
function check_hobby($arg)
{
//判断数组长度是否大于2
if (count($arg)<2) {
return false; //会自动输出验证错误信息
}
return true;
}
}
ログイン後にコピー
把验证的错误信息在模板中给展示出来(部分代码)
<td style="width:13%; text-align: right;">
<label for="User_username" class="required">用户名
<span>*</span></label>
</td>
<td style="width:87%;">
<input class="inputBg" size="25" name="username" id="User_username" type="text" value="" />
<span style="color:red;"><{$error.username|default:""}></span>
</td>
ログイン後にコピー
结果:

以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注PHP中文网!
相关推荐:
对THINKPHP的addAll支持的最大数据量的分析
关于ThinkPHP CURD方法之table方法
关于ThinkPHP利用getlist方法实现数据搜索功能的分析
以上がThinkPHP の create() メソッドの自動検証についての詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
thinkphpプロジェクトの実行方法
Apr 09, 2024 pm 05:33 PM
ThinkPHP プロジェクトを実行するには、Composer をインストールし、Composer を使用してプロジェクトを作成し、プロジェクト ディレクトリに入り、php bin/consoleserve を実行し、http://localhost:8000 にアクセスしてようこそページを表示する必要があります。
thinkphp にはいくつかのバージョンがあります
Apr 09, 2024 pm 06:09 PM
ThinkPHP には、さまざまな PHP バージョン向けに設計された複数のバージョンがあります。メジャー バージョンには 3.2、5.0、5.1、および 6.0 が含まれますが、マイナー バージョンはバグを修正し、新機能を提供するために使用されます。最新の安定バージョンは ThinkPHP 6.0.16 です。バージョンを選択するときは、PHP バージョン、機能要件、コミュニティ サポートを考慮してください。最高のパフォーマンスとサポートを得るには、最新の安定バージョンを使用することをお勧めします。
thinkphpの実行方法
Apr 09, 2024 pm 05:39 PM
ThinkPHP フレームワークをローカルで実行する手順: ThinkPHP フレームワークをローカル ディレクトリにダウンロードして解凍します。 ThinkPHP ルート ディレクトリを指す仮想ホスト (オプション) を作成します。データベース接続パラメータを構成します。 Webサーバーを起動します。 ThinkPHP アプリケーションを初期化します。 ThinkPHP アプリケーションの URL にアクセスして実行します。
開発に関する提案: ThinkPHP フレームワークを使用して非同期タスクを実装する方法
Nov 22, 2023 pm 12:01 PM
「開発に関する提案: ThinkPHP フレームワークを使用して非同期タスクを実装する方法」 インターネット技術の急速な発展に伴い、Web アプリケーションには、多数の同時リクエストと複雑なビジネス ロジックを処理するための要件がますます高まっています。システムのパフォーマンスとユーザー エクスペリエンスを向上させるために、開発者は多くの場合、電子メールの送信、ファイルのアップロードの処理、レポートの生成など、時間のかかる操作を実行するために非同期タスクの使用を検討します。 PHP の分野では、人気のある開発フレームワークとして ThinkPHP フレームワークが、非同期タスクを実装するための便利な方法をいくつか提供しています。
laravelとthinkphpではどちらが優れていますか?
Apr 09, 2024 pm 03:18 PM
Laravel フレームワークと ThinkPHP フレームワークのパフォーマンスの比較: ThinkPHP は、最適化とキャッシュに重点を置いて、一般に Laravel よりもパフォーマンスが優れています。 Laravel は優れたパフォーマンスを発揮しますが、複雑なアプリケーションの場合は、ThinkPHP の方が適している可能性があります。
thinkphpのインストール方法
Apr 09, 2024 pm 05:42 PM
ThinkPHP のインストール手順: PHP、Composer、および MySQL 環境を準備します。 Composer を使用してプロジェクトを作成します。 ThinkPHP フレームワークと依存関係をインストールします。データベース接続を構成します。アプリケーションコードを生成します。アプリケーションを起動し、http://localhost:8000 にアクセスします。
thinkphpのパフォーマンスはどうですか?
Apr 09, 2024 pm 05:24 PM
ThinkPHP は、キャッシュ メカニズム、コードの最適化、並列処理、データベースの最適化などの利点を備えた高性能 PHP フレームワークです。公式パフォーマンステストでは、1秒あたり10,000以上のリクエストを処理できることが示されており、実際のアプリケーションではJD.comやCtripなどの大規模なWebサイトやエンタープライズシステムで広く使用されています。
開発に関する提案: API 開発に ThinkPHP フレームワークを使用する方法
Nov 22, 2023 pm 05:18 PM
開発の提案: API 開発に ThinkPHP フレームワークを使用する方法 インターネットの継続的な発展に伴い、API (アプリケーション プログラミング インターフェイス) の重要性がますます高まっています。 API は、異なるアプリケーション間の通信の橋渡しとなるもので、データの共有や関数の呼び出しなどを実現し、開発者に比較的簡単かつ迅速な開発手法を提供します。優れた PHP 開発フレームワークである ThinkPHP フレームワークは、効率的でスケーラブルで使いやすいです。
See all articles