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


PHP password_hash函數代碼示例

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


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

示例1: add_member

function add_member($username, $password)
{
    require 'password.php';
    try {
        define('DB_HOST', getenv('OPENSHIFT_MYSQL_DB_HOST'));
        define('DB_PORT', getenv('OPENSHIFT_MYSQL_DB_PORT'));
        define('DB_USER', getenv('OPENSHIFT_MYSQL_DB_USERNAME'));
        define('DB_PASS', getenv('OPENSHIFT_MYSQL_DB_PASSWORD'));
        define('DB_NAME', getenv('OPENSHIFT_GEAR_NAME'));
        try {
            $dsn = 'mysql:dbname=members;host=' . DB_HOST . ';port=' . DB_PORT;
            $db = new PDO($dsn, DB_USER, DB_PASS);
        } catch (PDOException $ex) {
            echo 'Error!: ' . $ex->getMessage();
            die;
        }
        $password = password_hash($password, PASSWORD_BCRYPT);
        echo $password;
        $query = $db->query("USE members");
        $query = $db->query("INSERT INTO members (username, password) VALUES ('{$username}', '{$password}')");
        header('Location: main_login.php');
        return TRUE;
    } catch (Exception $ex) {
        return FALSE;
    }
}
開發者ID:jcomish,項目名稱:Web2,代碼行數:26,代碼來源:model.php

示例2: CreateNewAccount

 public static function CreateNewAccount()
 {
     // validate input
     if (!self::validateUserName(Request::post('new_account_name'))) {
         return false;
     }
     if (!self::validateUserPassword(Request::post('new_account_password'), Request::post('new_account_password_repeat'))) {
         return false;
     }
     // connect to database
     $db = Database::getFactory()->getConnection();
     if (!$db) {
         Session::add('feedback_negative', 'Critical error. Can\'t connect to database.');
         return false;
     }
     // get a password hash
     $passwordHash = password_hash(Request::post('new_account_password'), PASSWORD_DEFAULT);
     // write new users data into database
     $sql = "INSERT INTO users ( user_id,  user_name,  user_password,  user_registration_time)\n                       VALUES (:user_id, :user_name, :user_password, :user_registration_time)";
     $query = $db->prepare($sql);
     $query->execute(array(':user_id' => null, ':user_name' => Request::post('new_account_name'), ':user_password' => $passwordHash, ':user_registration_time' => time('c')));
     $count = $query->rowCount();
     if ($count == 1) {
         Session::add('feedback_positive', 'New account created successfully.');
         return true;
     }
     // if it gets to this point, something went wrong
     Session::add('feedback_negative', 'Something went wrong.');
     return false;
 }
開發者ID:shx13,項目名稱:skeletor,代碼行數:30,代碼來源:RegistrationModel.php

示例3: logreg

 public function logreg()
 {
     $flag = 1;
     $this->load->library('form_validation');
     // установка правил валидации
     $this->form_validation->set_rules($this->config->item('reg_validation'));
     if ($this->form_validation->run() === TRUE) {
         // получение данных с формы
         $email = $this->input->post('email');
         $pass = $this->input->post('password');
         $name = $this->input->post('name');
         $lastname = $this->input->post('lastname');
         $birthday = $this->input->post('birthday');
         $this->load->model("User_Model");
         $this->load->model('Cart_Model');
         $data['result'] = $this->User_Model->check_user($email, $pass);
         if ($data['result']['status'] == 2 && $flag > 0) {
             $this->User_Model->insert(array('email' => $email, 'password' => password_hash($pass, PASSWORD_DEFAULT), 'name' => $name, 'lastname' => $lastname, 'birthday' => $birthday));
             $data['result'] = array('status' => 0);
         }
     } else {
         $data['result']['status'] = 1;
         $data['result']['message'] = $this->form_validation->error_string();
     }
     $this->output->json_output($data);
 }
開發者ID:paintcast,項目名稱:loftphpdz7,代碼行數:26,代碼來源:User.php

