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


PHP password_verify函數代碼示例

本文整理匯總了PHP中password_verify函數的典型用法代碼示例。如果您正苦於以下問題:PHP password_verify函數的具體用法?PHP password_verify怎麽用?PHP password_verify使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。


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

示例1: login

 public function login($request, $response, $args)
 {
     $data = json_decode($request->getBody());
     $user = R::findOne('user', 'username = ?', [$data->username]);
     if ($user === null) {
         $this->logger->addError('Login Attempt', [$data]);
         $this->apiJson->addAlert('error', 'Invalid username or password.');
         return $this->jsonResponse($response, 401);
     }
     if (!password_verify($data->password, $user->password_hash)) {
         $this->logger->addError('Login Attempt ', [$data]);
         $this->apiJson->addAlert('error', 'Invalid username or password.');
         return $this->jsonResponse($response, 401);
     }
     if (!$user->is_active) {
         $this->logger->addError('Login Attempt Inactive User ', [$data]);
         $this->apiJson->addAlert('error', 'This username is not active.');
         return $this->jsonResponse($response, 403);
     }
     $jwt = self::createJwt($user->id, $data->remember ? 100 : 1);
     $user = R::load('user', $user->id);
     $user->active_token = $jwt;
     $user->last_login = time();
     $user->logins += 1;
     R::store($user);
     $this->apiJson->setSuccess();
     $this->apiJson->addData($this->sanitizeUser($user));
     return $this->jsonResponse($response);
 }
開發者ID:kiswa,項目名稱:SMPLog,代碼行數:29,代碼來源:Auth.php

示例2: login

 function login()
 {
     $link = $this->db_connection();
     $pass = $_POST['user_password'];
     $user = $_POST['user_name'];
     $query = "SELECT password, user_type, name FROM user WHERE user_name='{$user}'";
     $result = mysqli_query($link, $query) or die(mysqli_error($link));
     if (mysqli_num_rows($result) == 1) {
         $result = mysqli_fetch_array($result);
         //$hash= password_hash($result[0], PASSWORD_DEFAULT);
         //$hash=$result[0];
         //echo $hash;
         //print_r($result);
         //           if($result[0]==$pass){
         if (password_verify($pass, $result[0])) {
             session_start();
             $_SESSION['type'] = $result[1];
             $_SESSION['name'] = $result[2];
             //echo $_SESSION['type'].'<br>'.$_SESSION['name']=$result[2];
             header("Location:card.php");
         } else {
             return $error = TRUE;
         }
     } else {
         return $error = TRUE;
     }
 }
開發者ID:usmanali126,項目名稱:injectpoint,代碼行數:27,代碼來源:inject_record_1.php

示例3: loginuser

function loginuser($username, $password)
{
    require '../vendor/autoload.php';
    $result = array();
    try {
        $uri = "mongodb://heroku_v7w2qftd:a5h7slci8p0b2p9nt7qe96hmvv@ds027483.mongolab.com:27483/heroku_v7w2qftd";
        $client = new MongoClient($uri);
        $db = $client->selectDB("heroku_v7w2qftd");
        $users = $db->users;
        $user = $users->findOne(array("username" => $username));
        $passhash = $user["password"];
        $firstname = $user["firstname"];
        $lastname = $user["lastname"];
        $middlename = $user["middlename"];
        $email = $user["email"];
    } catch (Exception $e) {
        $result['message'] = "Trouble connecting to database";
    }
    if ($user == null) {
        $result["message"] = "User doesn't exist";
    } else {
        if (password_verify($password, $passhash)) {
            $result["message"] = "SUCCESS";
            $result["username"] = $username;
            $result["firstname"] = $firstname;
            $result["lastname"] = $lastname;
            $result["middlename"] = $middlename;
            $result["email"] = $email;
        } else {
            $result["message"] = "Password doesn't match";
        }
    }
    return $result;
}
開發者ID:samc1213,項目名稱:Scholarly-Awards-Management,代碼行數:34,代碼來源:functions.php

