


Informationen zur automatischen Überprüfung der Methode create() in ThinkPHP
Im Folgenden finden Sie ein Beispiel für die automatische Überprüfung der create()-Methode in ThinkPHP. Der Inhalt ist ziemlich gut, daher werde ich ihn jetzt mit Ihnen teilen und als Referenz verwenden.
Automatische Überprüfung ist eine von der ThinkPHP-Modellschicht bereitgestellte Datenüberprüfungsmethode, die automatisch eine Datenüberprüfung durchführen kann, wenn zum Erstellen eines Datenobjekts „create“ verwendet wird.
Prinzip:
Die Methode create() sammelt Formularinformationen ($_POST) und gibt sie zurück, während sie gleichzeitig eine automatische Überprüfung des Formulars auslöst und illegale Felder filtert ,
Verwenden Sie die Methode create() im Controller (der Rückgabewert ist wahr/falsch), die automatisch das Attribut $_validate in der Modellklasse auslöst (es ist die Methode in Passen Sie die Überprüfungsregeln in $ _validate an (die Überprüfungsregeln werden im Folgenden ausführlich erläutert). Wenn die Methode create () keine Daten enthält und der Rückgabewert falsch ist, erhalten Sie und Fehlermeldung zurückgeben!
Die Verwendung der automatischen Validierung muss gemäß dem folgenden Regelformat definiert werden:
protected $_validate = array( array(验证字段1,验证规则,错误提示,[验证条件,附加规则,验证时间]), array(验证字段2,验证规则,错误提示,[验证条件,附加规则,验证时间]), ...... );
wo Validierungsfelder , Validierungsregeln, die Fehleraufforderung ist erforderlich, die Überprüfungsbedingungen, zusätzliche Regeln und die Überprüfungszeit sind optional!
Validierungsfeld (erforderlich): Formularfeld.
Validierungsregeln (erforderlich): Das erforderliche Feld muss eine E-Mail-Adresse, eine URL-Adresse und eine Nummer enthalten und kann auch in Verbindung mit zusätzlichen Regeln verwendet werden.
Fehlermeldung (erforderlich): Eine Meldung wird zurückgegeben, wenn die Überprüfung fehlschlägt.
Überprüfungsbedingungen (optional): Es gibt drei Typen: 0, 1 und 2. 0: Feldüberprüfung, die in _POST vorhanden ist, Standard 1: Überprüfung ist erforderlich, wenn die Überprüfungsregeln definiert sind; Der Wert ist nicht leer. Überprüfen Sie.
Zusätzliche Regeln:
regex | 正则验证,定义的验证规则是一个正则表达式(默认) |
function | 函数验证,定义的验证规则是一个函数名 |
callback | 方法验证,定义的验证规则是当前模型类的一个方法 |
confirm | 验证表单中的两个字段是否相同,定义的验证规则是一个字段名 |
equal | 验证是否等于某个值,该值由前面的验证规则定义 |
notequal | 验证是否不等于某个值,该值由前面的验证规则定义(3.1.2版本新增) |
in | 验证是否在某个范围内,定义的验证规则可以是一个数组或者逗号分割的字符串 |
notin | 验证是否不在某个范围内,定义的验证规则可以是一个数组或者逗号分割的字符串(3.1.2版本新增) |
length | 验证长度,定义的验证规则可以是一个数字(表示固定长度)或者数字范围(例如3,12 表示长度从3到12的范围) |
between | 验证范围,定义的验证规则表示范围,可以使用字符串或者数组,例如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是否允许,定义的验证规则表示允许的IP地址列表,用逗号分隔,例如201.12.2.5,201.12.2.6 |
ip_deny | 验证IP是否禁止,定义的验证规则表示禁止的ip地址列表,用逗号分隔,例如201.12.2.5,201.12.2.6 |
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利用getlist方法实现数据搜索功能的分析
Das obige ist der detaillierte Inhalt vonInformationen zur automatischen Überprüfung der Methode create() in ThinkPHP. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

Um das ThinkPHP-Projekt auszuführen, müssen Sie: Composer installieren, das Projektverzeichnis aufrufen und http://localhost:8000 aufrufen.

ThinkPHP verfügt über mehrere Versionen, die für verschiedene PHP-Versionen entwickelt wurden. Zu den Hauptversionen gehören 3.2, 5.0, 5.1 und 6.0, während Nebenversionen dazu dienen, Fehler zu beheben und neue Funktionen bereitzustellen. Die neueste stabile Version ist ThinkPHP 6.0.16. Berücksichtigen Sie bei der Auswahl einer Version die PHP-Version, die Funktionsanforderungen und den Community-Support. Für optimale Leistung und Support wird empfohlen, die neueste stabile Version zu verwenden.

Schritte zum lokalen Ausführen von ThinkPHP Framework: Laden Sie ThinkPHP Framework herunter und entpacken Sie es in ein lokales Verzeichnis. Erstellen Sie einen virtuellen Host (optional), der auf das ThinkPHP-Stammverzeichnis verweist. Konfigurieren Sie Datenbankverbindungsparameter. Starten Sie den Webserver. Initialisieren Sie die ThinkPHP-Anwendung. Greifen Sie auf die URL der ThinkPHP-Anwendung zu und führen Sie sie aus.

Leistungsvergleich von Laravel- und ThinkPHP-Frameworks: ThinkPHP schneidet im Allgemeinen besser ab als Laravel und konzentriert sich auf Optimierung und Caching. Laravel schneidet gut ab, aber für komplexe Anwendungen ist ThinkPHP möglicherweise besser geeignet.

„Entwicklungsvorschläge: So verwenden Sie das ThinkPHP-Framework zur Implementierung asynchroner Aufgaben“ Mit der rasanten Entwicklung der Internettechnologie stellen Webanwendungen immer höhere Anforderungen an die Verarbeitung einer großen Anzahl gleichzeitiger Anforderungen und komplexer Geschäftslogik. Um die Systemleistung und das Benutzererlebnis zu verbessern, erwägen Entwickler häufig die Verwendung asynchroner Aufgaben, um einige zeitaufwändige Vorgänge auszuführen, z. B. das Senden von E-Mails, das Verarbeiten von Datei-Uploads, das Erstellen von Berichten usw. Im Bereich PHP bietet das ThinkPHP-Framework als beliebtes Entwicklungsframework einige praktische Möglichkeiten zur Implementierung asynchroner Aufgaben.

ThinkPHP-Installationsschritte: Bereiten Sie PHP-, Composer- und MySQL-Umgebungen vor. Erstellen Sie Projekte mit Composer. Installieren Sie das ThinkPHP-Framework und die Abhängigkeiten. Datenbankverbindung konfigurieren. Anwendungscode generieren. Starten Sie die Anwendung und besuchen Sie http://localhost:8000.

ThinkPHP ist ein leistungsstarkes PHP-Framework mit Vorteilen wie Caching-Mechanismus, Codeoptimierung, Parallelverarbeitung und Datenbankoptimierung. Offizielle Leistungstests zeigen, dass es mehr als 10.000 Anfragen pro Sekunde verarbeiten kann und in großen Websites und Unternehmenssystemen wie JD.com und Ctrip in praktischen Anwendungen weit verbreitet ist.

Entwicklungsvorschläge: So verwenden Sie das ThinkPHP-Framework für die API-Entwicklung Mit der kontinuierlichen Entwicklung des Internets ist die Bedeutung von API (Application Programming Interface) immer wichtiger geworden. Die API ist eine Brücke für die Kommunikation zwischen verschiedenen Anwendungen. Sie kann Datenaustausch, Funktionsaufrufe und andere Vorgänge realisieren und bietet Entwicklern eine relativ einfache und schnelle Entwicklungsmethode. Als hervorragendes PHP-Entwicklungsframework ist das ThinkPHP-Framework effizient, skalierbar und einfach zu verwenden.
