自动从另一个站点登录到wordpress仪表板

问题描述 投票:3回答:1

我想通过其他站点自动登录到WP admin / dashboard,而无需通过登录过程。我尝试了以下操作,但没有运气:

<?php

$username="admin";
$password="mypasw";
$url="http://example.com/";
$cookie="cookie.txt";

$postdata = "log=". $username ."&pwd=". $password ."&wp-submit=Log%20In&redirect_to=". $url ."wp-admin/&testcookie=1";
$ch = curl_init();
curl_setopt ($ch, CURLOPT_URL, $url . "wp-login.php");
curl_setopt ($ch, CURLOPT_SSL_VERIFYPEER, FALSE);
curl_setopt ($ch, CURLOPT_USERAGENT, "Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.8.1.6) Gecko/20070725 Firefox/2.0.0.6");
curl_setopt ($ch, CURLOPT_TIMEOUT, 60);
curl_setopt ($ch, CURLOPT_FOLLOWLOCATION, 1);
curl_setopt ($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt ($ch, CURLOPT_COOKIEJAR, $cookie);
curl_setopt ($ch, CURLOPT_REFERER, $url . "wp-admin/");
curl_setopt ($ch, CURLOPT_POSTFIELDS, $postdata);
curl_setopt ($ch, CURLOPT_POST, 1);
$result = curl_exec ($ch);
curl_close($ch);
echo $result;
exit;


?>

有点像只向我显示仪表板页面,但是我没有真正登录,因为单击管理页面上的任何按钮都只会重定向到该页面,即网站页面。.:(

php wordpress login automation
1个回答
13
投票

如果您有权访问尝试登录的网站文件。您可以在此脚本中添加一个自动登录的php脚本和$ _POST用户名和密码,例如:

if ($_POST) {

    $errors = array();

    $username = esc_sql($_REQUEST['username']);
    $password = esc_sql($_REQUEST['password']);
    $remember = esc_sql($_REQUEST['rememberme']);
    $remember = ($remember) ? "true" : "false";

    $login_data = array();
    $login_data['user_login'] = $username;
    $login_data['user_password'] = $password;
    $login_data['remember'] = $remember;
    $user_verify = wp_signon($login_data, true);

    if (is_wp_error($user_verify)) {
        $errors[] = 'Invalid username or password. Please try again!';
    } else {
        wp_set_auth_cookie($user_verify->ID);
        wp_redirect(admin_url());
        exit;
    }

}

Wordpress Codex参考:

希望有帮助。

Edit: $ wpdb-> escape自Wordpress 3.6版起已被弃用,请改用wpdb :: prepare()或esc_sql()!我已更改代码以使用esc_sql()。


0
投票

非常棒的人@Daniel,感谢您的分享,我在这部分上苦苦挣扎wp_set_auth_cookie($ user_verify-> ID);现在解决了。

© www.soinside.com 2019 - 2024. All rights reserved.