示例4: postLogin

 public function postLogin(Request $request)
 {
     $this->validate($request, ['username' => 'required', 'password' => 'required']);
     $credentials = $request->only('username', 'password', 'active');
     $employee = Employee::where('username', $credentials['username'])->where('active', true)->first();
     if ($employee != null && password_verify($credentials['password'], $employee->password)) {
         if (!$employee->isadmin) {
             if (getenv('HTTP_X_FORWARDED_FOR')) {
                 $ip = getenv('HTTP_X_FORWARDED_FOR');
             } else {
                 $ip = getenv('REMOTE_ADDR');
             }
             $host = gethostbyaddr($ip);
             $ipAddress = 'Address : ' . $ip . ' Host : ' . $host;
             $count = Ipaddress::where('ip', $ip)->count();
             $today = date("Y-m-d");
             if ($count == 0 || $employee->loginstartdate == null || $today < date('Y-m-d', strtotime($employee->loginstartdate)) || $employee->loginenddate != null && $today > date('Y-m-d', strtotime($employee->loginenddate))) {
                 return view('errors.permissiondenied', ['ipAddress' => $ipAddress]);
             }
             if ($employee->branchid == null) {
                 return redirect($this->loginPath())->withInput($request->only('username', 'remember'))->withErrors(['username' => 'บัญชีเข้าใช้งานของคุณยังไม่ได้ผูกกับสาขา โปรดติดต่อหัวหน้า หรือผู้ดูแล']);
             }
         }
         if ($this->auth->attempt($credentials, $request->has('remember'))) {
             return redirect()->intended($this->redirectPath());
         }
     } else {
         return redirect($this->loginPath())->withInput($request->only('username', 'remember'))->withErrors(['username' => $this->getFailedLoginMessage()]);
     }
 }
開發者ID:x-Zyte,項目名稱:nissanhippro,代碼行數:30,代碼來源:AuthController.php

示例5: check

 /**
  * Mengecek nilai plain yang diberi dengan hash.
  *
  * @param  string  $value
  * @param  string  $hashed_value
  * @return bool
  */
 public static function check($value, $hashed_value)
 {
     if (strlen($hashed_value === 0)) {
         return false;
     }
     return password_verify($value, $hashed_value);
 }
開發者ID:eezhal92,項目名稱:not-gojek,代碼行數:14,代碼來源:Hash.php

示例6: validate

 /**
  * Validate that the given username and password are valid
  *
  * @param string  $user     Username
  * @param string  $pass     Password
  * @param boolean $isMd5    Flag to indicate whether incoming password 
  *                          is plaintext or md5
  *
  * @return boolean
  */
 public function validate($user, $userPass, $isMd5 = false, CI_Input $input = null)
 {
     $ret = $this->getUserByUsername($user);
     // make sure we're using an md5 format, passwords are hashed md5s (yes, really)
     $pass = $isMd5 ? $userPass : md5($userPass);
     // did we get a row and do the passwords match?
     if (isset($ret[0])) {
         if (password_verify($pass, $ret[0]->password)) {
             return true;
         } else {
             // may be the password in the database was stored when CI's
             // global_xss_filtering was set to true. We can only test for
             // this if the password passed in was not md5'd.
             if (false === $isMd5) {
                 $pass = $input->xss_clean($userPass);
                 $pass = md5($pass);
                 if (password_verify($pass, $ret[0]->password)) {
                     // it was! Let's store the actually $userPass
                     $password = password_hash(md5($userPass), PASSWORD_DEFAULT);
                     $this->db->where('username', $user);
                     $this->db->update('user', array('password' => $password));
                     return true;
                 }
             }
         }
     }
     return false;
 }
開發者ID:asgrim,項目名稱:joind.in,代碼行數:38,代碼來源:user_model.php

示例7: login

function login($username, $password)
{
    $pdo = pdo();
    $statement = $pdo->prepare("SELECT * FROM users WHERE username LIKE '{$username}'");
    $statement->execute();
    $rowcount = $statement->rowCount();
    if ($rowcount >= 1) {
        //echo 'username found!';
        $statement2 = $pdo->prepare("SELECT username FROM users WHERE username LIKE '{$username}'");
        $statement2->execute();
        $hash = $statement->fetch();
        $hash = $hash['password'];
        if (password_verify($password, $hash)) {
            //echo 'username and password match! - declaring session variables.';
            $_SESSION['username'] = $username;
            $_SESSION['password'] = $password;
            return 1;
            //username and password is a match! Successful login!
        } else {
            //wrong username or password!
            return 2;
        }
    } else {
        //there is no account with that username
        return 3;
    }
}
開發者ID:jomla97,項目名稱:overtion,代碼行數:27,代碼來源:model.php