示例4: testPassword

 public function testPassword()
 {
     $passwd = password_hash('WowSoSecretPassword', PASSWORD_DEFAULT);
     $this->assertEmpty($this->user->getPassword());
     $this->user->setPassword($passwd);
     $this->assertEquals($passwd, $this->user->getPassword());
 }
開發者ID:fer2d2,項目名稱:fernando.moro.php.ecp1,代碼行數:7,代碼來源:UserTest.php

示例5: add

 public function add()
 {
     $this->userObject = new User();
     $data = array('email' => $_POST['email'], 'password' => password_hash($_POST['password'], PASSWORD_DEFAULT), 'first_name' => $_POST['firstname'], 'last_name' => $_POST['lastname']);
     $result = $this->userObject->add_user($data);
     $this->set('message', $result);
 }
開發者ID:klgrimley,項目名稱:CIT-313,代碼行數:7,代碼來源:registercontroller.php

示例6: changePasswordddd

 public function changePasswordddd()
 {
     $pass = password_hash('Opti369', PASSWORD_DEFAULT);
     $data = array('password' => $pass);
     $this->db->where('id', 13);
     $this->db->update('tbl_sites', $data);
 }
開發者ID:svenhabex,項目名稱:dashboard-hotspot,代碼行數:7,代碼來源:Site_model.php

示例7: postShowRegisterPage

 public function postShowRegisterPage()
 {
     $errors = [];
     $validation_data = ['first_name' => 'min:3', 'last_name' => 'min:3', 'email' => 'email', 'verify_email' => 'email', 'password' => 'min:3', 'email' => 'equalTo:verify_email', 'password' => 'equalTo:verify_password'];
     // validate data
     $validator = new Validator();
     $errors = $validator->isValid($validation_data);
     //  print_r($errors);
     //  exit();
     // if validation fails, go back to register
     // page and display error message
     if (sizeof($errors) > 0) {
         $_SESSION['msg'] = $errors;
         header("Location: /register");
         exit;
     }
     // save this data into a database
     $user = new User();
     $user->first_name = $_REQUEST['first_name'];
     $user->last_name = $_REQUEST['last_name'];
     $user->email = $_REQUEST['email'];
     $user->password = password_hash($_REQUEST['password'], PASSWORD_DEFAULT);
     $user->save();
     echo "Posted!";
 }
開發者ID:Andy16296,項目名稱:acme,代碼行數:25,代碼來源:PageControllerVer1.php

示例8: createImageKey

 public function createImageKey($user, $dblink)
 {
     if ($stm = $dblink->prepare("SELECT 2fa_imgname FROM  " . TABLE_USERS . " WHERE email = ?")) {
         $stm->execute(array($user));
         $row = $stm->fetch();
         $stm = NULL;
         $file = 'uploads/2fa/' . $row['2fa_imgname'];
     }
     $im = new Image();
     $imageclean = $im->loadLocalFile($file);
     $imagekey = $im->embedStegoKey($imageclean);
     $stegoKey = $im->stegoKey;
     $hash = password_hash($stegoKey, PASSWORD_DEFAULT);
     if ($stm = $dblink->prepare("UPDATE " . TABLE_USERS . " SET 2fa_hash = ? WHERE email = ?")) {
         $stm->execute(array($hash, $user));
         $stm = NULL;
     }
     if (ob_get_level()) {
         ob_end_clean();
     }
     header('Content-Description: File Transfer');
     header('Content-Type: application/octet-stream');
     header('Content-Disposition: attachment; filename=KeyImage.png');
     header('Content-Transfer-Encoding: binary');
     header('Expires: 0');
     header('Cache-Control: must-revalidate');
     header('Pragma: public');
     //header('Content-Length: ' . filesize($file));
     $ok = imagepng($imagekey);
     //, NULL, 9
     imagedestroy($imagekey);
     return $ok;
 }
