-
-
/** - * ログイン用のバリデータ
- */
- final class LoginValidator {
プライベート関数 __construct() {
-
- } p>
/**
- * 指定されたユーザー名とパスワードを検証します。
- * @param $username と $password を検証します
- * {@link Error} の @return array 配列
- */
- public static function validate($username, $password) {
- $errors = array();
- $username = トリム($username);
- if (! $username) {
- $errors[] = new Error('username', 'Username を空にすることはできません。');
- } elseif (strlen($username)<3) {
- $errors[] = new Error( ' username', 'ユーザー名は 3 文字未満にすることはできません');
- } elseif (strlen($username)>30) {
- $errors[] = new Error('username', 'ユーザー名は 3 文字未満にすることはできません3 文字。');
- } elseif (!preg_match('/^[A-Za-z]+$/',substr($username, 0, 1))) {
- $errors[] = new Error( 'ユーザー名', 'ユーザー名は文字で始まる必要があります。');
- } elseif (!preg_match('/^[A-Za-z0-9_]+$/', $username)) {
- $errors[ ] = new Error('ユーザー名', 'ユーザー名には文字、数字、アンダースコア (_) の組み合わせのみを使用できます。');
- } elseif (!trim($password)) {
- $errors[] = new Error( 'password ', 'パスワードを空にすることはできません。 ');
- } else {
- // use が存在するかどうかを確認します
- $dao = new UserDao();
- $user = $dao->findByName($username); < /p>
if ($user) {
- if (!($user->getPassword() == sha1($user->getSalt() . $password))) {
- $ errors[ ] = new Error('password', 'ユーザー名またはパスワードが正しくありません。 ');
- }
- } else {
- $errors[] = new Error('ユーザー名', 'ユーザー名が存在しません。');
- }
- }
- return $errors;
- }
- }
- ?>< /p>
-
コードをコピー
エラーは私が書いたクラスです:
-
-
/** - * 検証エラー
- */
- final class Error {
private $source;
- private $message;< /p>
- /**
- * 新しいエラーを作成します。
- * @parammixed $source エラーのソース
- * @param string $message エラーメッセージ
- */
- function __construct($source, $message) {
- $this->source = $source;
- $this->message = $message;
- }
/**
- * エラーのソースを取得します。
- * @return エラーの混合ソースを返します
- */
- public function getSource() {
- return $this->source;
- }
*
- * エラーメッセージを取得します。
- * @return string エラーメッセージ
- */
- public function getMessage() {
- return $this->message;
- }
- }
- ?>
-
コードをコピーします
2. バリデーターを呼び出します。続行するには確認してください
-
-
- $username = null;
- $password = null;
$msg = "";
- < ;p>if (isset($_POST['username']) && isset($_POST['password'])) {
- $username =addslashes(trim(stripslashes($_POST ['username'])));
- $password = addedlashes(trim(stripslashes($_POST ['password'])));
- // validate
- $errors = LoginValidator::validate($username, $password);
-
- if (empty($errors)) {
- // 最新の IP アドレスまたはログイン時刻をデータベースに保存し、ページ転送を処理します
- $dao = new UserDao();
- $user = $dao->findByName($username);
- $last_login_ip = Utils::getIpAddress ();
- $user->setLastLoginIp($last_login_ip);
- $now = new DateTime();
- $user->setLastLoginTime($now);
- $dao->save($user);
- UserLogin ::setUserInfo($user);
- Flash::addFlash('ログイン成功!');
- Utils::redirect('welcome');
- }
-
- foreach ($errors as $e) {
- $msg .= $e->getMessage()."
";
- }
- ?>
-
コードをコピー
|