ホームページ >バックエンド開発 >PHPチュートリアル >PHP で書かれたログイン ユーザー名とパスワードの検証ツール

PHP で書かれたログイン ユーザー名とパスワードの検証ツール

WBOY
WBOYオリジナル
2016-07-25 09:07:291274ブラウズ
  1. /**

  2. * ログイン用のバリデータ
  3. */
  4. final class LoginValidator {

  5. プライベート関数 __construct() {

  6. }
  7. /**

  8. * 指定されたユーザー名とパスワードを検証します。
  9. * @param $username と $password を検証します
  10. * {@link Error} の @return array 配列
  11. */
  12. public static function validate($username, $password) {
  13. $errors = array();
  14. $username = トリム($username);
  15. if (! $username) {
  16. $errors[] = new Error('username', 'Username を空にすることはできません。');
  17. } elseif (strlen($username)<3) {
  18. $errors[] = new Error( ' username', 'ユーザー名は 3 文字未満にすることはできません');
  19. } elseif (strlen($username)>30) {
  20. $errors[] = new Error('username', 'ユーザー名は 3 文字未満にすることはできません3 文字。');
  21. } elseif (!preg_match('/^[A-Za-z]+$/',substr($username, 0, 1))) {
  22. $errors[] = new Error( 'ユーザー名', 'ユーザー名は文字で始まる必要があります。');
  23. } elseif (!preg_match('/^[A-Za-z0-9_]+$/', $username)) {
  24. $errors[ ] = new Error('ユーザー名', 'ユーザー名には文字、数字、アンダースコア (_) の組み合わせのみを使用できます。');
  25. } elseif (!trim($password)) {
  26. $errors[] = new Error( 'password ', 'パスワードを空にすることはできません。 ');
  27. } else {
  28. // use が存在するかどうかを確認します
  29. $dao = new UserDao();
  30. $user = $dao->findByName($username); < /p>
  31. if ($user) {

  32. if (!($user->getPassword() == sha1($user->getSalt() . $password))) {
  33. $ errors[ ] = new Error('password', 'ユーザー名またはパスワードが正しくありません。 ');
  34. }
  35. } else {
  36. $errors[] = new Error('ユーザー名', 'ユーザー名が存在しません。');
  37. }
  38. }
  39. return $errors;
  40. }
  41. }
  42. ?>< /p>
コードをコピー

エラーは私が書いたクラスです:

  1. /**

  2. * 検証エラー
  3. */
  4. final class Error {

  5. private $source;

  6. private $message;< /p>
  7. /**
  8. * 新しいエラーを作成します。
  9. * @parammixed $source エラーのソース
  10. * @param string $message エラーメッセージ
  11. */
  12. function __construct($source, $message) {
  13. $this->source = $source;
  14. $this->message = $message;
  15. }

  16. /**

  17. * エラーのソースを取得します。
  18. * @return エラーの混合ソースを返します
  19. */
  20. public function getSource() {
  21. return $this->source;
  22. }

  23. *

  24. * エラーメッセージを取得します。
  25. * @return string エラーメッセージ
  26. */
  27. public function getMessage() {
  28. return $this->message;
  29. }
  30. }
  31. ?>

コードをコピーします

2. バリデーターを呼び出します。続行するには確認してください

  1. $username = null;
  2. $password = null;

  3. $msg = "";

  4. < ;p>if (isset($_POST['username']) && isset($_POST['password'])) {
  5. $username =addslashes(trim(stripslashes($_POST ['username'])));
  6. $password = addedlashes(trim(stripslashes($_POST ['password'])));
  7. // validate
  8. $errors = LoginValidator::validate($username, $password);
  9. if (empty($errors)) {
  10. // 最新の IP アドレスまたはログイン時刻をデータベースに保存し、ページ転送を処理します
  11. $dao = new UserDao();
  12. $user = $dao->findByName($username);
  13. $last_login_ip = Utils::getIpAddress ();
  14. $user->setLastLoginIp($last_login_ip);
  15. $now = new DateTime();
  16. $user->setLastLoginTime($now);
  17. $dao->save($user);
  18. UserLogin ::setUserInfo($user);
  19. Flash::addFlash('ログイン成功!');
  20. Utils::redirect('welcome');
  21. }
  22. foreach ($errors as $e) {
  23. $msg .= $e->getMessage()."
    ";
  24. }
  25. ?>

コードをコピー


声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。