開發者ID:semaster,項目名稱:2FAuth-Steganography,代碼行數:33,代碼來源:AccountSetup2fa.php

示例9: 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

示例10: insert_user

    public function insert_user()
    {
        $project_type = $this->input->post('project_type');
        $project_title = $this->input->post('project_title');
        $project_category = $this->input->post('project_category');
        $project_ = $this->input->post('project_');
        $project_ = $this->input->post('project_');
        $project_ = $this->input->post('project_');
        $project_ = $this->input->post('project_');
        $project_ = $this->input->post('project_');
        $project_ = $this->input->post('project_');
        $project_ = $this->input->post('project_');
        $keypass = 'du_du_chinhi_' . $password;
        $password_hash = password_hash($keypass, PASSWORD_BCRYPT);
        //--------------------------------------------------------------------------
        $sqlch1 = 'SELECT user_name FROM users WHERE user_name = ? OR email = ?';
        $sqlcheck1 = $this->db->query($sqlch1, array($username, $email));
        if ($this->db->affected_rows() > 0) {
            print_r('Number of affected rows:' . $this->db->affected_rows() . '</br>');
            echo 'Either the Username or email already exists.</br>';
        } else {
            $sql = 'INSERT INTO users ( first_name, last_name, email, user_name, password )	
				  VALUES (' . $this->db->escape($firstname) . ',
						  ' . $this->db->escape($lastname) . ',
						  ' . $this->db->escape($email) . ',
						  ' . $this->db->escape($username) . ',
						  ' . $this->db->escape($password_hash) . ')';
            $result = $this->db->query($sql);
        }
        //----------------------------------------------------------------------------
        return $result;
    }
開發者ID:ismael-rivera,項目名稱:project-manati,代碼行數:32,代碼來源:model_projectcreate.php

示例11: agregarProductor

 public function agregarProductor()
 {
     $cadena = "1234567890abcd";
     for ($i = 0; $i <= 7; $i++) {
         $generador_password = substr($cadena, mt_rand(0, strlen($cadena) - 1), 1);
         $this->user_password .= $generador_password;
     }
     $this->user_password_hash = password_hash($this->user_password, PASSWORD_DEFAULT);
     $this->user_name = $this->nombre . $this->apellidop;
     $sql = "INSERT INTO usuarios(id_usuario, nombre, apellidop, apellidom) \r\n\t\t\t\tVALUES (null, '{$this->nombre}', '{$this->apellidop}', '{$this->apellidom}')";
     $insertUsuario = $this->db->consultaRetorno($sql);
     $sql = "SELECT id_usuario FROM usuarios";
     $selectUsuario = $this->db->consultaRetorno($sql);
     for ($i = 0; $row = $this->db->recorrer_assoc($selectUsuario); $i++) {
         $id_usuario = $row['id_usuario'];
     }
     $this->id_usuario = $id_usuario;
     $this->user_captcha = password_hash($_POST['user_captcha'], PASSWORD_DEFAULT);
     $sql = "INSERT INTO users(id_user, user_name, user_password_hash, user_email, user_captcha, idperfil, idusuario, user_registration_datetime)\r\n\t\t\tVALUES (null,'{$this->user_name}', '{$this->user_password_hash}', '{$this->user_email}', '{$this->user_captcha}', '{$this->tipo}', '{$this->id_usuario}', NOW())";
     $insertUser = $this->db->consultaRetorno($sql);
     if ($insertUsuario == true && $insertUser == true) {
         $this->link($this->user_name, $this->user_email, $this->user_password_hash, $this->user_captcha, $this->id_usuario);
     } else {
         $this->error[] = "<span class='label label-danger posicion'>Error Desconocido Intente De Nuevo.</span>";
         $sql = "DELETE FROM users WHERE idusuario = '{$this->id_usuario}'";
         $a = $this->db->consultaRetorno($sql);
         $sql = "DELETE FROM usuarios WHERE id_usuario = '{$this->id_usuario}'";
         $b = $this->db->consultaRetorno($sql);
     }
 }
