ฉันสามารถเข้าสู่ระบบผู้ใช้ด้วยโปรแกรมโดยไม่ต้องใช้รหัสผ่านหรือไม่


32

ฉันสร้างผู้ใช้ด้วยตนเองโดยทางโปรแกรมและฉันต้องการลงชื่อเข้าใช้ผู้ใช้ที่เพิ่งสร้างใหม่ WP ทำให้ง่ายต่อการเข้าถึงรหัสผ่านที่ถูกแฮช แต่ไม่ใช่เวอร์ชันเพลนเท็กซ์ มีวิธีใช้ wp_signon () โดยไม่มีรหัสผ่านแบบธรรมดาหรือไม่?

ฉันพบคนหนึ่งที่อ้างว่าได้ทำสิ่งนี้ที่นี่แต่มันไม่ได้ผลสำหรับฉัน

ขอขอบคุณ!


ฉันคิดว่าคุณสามารถกำหนดวัตถุผู้ใช้ของผู้ใช้ที่คุณเพิ่งสร้างให้กับตัวแปรโกลบอล current_user
onetrickpony

คำตอบ:


32

wp_set_auth_cookie() จะเข้าสู่ระบบผู้ใช้โดยไม่ต้องรู้รหัสผ่าน


มันใช้งานได้ดีมาก อย่างไรก็ตามเมื่อฉันใช้มันเงื่อนไขis_user_logged_in()ดูเหมือนจะไม่ทำงาน คุณรู้หรือไม่ว่ามันกำลังดูสิ่งที่แตกต่างจากคุกกี้?
emersonthis

2
@Emerson - คุณมีตะขออะไรเข้าสู่ระบบใน? มันจะต้องมีก่อนที่จะส่งส่วนหัว ลองwp_set_current_userก่อนลงชื่อเข้าใช้ด้วย
Milo

ที่จริงฉันไม่ได้เรียกมันจากเบ็ดเลย ฉันเพิ่งเพิ่มwp_set_auth_cookie()เข้าสู่ฟังก์ชันลงชื่อเข้าใช้ ฉันคิดว่าฉันต้องคิดใหม่ ฉันจะค้นหา wp_set_current_user และรายงานกลับ ขอบคุณมากสำหรับความช่วยเหลือของคุณในครั้งนี้!
emersonthis

เป็นไปได้หรือไม่ที่จะล็อกอินผู้ใช้โดยไม่มีรายละเอียดของเขาอยู่ในฐานข้อมูล? แค่ตั้งค่าคุกกี้ไม่กี่ตัวในเบราว์เซอร์ผ่านสคริปต์ก็เพียงพอแล้ว โปรดแจ้งให้เราทราบ
shasi kanth

45

รหัสต่อไปนี้ทำงานสำหรับการเข้าสู่ระบบอัตโนมัติโดยไม่มีรหัสผ่านใด ๆ !

// Automatic login //
$username = "Admin";
$user = get_user_by('login', $username );

// Redirect URL //
if ( !is_wp_error( $user ) )
{
    wp_clear_auth_cookie();
    wp_set_current_user ( $user->ID );
    wp_set_auth_cookie  ( $user->ID );

    $redirect_to = user_admin_url();
    wp_safe_redirect( $redirect_to );
    exit();
}

มันใช้งานได้ดี เพียงชื่อผู้ใช้ก็เพียงพอซึ่งเป็นกรณีที่ไม่สำคัญ
shasi kanth

get_user_by()ส่งกลับค่าเท็จเมื่อล้มเหลวดังนั้นคุณควรตรวจสอบเท็จแทนวัตถุ WP_Error
Brian

@Sjoerd Linders ฉันจะขอสคริปต์ของคุณเพื่อบังคับให้ผู้ใช้เชื่อมต่อได้อย่างไร
RafaSashi

ฉันจะเก็บบล็อคโค้ดนี้ไว้ที่ไฟล์ไหน?
sgiri

8

ฉันได้พบวิธีแก้ไขปัญหาอื่นที่นี่ซึ่งใช้วิธีการที่ดีกว่า (อย่างน้อยในความคิดของฉัน ... ) ไม่จำเป็นต้องตั้งค่าคุกกี้ใด ๆ มันใช้ Wordpress API:

/**
 * Programmatically logs a user in
 * 
 * @param string $username
 * @return bool True if the login was successful; false if it wasn't
 */
    function programmatic_login( $username ) {
        if ( is_user_logged_in() ) {
            wp_logout();
        }

    add_filter( 'authenticate', 'allow_programmatic_login', 10, 3 );    // hook in earlier than other callbacks to short-circuit them
    $user = wp_signon( array( 'user_login' => $username ) );
    remove_filter( 'authenticate', 'allow_programmatic_login', 10, 3 );

    if ( is_a( $user, 'WP_User' ) ) {
        wp_set_current_user( $user->ID, $user->user_login );

        if ( is_user_logged_in() ) {
            return true;
        }
    }

    return false;
 }

 /**
  * An 'authenticate' filter callback that authenticates the user using only     the username.
  *
  * To avoid potential security vulnerabilities, this should only be used in     the context of a programmatic login,
  * and unhooked immediately after it fires.
  * 
  * @param WP_User $user
  * @param string $username
  * @param string $password
  * @return bool|WP_User a WP_User object if the username matched an existing user, or false if it didn't
  */
 function allow_programmatic_login( $user, $username, $password ) {
    return get_user_by( 'login', $username );
 }

ฉันคิดว่ารหัสนี้อธิบายตนเองได้:

ตัวกรองค้นหาวัตถุ WP_User สำหรับชื่อผู้ใช้ที่กำหนดและส่งคืน การเรียกใช้ฟังก์ชันที่wp_set_current_userมีวัตถุ WP_User ส่งคืนมาwp_signonตรวจสอบกับฟังก์ชันis_user_logged_inเพื่อให้แน่ใจว่าคุณล็อกอินแล้วและนั่นคือ!

รหัสที่ดีและสะอาดในความคิดของฉัน!


จะใช้ programmatic_login ได้ที่ไหน
RafaSashi

คำตอบที่สมบูรณ์แบบ!
Maximus

@Shebo ความคิดเห็นของคุณไม่ถูกต้อง บรรทัดแรกของฟังก์ชั่นตรวจสอบว่าอาร์เรย์$credentialsว่างเปล่าหรือไม่ หากอาร์เรย์ไม่ว่างเปล่า (ซึ่งเป็นกรณีในคำตอบของฉัน) ค่าจากอาร์เรย์จะใช้ในการตรวจสอบผู้ใช้
Mike

@ ไมค์ว้าวฉันจะทำยังไงดี ... แย่จังขอโทษที่ทำให้เข้าใจผิด ฉันจะลบความคิดเห็นแรกของฉันเพื่อหลีกเลี่ยงความสับสน วิธีแก้ปัญหาที่ดี :) :)
Shebo

5

มันใช้งานได้ดีสำหรับฉัน:

  clean_user_cache($user->ID);
  wp_clear_auth_cookie();
  wp_set_current_user($user->ID);
  wp_set_auth_cookie($user->ID, true, false);
  update_user_caches($user);

2

นอกจากนี้ Mike, Paul และ Sjoerd:

หากต้องการจัดการการlogin.phpเปลี่ยนเส้นทางให้ดีขึ้น:

//---------------------Automatic login--------------------

if(!is_user_logged_in()){

    $username = "user1";

    if($user=get_user_by('login',$username)){

        clean_user_cache($user->ID);

        wp_clear_auth_cookie();
        wp_set_current_user( $user->ID );
        wp_set_auth_cookie( $user->ID , true, false);

        update_user_caches($user);

        if(is_user_logged_in()){

            $redirect_to = user_admin_url();
            wp_safe_redirect( $redirect_to );
            exit;
        }
    }
}
elseif('http://' . $_SERVER['HTTP_HOST'] . $_SERVER['SCRIPT_NAME'] == wp_login_url()){

    $redirect_to = user_admin_url();
    wp_safe_redirect( $redirect_to );
    exit;
}

จะถูกวางไว้ในwp-config.phpหลังจาก

require_once(ABSPATH . 'wp-settings.php');

FYI

จากวิธีการด้านบนฉันได้เปิดตัวปลั๊กอินเพื่อให้ผู้ใช้เข้าสู่ระบบจาก wordpress หนึ่งไปยังอีกโดยการประสานข้อมูลผู้ใช้และคุกกี้เซสชั่น:

https://wordpress.org/plugins/user-session-synchronizer/

โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.