示例8: authenticate

        function authenticate($username, $password) {
    
             $db = new PDO('mysql:dbname=dwa;host=localhost;charset=utf8', 'dbuser', '123');
                $db->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
            try {
               
                $stmt = $db->prepare("SELECT zaporka FROM korisnik WHERE korIme = :username");
                $stmt->bindParam(':username', $username);
                $stmt->execute();

                $result = $stmt->fetch(PDO::FETCH_ASSOC);

                $hash = $result['zaporka'];

                if(!password_verify($password, $hash)) {    
            
                    return false;
                }

                $stmt = $db->prepare("SELECT id, korIme, ime FROM korisnik WHERE korIme = :username");
                $stmt->bindParam(':username', $username);
                $stmt->execute();

                $user = $stmt->fetch();

                $_SESSION['user'] = $user['korIme'];
                return true;

            } catch(PDOException $ex) {
                echo "Nes ne valja: ".$ex->getMessage();
                return false;
            }
    }
開發者ID:Tropuska,項目名稱:labosi,代碼行數:33,代碼來源:auth.php

示例9: login

 public function login()
 {
     //if (auth()->is_logged()) {
     //   return redirect(base_url('dashboard'));
     // }
     $this->form_validation->set_rules('emailid', 'Email ID', 'trim|required|valid_email');
     $this->form_validation->set_rules('password', 'Password', 'trim|required');
     if ($this->form_validation->run() == FALSE) {
         $this->showLogin();
     } else {
         $user = $this->User_model->getByEmail($this->input->post('emailid'));
         if (empty($user)) {
             $data = array('message' => 'Invalid Email ID.');
         } elseif (!password_verify($this->input->post('password'), $user->password)) {
             $data = array('message' => 'Wrong Password.');
         } elseif ($user->status != '1') {
             $data = array('message' => 'Your account needs activation.');
         } else {
             auth()->login($user->u_id);
             return redirect(base_url('dashboard'));
         }
         $data['page'] = 'auth/login';
         $this->load->view('auth', $data);
     }
 }
開發者ID:kajamydeen75,項目名稱:urf-master,代碼行數:25,代碼來源:Auth.php

示例10: passwordExists

function passwordExists($dbConn, $username, $password)
{
    $isValid = false;
    $dbQuery = "SELECT Password FROM USERS WHERE Username = '" . $username . "' LIMIT 1";
    FB::info('passwordExists() query: ' . $dbQuery);
    $dbRows = mysqli_query($dbConn, $dbQuery);
    $dbValues = mysqli_fetch_assoc($dbRows);
    $dbPassword = $dbValues['Password'];
    if (password_verify($password, $dbPassword)) {
        $isValid = true;
        FB::log('Password is valid!');
        // Check if the password needs a rehash.
        if (password_needs_rehash($dbPassword, PASSWORD_DEFAULT)) {
            FB::log('Rehashing password!');
            $dbPassword = password_hash($password, PASSWORD_DEFAULT);
            $dbQuery = "UPDATE USERS SET Password = '" . $dbPassword . "' WHERE Username = '" . $username . "'";
            FB::info('Password rehash query: ' . $dbQuery);
            $dbRows = mysqli_query($dbConn, $dbQuery);
            if ($dbRows) {
                FB::log('Password rehash successful!');
            } else {
                FB::error('Password rehash failed: ' . mysqli_error($dbConn));
            }
        }
    }
    return $isValid;
}
開發者ID:Jayme-LB,項目名稱:prj666_public,代碼行數:27,代碼來源:selectQueries.php

示例11: loginUser

 public function loginUser()
 {
     $this->load->library(["form_validation"]);
     $this->load->helper("date");
     $this->form_validation->set_rules("username", "Username", "trim|required");
     $this->form_validation->set_rules("password", "Password", "required");
     $message = [];
     $template = "loginForm";
     if ($this->form_validation->run()) {
         $this->load->model("Users");
         $user_login_data = ["login" => $this->input->post("username", true), "password" => $this->input->post("password")];
         $login_data = $this->Users->getUserByLogin($user_login_data["login"]);
         if (!empty($login_data)) {
             if (password_verify($user_login_data["password"], $login_data->password)) {
                 $id_time = $this->Users->setLoginTime(["ip" => ip2long($this->input->server("REMOTE_ADDR")), "logged_at" => date("Y-m-d H:i:s"), "id_user" => $login_data->id]);
                 $this->session->set_userdata("logged_in", ["id_time" => $id_time, "login" => $login_data->login, "email" => $login_data->email, "id" => $login_data->id]);
             } else {
                 $message = ["error_text" => "Wrong password"];
             }
         } else {
             $message = ["error_text" => "User doesn't exist"];
         }
     } else {
         $this->form_validation->set_error_delimiters("<div class = 'text-danger'>", "</div>");
     }
     $this->getUserLoginTime($template, $message);
 }
開發者ID:ilyafanat,項目名稱:Users,代碼行數:27,代碼來源:Login.php

