簡體   English   中英

在PHP中使用wordpress加密密碼注冊用戶

[英]Register user with wordpress encryption password in PHP

我已經在Wordpress中創建了一個php文件,該文件使用哈希和鹽加密方法進行注冊,但是我的加密密碼與wordpress不同,由於不同類型的加密密碼,導致我無法登錄。 我可以像Wordpress一樣知道如何加密和檢索密碼嗎?

public function storeUser($name, $email, $password) {
        $uuid = uniqid('', true);
        $hash = $this->hashSSHA($password);
        $encrypted_password = $hash["encrypted"]; // encrypted password
        $salt = $hash["salt"]; // salt
        $result = mysql_query("INSERT INTO wp_users(unique_id, user_login, user_email, user_pass, salt, user_registered) VALUES('$uuid', '$name', '$name', '$encrypted_password', '$salt', NOW())");
        // check for successful store
        if ($result) {
            // get user details 
            $uid = mysql_insert_id(); // last inserted id
            $result = mysql_query("SELECT * FROM wp_users WHERE ID = $uid");
            // return user details
            return mysql_fetch_array($result);
        } else {
            return false;
        }
    }

    /**
     * Get user by email and password
     */
    public function getUserByEmailAndPassword($name, $password) {
        $result = mysql_query("SELECT * FROM wp_users WHERE user_login = '$name'") or die(mysql_error());
        // check for result $email
        $no_of_rows = mysql_num_rows($result);
        if ($no_of_rows > 0) {
            $result = mysql_fetch_array($result);
            $salt = $result['salt'];
            $encrypted_password = $result['user_pass'];
            $hash = $this->checkhashSSHA($salt, $password);
            // check for password equality
            if ($encrypted_password == $hash) {
                // user authentication details are correct
                return $result;
            }
        } else {
            // user not found
            return false;
        }
    }

    /**
     * Check user is existed or not
     */
    public function isUserExisted($name) {
        $result = mysql_query("SELECT user_login from wp_users WHERE user_login = '$name'");
        $no_of_rows = mysql_num_rows($result);
        if ($no_of_rows > 0) {
            // user existed 
            return true;
        } else {
            // user not existed
            return false;
        }
    }

    /**
     * Encrypting password
     * @param password
     * returns salt and encrypted password
     */
    public function hashSSHA($password) {

        $salt = sha1(rand());
        $salt = substr($salt, 0, 10);
        $encrypted = base64_encode(sha1($password . $salt, true) . $salt);
        $hash = array("salt" => $salt, "encrypted" => $encrypted);
        return $hash;
    }

    /**
     * Decrypting password
     * @param salt, password
     * returns hash string
     */
    public function checkhashSSHA($salt, $password) {

        $hash = base64_encode(sha1($password . $salt, true) . $salt);

        return $hash;
    }

}

是的,不要開始為此編寫自己的代碼。 WordPress更加復雜。

在您的php文件中包括wordpress並嘗試: <?php wp_create_user( $username, $password, $email ); ?> <?php wp_create_user( $username, $password, $email ); ?>

此處有更多詳細信息: https : //codex.wordpress.org/Function_Reference/wp_create_user

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM