php 注冊(cè)時(shí)輸入信息驗(yàn)證器的實(shí)現(xiàn)詳解
更新時(shí)間:2013年07月05日 10:46:54 作者:
本篇文章是對(duì)php中注冊(cè)時(shí)輸入信息驗(yàn)證器的實(shí)現(xiàn)方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
1、對(duì)輸入信息進(jìn)行驗(yàn)證的類(lèi)(主要用于驗(yàn)證用戶(hù)名,密碼,重復(fù)密碼,郵箱,可添加其它功能)
<?php
/**
* Validator for Register.
*/
final class RegisterValidator {
private function __construct() {
}
/**
* Validate the given username, password, repeat_password and email.
* @param $username, $password, $repeat_password and $email to be validated
* @return array array of {@link Error} s
*/
public static function validate($username, $password, $repeat_password, $email) {
$errors = array();
$username = trim($username);
$password = trim($password);
if (!$username) {
$errors[] = new Error('username', '用戶(hù)名不能為空。');
} elseif (strlen($username)<3) {
$errors[] = new Error('username', '用戶(hù)名長(zhǎng)度不能小于3個(gè)字符。');
} elseif (strlen($username)>30) {
$errors[] = new Error('username', '用戶(hù)名長(zhǎng)度不能超過(guò)30個(gè)字符。');
} elseif (!preg_match('/^[A-Za-z]+$/',substr($username, 0, 1))) {
$errors[] = new Error('username', '用戶(hù)名必須以字母開(kāi)頭。');
} elseif (!preg_match('/^[A-Za-z0-9_]+$/', $username)) {
$errors[] = new Error('username', '用戶(hù)名只能是字母、數(shù)字以及下劃線(xiàn)( _ )的組合。');
} elseif (!$password) {
$errors[] = new Error('password', '密碼不能為空。');
} elseif (strlen($password)<6) {
$errors[] = new Error('password', '密碼長(zhǎng)度不能小于6個(gè)字符。');
} elseif (strlen($password)>30) {
$errors[] = new Error('password', '密碼長(zhǎng)度不能超過(guò)30個(gè)字符。');
} elseif (!preg_match('/^[A-Za-z0-9!@#\\$%\\^&\\*_]+$/', $password)) {
$errors[] = new Error('password', '密碼只能是數(shù)字、字母或!@#$%^&*_等字符的組合。');
} elseif ($password != trim($repeat_password)) {
$errors[] = new Error('password', '兩次輸入密碼不一致。');
} elseif (!Utils::isValidEmail($email)) {
$errors[] = new Error('email', '郵箱格式有誤。');
} else {
// check whether user exists or not
$dao = new UserDao();
$user = $dao->findByName(trim($username));
if ($user) {
$errors[] = new Error('username', '該用戶(hù)名已經(jīng)被使用。');
}
$user = null;
// check whether email being used or not
$user = $dao->findByEmail(trim($email));
if ($user) {
$errors[] = new Error('email', '該郵箱已被注冊(cè)。');
}
}
return $errors;
}
}
?>
2、在注冊(cè)頁(yè)面進(jìn)行調(diào)用
$username = null;
$password = null;
$repeat_password = null;
$email = null;
$msg = "";
if (isset($_POST['username']) && isset($_POST['password'])
&& isset($_POST['repeat_password']) && isset($_POST['email'])) {
$username = addslashes(trim(stripslashes($_POST ['username'])));
$password = addslashes(trim(stripslashes($_POST ['password'])));
$repeat_password = addslashes(trim(stripslashes($_POST ['repeat_password'])));
$email = addslashes(trim(stripslashes($_POST ['email'])));
// validate
$errors = RegisterValidator::validate($username, $password, $repeat_password, $email);
// validate
if (empty($errors)) {
// save
$dao = new UserDao();
$user = new User();
$user->setEmail($email);
$last_login_ip = Utils::getIpAddress();
$user->setLastLoginIp($last_login_ip);
$user->setUsername($username);
$salt = substr(sha1(mt_rand()), 0, 22);
$hash_password = sha1($salt . $password);
$user->setPassword($hash_password);
$user->setSalt($salt);
$user = $dao->save($user);
if ($user) {
UserLogin::setUserInfo($user);
Flash::addFlash('注冊(cè)成功!');
}
else {
Flash::addFlash('對(duì)不起,由于服務(wù)器內(nèi)部錯(cuò)誤,導(dǎo)致注冊(cè)失敗。請(qǐng)稍后再試。');
}
Utils::redirect('welcome');
}
foreach ($errors as $e) {
$msg .= $e->getMessage()."<br>";
}
3.代碼中Error類(lèi)用于記錄驗(yàn)證時(shí)的錯(cuò)誤信息
<?php
/**
* Validation error.
*/
final class Error {
private $source;
private $message;
/**
* Create new error.
* @param mixed $source source of the error
* @param string $message error message
*/
function __construct($source, $message) {
$this->source = $source;
$this->message = $message;
}
/**
* Get source of the error.
* @return mixed source of the error
*/
public function getSource() {
return $this->source;
}
/**
* Get error message.
* @return string error message
*/
public function getMessage() {
return $this->message;
}
}
?>
復(fù)制代碼 代碼如下:
<?php
/**
* Validator for Register.
*/
final class RegisterValidator {
private function __construct() {
}
/**
* Validate the given username, password, repeat_password and email.
* @param $username, $password, $repeat_password and $email to be validated
* @return array array of {@link Error} s
*/
public static function validate($username, $password, $repeat_password, $email) {
$errors = array();
$username = trim($username);
$password = trim($password);
if (!$username) {
$errors[] = new Error('username', '用戶(hù)名不能為空。');
} elseif (strlen($username)<3) {
$errors[] = new Error('username', '用戶(hù)名長(zhǎng)度不能小于3個(gè)字符。');
} elseif (strlen($username)>30) {
$errors[] = new Error('username', '用戶(hù)名長(zhǎng)度不能超過(guò)30個(gè)字符。');
} elseif (!preg_match('/^[A-Za-z]+$/',substr($username, 0, 1))) {
$errors[] = new Error('username', '用戶(hù)名必須以字母開(kāi)頭。');
} elseif (!preg_match('/^[A-Za-z0-9_]+$/', $username)) {
$errors[] = new Error('username', '用戶(hù)名只能是字母、數(shù)字以及下劃線(xiàn)( _ )的組合。');
} elseif (!$password) {
$errors[] = new Error('password', '密碼不能為空。');
} elseif (strlen($password)<6) {
$errors[] = new Error('password', '密碼長(zhǎng)度不能小于6個(gè)字符。');
} elseif (strlen($password)>30) {
$errors[] = new Error('password', '密碼長(zhǎng)度不能超過(guò)30個(gè)字符。');
} elseif (!preg_match('/^[A-Za-z0-9!@#\\$%\\^&\\*_]+$/', $password)) {
$errors[] = new Error('password', '密碼只能是數(shù)字、字母或!@#$%^&*_等字符的組合。');
} elseif ($password != trim($repeat_password)) {
$errors[] = new Error('password', '兩次輸入密碼不一致。');
} elseif (!Utils::isValidEmail($email)) {
$errors[] = new Error('email', '郵箱格式有誤。');
} else {
// check whether user exists or not
$dao = new UserDao();
$user = $dao->findByName(trim($username));
if ($user) {
$errors[] = new Error('username', '該用戶(hù)名已經(jīng)被使用。');
}
$user = null;
// check whether email being used or not
$user = $dao->findByEmail(trim($email));
if ($user) {
$errors[] = new Error('email', '該郵箱已被注冊(cè)。');
}
}
return $errors;
}
}
?>
2、在注冊(cè)頁(yè)面進(jìn)行調(diào)用
復(fù)制代碼 代碼如下:
$username = null;
$password = null;
$repeat_password = null;
$email = null;
$msg = "";
if (isset($_POST['username']) && isset($_POST['password'])
&& isset($_POST['repeat_password']) && isset($_POST['email'])) {
$username = addslashes(trim(stripslashes($_POST ['username'])));
$password = addslashes(trim(stripslashes($_POST ['password'])));
$repeat_password = addslashes(trim(stripslashes($_POST ['repeat_password'])));
$email = addslashes(trim(stripslashes($_POST ['email'])));
// validate
$errors = RegisterValidator::validate($username, $password, $repeat_password, $email);
// validate
if (empty($errors)) {
// save
$dao = new UserDao();
$user = new User();
$user->setEmail($email);
$last_login_ip = Utils::getIpAddress();
$user->setLastLoginIp($last_login_ip);
$user->setUsername($username);
$salt = substr(sha1(mt_rand()), 0, 22);
$hash_password = sha1($salt . $password);
$user->setPassword($hash_password);
$user->setSalt($salt);
$user = $dao->save($user);
if ($user) {
UserLogin::setUserInfo($user);
Flash::addFlash('注冊(cè)成功!');
}
else {
Flash::addFlash('對(duì)不起,由于服務(wù)器內(nèi)部錯(cuò)誤,導(dǎo)致注冊(cè)失敗。請(qǐng)稍后再試。');
}
Utils::redirect('welcome');
}
foreach ($errors as $e) {
$msg .= $e->getMessage()."<br>";
}
3.代碼中Error類(lèi)用于記錄驗(yàn)證時(shí)的錯(cuò)誤信息
復(fù)制代碼 代碼如下:
<?php
/**
* Validation error.
*/
final class Error {
private $source;
private $message;
/**
* Create new error.
* @param mixed $source source of the error
* @param string $message error message
*/
function __construct($source, $message) {
$this->source = $source;
$this->message = $message;
}
/**
* Get source of the error.
* @return mixed source of the error
*/
public function getSource() {
return $this->source;
}
/**
* Get error message.
* @return string error message
*/
public function getMessage() {
return $this->message;
}
}
?>
您可能感興趣的文章:
- PHP+Ajax異步通訊實(shí)現(xiàn)用戶(hù)名郵箱驗(yàn)證是否已注冊(cè)( 2種方法實(shí)現(xiàn))
- php發(fā)送短信驗(yàn)證碼完成注冊(cè)功能
- 注冊(cè)頁(yè)面之前先驗(yàn)證用戶(hù)名是否存在的php代碼
- php用戶(hù)注冊(cè)頁(yè)面利用js進(jìn)行表單驗(yàn)證具體實(shí)例
- php用戶(hù)注冊(cè)信息驗(yàn)證正則表達(dá)式
- 用Php編寫(xiě)注冊(cè)后Email激活驗(yàn)證的實(shí)例代碼
- php自動(dòng)注冊(cè)登錄驗(yàn)證機(jī)制實(shí)現(xiàn)代碼
- PHP學(xué)習(xí)筆記 用戶(hù)注冊(cè)模塊用戶(hù)類(lèi)以及驗(yàn)證碼類(lèi)
- Thinkphp實(shí)現(xiàn)短信驗(yàn)證注冊(cè)功能
- php+ajax注冊(cè)實(shí)時(shí)驗(yàn)證功能
- js和php郵箱地址驗(yàn)證的實(shí)現(xiàn)方法
- PHP實(shí)現(xiàn)的激活用戶(hù)注冊(cè)驗(yàn)證郵箱功能示例
相關(guān)文章
php實(shí)現(xiàn)壓縮多個(gè)CSS與JS文件的方法
這篇文章主要介紹了php實(shí)現(xiàn)壓縮多個(gè)CSS與JS文件的方法,通過(guò)兩個(gè)完整實(shí)例分別實(shí)現(xiàn)了針對(duì)css文件與js文件的壓縮,需要的朋友可以參考下2014-11-11PHP中文豎排轉(zhuǎn)換實(shí)現(xiàn)方法
這篇文章主要介紹了PHP中文豎排轉(zhuǎn)換實(shí)現(xiàn)方法,一般大家的閱讀習(xí)慣是一行行瀏覽,很少使用豎排進(jìn)行閱讀,本文介紹了PHP實(shí)現(xiàn)中文豎排轉(zhuǎn)換,感興趣的小伙伴們可以參考一下2015-10-10PHP+Apache實(shí)現(xiàn)二級(jí)域名之間共享cookie的方法
這篇文章主要介紹了PHP+Apache實(shí)現(xiàn)二級(jí)域名之間共享cookie的方法,涉及Apache的配置、hosts修改及php cookie操作相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2019-07-07PHP下通過(guò)exec獲得計(jì)算機(jī)的唯一標(biāo)識(shí)[CPU,網(wǎng)卡 MAC地址]
PHP下通過(guò)exec獲得計(jì)算機(jī)的唯一標(biāo)識(shí)的代碼,可獲得CPU,網(wǎng)卡 MAC地址信息。2011-06-06PHP導(dǎo)出EXCEL快速開(kāi)發(fā)指南--PHPEXCEL的使用詳解
本篇文章是對(duì)PHPEXCEL的使用進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06