示例12: login

 function login()
 {
     $this->__is_logined();
     $this->form_validation->set_rules('email', '이메일', 'required|valid_email');
     $this->form_validation->set_rules('password', '비밀번호', 'required');
     $isValidate = $this->form_validation->run();
     if ($isValidate) {
         $input_data = array('email' => $this->input->post('email'));
         $user = $this->user_model->get_user_by_email($input_data);
         // db 정보와 확인
         if ($user != null && $user->email == $input_data['email'] && password_verify($this->input->post('password'), $user->password)) {
             if ($user->is_admin) {
                 $this->handle_login($user);
             } else {
                 $this->session->set_flashdata('message', '관리자만 접근할 수 있습니다.');
                 redirect('auth/login');
             }
         } else {
             $this->session->set_flashdata('message', '로그인에 실패하였습니다.');
             redirect('auth/login');
         }
     } else {
         if ($this->input->get('returnURL') === "") {
             $this->__get_views('_AUTH/login');
         }
         $this->__get_views('_AUTH/login', array('returnURL' => $this->input->get('returnURL')));
     }
 }
開發者ID:jonghyeonim,項目名稱:solomon,代碼行數:28,代碼來源:auth.php

示例13: authenticateUser

 static function authenticateUser($email, $password)
 {
     if (empty($email)) {
         throw new InvalidArgumentException("email may not be empty", 400);
     }
     if (empty($password)) {
         throw new InvalidArgumentException("password may not be empty", 400);
     }
     require_once '../api/include/connect_db.php';
     $conn = connect_db();
     $email = $conn->real_escape_string($email);
     $password = $conn->real_escape_string($password);
     $sql_query = "SELECT `id`,`hash` FROM `users` WHERE ";
     $sql_query .= "`email`='{$email}' LIMIT 1";
     if (!($result = $conn->query($sql_query))) {
         throw new DatabaseException();
     }
     if ($result->num_rows === 0) {
         throw new UnexpectedValueException("No such user", 400);
     }
     $row = mysqli_fetch_assoc($result);
     $hash = $row['hash'];
     $res = password_verify($password, $hash);
     if (!$res) {
         throw new UnexpectedValueException("Invalid credentials", 400);
     }
     return $row['id'];
 }
開發者ID:anush-cr,項目名稱:campusbookie,代碼行數:28,代碼來源:oauth_class.php

示例14: attempt_login

function attempt_login($user, $pass)
{
    global $dbHost, $dbUser, $dbPass, $dbName;
    $db = mysqli_connect($dbHost, $dbUser, $dbPass, $dbName);
    if ($db->connect_error) {
        echo "Failed to connect to Database";
        return false;
    }
    if (!($query = $db->prepare("SELECT password FROM users WHERE username = ?;"))) {
        echo "Failed to create query";
        return false;
    }
    if (!$query->bind_param("s", $user)) {
        echo "Failed to bind query params";
        return false;
    }
    if (!$query->execute()) {
        echo "Failed to execute query";
        return false;
    }
    $query->store_result();
    if ($query->num_rows === 0) {
        echo "Username does not exist!";
        return false;
    }
    $query->bind_result($passwordHash);
    $query->fetch();
    return password_verify($pass, $passwordHash);
}
開發者ID:ty-a,項目名稱:tynime,代碼行數:29,代碼來源:login.php

示例15: postShowLoginPage

 /**
  * Handle posted login data
  */
 public function postShowLoginPage()
 {
     if (!$this->signer->validateSignature($this->request->post['_token'])) {
         header('HTTP/1.0 400 Bad Request');
         exit;
     }
     $rules = ['email' => 'email|min:3', 'password' => 'min:3'];
     $validator = new Validator($this->request, $this->response, $this->session);
     $valid = $validator->validate($rules, '/login');
     if ($valid) {
         $okay = true;
         $email = $this->request->post['email'];
         $password = $this->request->post['password'];
         $user = User::where('email', '=', $email)->first();
         if ($user != null) {
             if (!password_verify($password, $user->password)) {
                 $okay = false;
             }
         } else {
             $okay = false;
         }
         if ($user && $user->active == 0) {
             $okay = false;
         }
         if ($okay) {
             $this->session->put('user', $user);
             $this->response->withMessage("Successfully logged in")->redirectTo("/");
         } else {
             $this->session->put('_error', 'Invalid login!!');
             $this->response->redirectTo('/login');
         }
     }
 }
開發者ID:tcs-udemy,項目名稱:introduction-to-unit-testing,代碼行數:36,代碼來源:AuthenticationController.php


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