開發者ID:comunidad-uimqroo,項目名稱:Tianguis,代碼行數:30,代碼來源:Productores.php

示例12: registrationUser

 public function registrationUser()
 {
     $this->load->library(["form_validation"]);
     $this->load->helper("email");
     $this->form_validation->set_rules("tabUsername", "Username", "trim|required|min_length[5]|max_length[40] ");
     $this->form_validation->set_rules("tabPassword", "Password", "required|min_length[2]|max_length[60] ");
     $this->form_validation->set_rules("tabEmail", "Email", "trim|required|valid_email|max_length[254]");
     $message = [];
     if ($this->form_validation->run()) {
         $this->load->model("Users");
         $user_signin_data = ["login" => $this->input->post("tabUsername", true), "password" => password_hash($this->input->post("tabPassword"), PASSWORD_BCRYPT), "email" => $this->input->post("tabEmail")];
         $message = ["text" => "User " . $user_signin_data["login"]];
         if (empty($this->Users->getUserByLogin($user_signin_data["login"]))) {
             $this->Users->add($user_signin_data);
             $template = "loginForm";
             $message["text"] .= " succesfully registered";
         } else {
             $template = "signupForm";
             $message["text"] .= " already exist";
         }
     } else {
         $this->form_validation->set_error_delimiters("<div class='text-danger'>", "</div>");
         $template = "signupForm";
     }
     $this->loadTemplateView($template, $message);
 }
開發者ID:ilyafanat,項目名稱:Users,代碼行數:26,代碼來源:Login.php

示例13: create

 public function create()
 {
     $firstname = $_POST['firstname'];
     $lastname = $_POST['lastname'];
     $email = $_POST['email'];
     $username = $_POST['username'];
     $password = password_hash($_POST['password'], PASSWORD_BCRYPT);
     $conn = Db::getConnection();
     $sql = "SELECT *\n\t\t\t\tFROM users";
     $q = $conn->prepare($sql);
     $q->execute();
     $users = $q->fetchAll(\PDO::FETCH_ASSOC);
     $validator = new Validator();
     $error = $validator->validateRegisterForm($_POST, $users);
     //echo '<pre>'; var_dump($error); echo '</pre>';die();
     if ($error) {
         //echo '<pre>'; var_dump($error);die(); echo '</pre>';
         $html = new Html($this->controllerName);
         $html->error = $error;
         //echo '<pre>'; var_dump($html->error);die(); echo '</pre>';
         //;kweojn'dlfv'dlfkv
         $html->render('index');
     } else {
         $newUserSql = "INSERT INTO users\n\t\t\t(`firstname`, `lastname`, `email`, `username`, `password`, `admin`)\n\t\t\tVALUES\n\t\t\t('{$firstname}', '{$lastname}', '{$email}', '{$username}', '{$password}', '0')";
         $q = $conn->prepare($newUserSql);
         $q->execute();
         header('Location: /login/index');
     }
 }
開發者ID:Mikili975,項目名稱:news_obj,代碼行數:29,代碼來源:RegisterController.php

示例14: testInsertMapped

 public function testInsertMapped()
 {
     $name = 'My Name';
     $this->mapped->insert(['email' => 'test+insertmapped@bapcat.com', 'password' => password_hash('password', PASSWORD_DEFAULT), 'user_name' => $name, 'age' => 5]);
     $user = $this->mapped->where('user_name', $name)->first();
     $this->assertSame($name, $user['user_name']);
 }
開發者ID:bapcat,項目名稱:remodel,代碼行數:7,代碼來源:GatewayQueryMappedTest.php

示例15: create

 public function create($data)
 {
     $options = array('cost' => 11);
     $data['password'] = password_hash($data['password'], PASSWORD_BCRYPT, $options);
     parent::create($data);
     return $this->db->insert_id();
 }
開發者ID:vjlomocso,項目名稱:meetthedocs,代碼行數:7,代碼來源:user_model.php


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