php可扩展的验证类实例(可对邮件、手机号、URL等验证)
这篇文章主要介绍了php可扩展的验证类,实例分析了php针对邮件、手机号、URL等常用的验证技巧,非常具有实用价值,需要的朋友可以参考下
本文实例讲述了php可扩展的验证类。分享给大家供大家参考。具体分析如下:
这里介绍一个可扩展的php验证类,
类里面可以的各类验证可自行调整实现,现在为基本实现方式。
需要添加规则的话, 直接定义方法,方法名即为规则名称。具体参考使用方法。
require_once('./Validator.class.php'); $data = array( 'nickname' => 'heno' , 'realname' => 'steven', 'age' => 25, 'mobile' => '1521060426'); $validator = new Validator($data); $validator->setRule('nickname', 'required'); $validator->setRule('realname', array('length' => array(1,6), 'required')); $validator->setRule('age', array('required', 'digit')); $validator->setRule('mobile', array('mobile')); $result = $validator->validate(); var_dump($result); var_dump($validator->getResultInfo());
Validator.class.php文件如下:
_data = $data;
}
}
/**
* 设置校验规则
* @param string $var 带校验项key
* @param mixed $rule 校验规则
* @return void
*/
public function setRule($var, $rule)
{
$this->_ruleList[$var] = $rule;
}
/**
* 检验数据
* @param array $data
*
* $data = array('nickname' => 'heno' , 'realname' => 'steven', 'age' => 25);
* $validator = new Validator($data);
* $validator->setRule('nickname', 'required');
* $validator->setRule('realname', array('lenght' => array(1,4), 'required'));
* $validator->setRule('age', array('required', 'digit'));
* $result = $validator->validate();
* var_dump($validator->getResultInfo());
*
* @return bool
*/
public function validate($data = null)
{
$result = true;
/* 如果没有设置校验规则直接返回 true */
if ($this->_ruleList === null || !count($this->_ruleList)) {
return $result;
}
/* 已经设置规则,则对规则逐条进行校验 */
foreach ($this->_ruleList as $ruleKey => $ruleItem) {
/* 如果检验规则为单条规则 */
if (!is_array($ruleItem)) {
$ruleItem = trim($ruleItem);
if (method_exists($this, $ruleItem)) {
/* 校验数据,保存校验结果 */
$tmpResult = $this->$ruleItem($ruleKey);
if (!$tmpResult) {
$this->_resultInfo[$ruleKey][$ruleItem] = $tmpResult;
$result = false;
}
}
continue;
}
/* 校验规则为多条 */
foreach ($ruleItem as $ruleItemKey => $rule) {
if (!is_array($rule)) {
$rule = trim($rule);
if (method_exists($this, $rule)) {
/* 校验数据,,设置结果集 */
$tmpResult = $this->$rule($ruleKey);
if (!$tmpResult) {
$this->_resultInfo[$ruleKey][$rule] = $tmpResult;
$result = false;
}
}
} else {
if (method_exists($this, $ruleItemKey)) {
/* 校验数据,设置结果集 */
$tmpResult = $this->$ruleItemKey($ruleKey, $rule);
if (!$tmpResult) {
$this->_resultInfo[$ruleKey][$ruleItemKey] = $tmpResult;
$result = false;
}
}
}
}
}
return $result;
}
/**
* 获取校验结果数据
* @return [type] [description]
*/
public function getResultInfo()
{
return $this->_resultInfo;
}
/**
* 校验必填参数
* @param string $varName 校验项
* @return bool
*/
public function required($varName)
{
$result = false;
if (is_array($this->_data) && isset($this->_data[$varName])) {
$result = true;
}
return $result;
}
/**
* 校验参数长度
*
* @param string $varName 校验项
* @param array $lengthData array($minLen, $maxLen)
* @return bool
*/
public function length($varName, $lengthData)
{
$result = true;
/* 如果该项没有设置,默认为校验通过 */
if ($this->required($varName)) {
$varLen = mb_strlen($this->_data[$varName]);
$minLen = $lengthData[0];
$maxLen = $lengthData[1];
if ($varLen $maxLen) {
$result = true;
}
}
return $result;
}
/**
* 校验邮件
* @param string $varName 校验项
* @return bool
*/
public function email($varName)
{
$result = true;
/* 如果该项没有设置,默认为校验通过 */
if ($this->required($varName)) {
$email = trim($this->_data[$varName]);
if (preg_match('/^[-\w]+?@[-\w.]+?$/', $email)) {
$result = false;
}
}
return $result;
}
/**
* 校验手机
* @param string $varName 校验项
* @return bool
*/
public function mobile($varName)
{
$result = true;
/* 如果该项没有设置,默认为校验通过 */
if ($this->required($varName)) {
$mobile = trim($this->_data[$varName]);
if (!preg_match('/^1[3458]\d{10}$/', $mobile)) {
$result = false;
}
}
return $result;
}
/**
* 校验参数为数字
* @param string $varName 校验项
* @return bool
*/
public function digit($varName)
{
$result = false;
if ($this->required($varName) && is_numeric($this->_data[$varName])) {
$result = true;
}
return $result;
}
/**
* 校验参数为身份证
* @param string $varName 校验项
* @return bool
*/
public function ID($ID)
{
}
/**
* 校验参数为URL
* @param string $varName 校验项
* @return bool
*/
public function url($url)
{
$result = true;
/* 如果该项没有设置,默认为校验通过 */
if ($this->required($varName)) {
$url = trim($this->_data[$varName]);
if(!preg_match('/^(http[s]?::)?\w+?(\.\w+?)$/', $url)) {
$result = false;
}
}
return $result;
}
}
?>
希望本文所述对大家的php程序设计有所帮助。

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

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

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



In diesem Kapitel werden wir die Umgebungsvariablen, die allgemeine Konfiguration, die Datenbankkonfiguration und die E-Mail-Konfiguration in CakePHP verstehen.

PHP 8.4 bringt mehrere neue Funktionen, Sicherheitsverbesserungen und Leistungsverbesserungen mit einer beträchtlichen Menge an veralteten und entfernten Funktionen. In dieser Anleitung wird erklärt, wie Sie PHP 8.4 installieren oder auf PHP 8.4 auf Ubuntu, Debian oder deren Derivaten aktualisieren. Obwohl es möglich ist, PHP aus dem Quellcode zu kompilieren, ist die Installation aus einem APT-Repository wie unten erläutert oft schneller und sicherer, da diese Repositorys in Zukunft die neuesten Fehlerbehebungen und Sicherheitsupdates bereitstellen.

Um in cakephp4 mit Datum und Uhrzeit zu arbeiten, verwenden wir die verfügbare FrozenTime-Klasse.

Das Arbeiten mit der Datenbank in CakePHP ist sehr einfach. In diesem Kapitel werden wir die CRUD-Operationen (Erstellen, Lesen, Aktualisieren, Löschen) verstehen.

Um am Datei-Upload zu arbeiten, verwenden wir den Formular-Helfer. Hier ist ein Beispiel für den Datei-Upload.

In diesem Kapitel lernen wir die folgenden Themen im Zusammenhang mit dem Routing kennen.

CakePHP ist ein Open-Source-Framework für PHP. Es soll die Entwicklung, Bereitstellung und Wartung von Anwendungen erheblich vereinfachen. CakePHP basiert auf einer MVC-ähnlichen Architektur, die sowohl leistungsstark als auch leicht zu verstehen ist. Modelle, Ansichten und Controller gu

Der Validator kann durch Hinzufügen der folgenden zwei Zeilen im Controller erstellt werden.
