當前位置: 首頁>>代碼示例>>PHP>>正文


PHP Func::rand_string方法代碼示例

本文整理匯總了PHP中Func::rand_string方法的典型用法代碼示例。如果您正苦於以下問題:PHP Func::rand_string方法的具體用法?PHP Func::rand_string怎麽用?PHP Func::rand_string使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在Func的用法示例。


在下文中一共展示了Func::rand_string方法的2個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: registration

 function registration($arr)
 {
     $login = !empty($arr['login']) ? $arr['login'] : false;
     $pas = !empty($arr['pas']) ? $arr['pas'] : false;
     $email = !empty($arr['email']) ? $arr['email'] : '';
     //Валидация данных--------
     if ($email and !Func::valid_email($email)) {
         throw new Exception('Не верный адре электронной почты.');
     }
     if (mb_strlen($login, 'utf-8') < 3) {
         throw new Exception('Длина логина должна быть не менее 3х символов.');
     }
     if (mb_strlen($pas, 'utf-8') < 5) {
         throw new Exception('Длина пароля должна быть не менее 5и символов.');
     }
     if (!Func::valid_login($login)) {
         throw new Exception('Запрещённые символы в поле Login! Разрешены только буквы русского и латинского алфавита и цифры.');
     }
     //-------------------------
     $res = $this->db->prepare("SELECT id FROM users WHERE login=?;");
     $res->execute(array($login));
     if ($row = $res->fetch()) {
         throw new Exception("Пользователь с логином {$login} уже зарегистрирован. Выберите другой логин.");
     }
     if ($email) {
         $res = $this->db->prepare("SELECT id FROM users WHERE email=?;");
         $res->execute(array($email));
         if ($row = $res->fetch()) {
             throw new Exception('Пользователь с таким Email уже зарегистрирован.');
         }
     }
     //Удаляем не подтверждённые аккаунты, старше суток
     $this->db->query("DELETE FROM tmp_users WHERE time<UNIX_TIMESTAMP()-3600*24;");
     $res = $this->db->prepare("SELECT login FROM tmp_users WHERE login=?;");
     $res->execute(array($login));
     if ($row = $res->fetch()) {
         throw new Exception("Пользователь с логином {$login} ожидает подтверждение регистрации. Выберите другой логин.");
     }
     if ($email) {
         $res = $this->db->prepare("SELECT login FROM tmp_users WHERE email=?;");
         $res->execute(array($email));
         if ($row = $res->fetch()) {
             throw new Exception('Пользователь с таким Email ожидает подтверждение регистрации.');
         }
     }
     //Шифруем пароль
     $md5pas = md5('cms' . md5($pas));
     //Если требуется подтверждение $email--
     if ($this->conf['reg']['email_must']) {
         if (!$email) {
             throw new Exception('Необходим Email');
         } else {
             $code = Func::rand_string(10);
             $res = $this->db->prepare("INSERT INTO tmp_users (login,pas,email,code,time) VALUES (?,?,?,?,UNIX_TIMESTAMP());");
             if (!$res->execute(array($login, $md5pas, $email, $code))) {
                 throw new Exception($this->db->errorInfo());
             }
             //Высылаем код для подтверждения email
             $from_name = 'Администрация ' . $_SERVER['HTTP_HOST'];
             $from_email = 'admin@' . $_SERVER['HTTP_HOST'];
             $mail_subject = 'Подтверждение регистрации';
             $mail_text = 'Для подтверждения регистрации на сайте ' . H . ' перейдите по следующей ссылке:' . "\n" . H . '/login/email_confirm/' . $code;
             Func::send_mail($from_name, $from_email, $login, $email, $mail_subject, $mail_text);
             return array('pas' => $md5pas, 'email' => $email, 'login' => $login);
         }
     }
     //-------------------------------------
     $res = $this->db->prepare("INSERT INTO users (login, pas, email,reg_time) VALUES (?,?,?,UNIX_TIMESTAMP());");
     if (!$res->execute(array($login, $md5pas, $email))) {
         throw new Exception($this->db->errorInfo());
     }
     $id = $this->db->lastInsertId();
     return array('id' => $id, 'pas' => $md5pas, 'email' => $email, 'login' => $login);
 }
開發者ID:kostarev,項目名稱:test,代碼行數:74,代碼來源:SiteWrite.php

示例2: forget

 function forget()
 {
     $captcha = new Captcha();
     $this->des->set('captcha', $captcha);
     $this->des->set('title', 'Восстановление пароля');
     $this->des->set('forget', true);
     //Обработка формы---
     if (!empty($_POST['emlogin'])) {
         if (!$captcha->is_access($_POST['captcha'])) {
             $this->error('Не верно введены символы с картинки');
         }
         $res = $this->db->prepare("SELECT email,login FROM users WHERE login=? OR email=?;");
         $res->execute(array($_POST['emlogin'], $_POST['emlogin']));
         if (!($row = $res->fetch())) {
             if (Func::valid_email($_POST['emlogin'])) {
                 $this->error('Пользователь с таким Email не зарегистрирован', false);
             } else {
                 $this->error('Пользователь с таким логином не зарегистрирован', false);
             }
         } elseif (!$row['email']) {
             $this->error('У пользователя ' . $row['login'] . ' не заполнен Email. Смена пароля не возможна.', false);
         } else {
             $res = $this->db->prepare("SELECT login FROM tmp_users WHERE login=?;");
             $res->execute(array($row['login']));
             if ($arr = $res->fetch()) {
                 $this->error('Инструкция для смены пароля уже выслана вам на Email. Повторить попытку вы сможете через 24 часа.');
             }
             $code = Func::rand_string(20);
             $this->db->query("DELETE FROM tmp_users WHERE time<UNIX_TIMESTAMP()-3600*24;");
             $res = $this->db->prepare("INSERT INTO tmp_users (login,code,time) VALUES (?,?,UNIX_TIMESTAMP());");
             $res->execute(array($row['login'], $code));
             //Высылаем инструкцию по смене пароля
             $from_name = 'Администрация ' . $_SERVER['HTTP_HOST'];
             $from_email = 'admin@' . $_SERVER['HTTP_HOST'];
             $mail_subject = 'Смена пароля';
             $mail_text = $row['login'] . ', для смены пароля на сайте ' . H . ' перейдите по следующей ссылке:' . "\n" . H . '/login/change_pass/' . $code;
             Func::send_mail($from_name, $from_email, $row['login'], $row['email'], $mail_subject, $mail_text);
             $this->des->set('forget_email', true);
         }
     }
     //------------------
     $this->des->display('login');
 }
開發者ID:kostarev,項目名稱:test,代碼行數:43,代碼來源:login.php


注:本文中的Func::rand_string方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。