Меняем забытый пароль администратора для сайта на WordPress

Не так давно ко мне обратился один мой знакомый с просьбой помочь ему восстановить утерянный пароль администратора для сайта на CMS WordPress. Конечно же я не отказал ему в помощи, заодно подумал, что может это будет интересно также посетителям моего сайта.

Итак, представляю вам четыре несложных способа решения вопроса «как сбросить пароль администратора в блоговой системе управления содержимым сайтов WordPress, если вы его нечаянно забыли».

Варианты решений:

  • восстановить пароль по письму, высланному движком WordPress на ящик электронной почты;
  • восстановить пароль через SQL-запрос;
  • восстановить пароль путем правки php-кода шаблона активной темы оформления с вызовом функции wp_set_password()
  • восстановление пароля с помощью ftp+специального файла php

А теперь более подробнее.

  1. Восстановление пароля по адресу электронной почты:

Восстановить доступ к учетной записи можно, воспользовавшись ссылкой «Забыли пароль?», которая показывается в форме входа (http://www.example.com/wordpress/wp-admin или http://www.example.com/wordpress/wp-login.php). На ящик электронной почты пользователя придет письмо с другой ссылкой по которой можно будет без лишних проблем авторизоваться.

Восстановление пароля на WordPress

2. Восстановление пароля посредством sql+phpmyadmin:

Если описанный мною выше способ по каким-либо причинам вам не подходит, тогда можно зайти в phpMyAdmin и сменить данные прямым SQL-запросом к таблице wp_users, где administrator — это имя пользователя, а приставка «wp_» (без кавычек) — префикс, заданный вами при инсталляции движка.:

UPDATE  `wp_users` SET  `user_pass` = MD5(  'Новый пароль' ) WHERE  `user_login` =  'admin'

Для тех, кто с не знаком с языком структурированных запросов подойдет вариант с кликами мышкой: перейдите к базе данных CMS, затем выберите уже упомянутую таблицу, нажмите на ссылку «Изменить» напротив строки с вашим логином. После в форме редактирования выберите поле user_pass и из выпадающего списка столбца «Функция» выберите значение MD5. Правее наберите новый password, кликнете по кнопочке OK.

Восстановление пароля к WordPress с помощью phpMyAdmin

3. Восстановление пароля с помощью ftp+wordpress api:

Также можно зайти по FTP, а лучше через файловый менеджер хостинга и в коде активной темы вписать вызов следующей функции, где вместо звездочек вписываете новый пароль, а вместо переменной $user_id — целое число-идентификатор пользователя. Подсказка: у администратора он обычно равняется единичке.:

 <?php wp_set_password( '************', $user_id ) ?>

4. Восстановление пароля с помощью ftp+специального файла php:

Итак, по пунктам.

    1. Создаем файл, например, emergency.php
    2. Копируем в него нижеприведенный код
    3. Заходим на наш сайт по адресу http://имя_сайта.домен/emergency.php
    4. Меняем пароль администратора
  1. Обязательно удаляем закачанный нами файл emergency.php, иначе можем потерять весь сайт целиком
  2. Наслаждаемся восстановленным доступом к админке сайта на WordPress
<?php
/*  
    This program is free software; you can redistribute it and/or modify
        it under the terms of the GNU General Public License as published by
        the Free Software Foundation; either version 2 of the License, or
        (at your option) any later version.

    This program is distributed in the hope that it will be useful,
        but WITHOUT ANY WARRANTY; without even the implied warranty of
        MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
        GNU General Public License for more details.

    You should have received a copy of the GNU General Public License
        along with this program; if not, write to the Free Software
        Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
*/

require('./wp-blog-header.php');

function meh() {
global $wpdb;

        if (isset($_POST['update']))
        {
            $user_login = ( empty( $_POST['e-name'] ) ? '' : sanitize_user( $_POST['e-name'] ) );
            $user_pass  = ( empty( $_POST[ 'e-pass' ] ) ? '' : $_POST['e-pass'] );
            $answer = ( empty( $user_login ) ? '<div id="message"><p><strong>The user name field is empty.</strong></p></div>' : '' );
            $answer .= ( empty( $user_pass ) ? '<div id="message"><p><strong>The password field is empty.</strong></p></div>' : '' );
            if ( $user_login != $wpdb->get_var("SELECT user_login FROM $wpdb->users WHERE ID = '1' LIMIT 1") )
            {
                $answer .="<div id='message' class='updated fade'><p><strong>That is not the correct administrator username.</strong></p></div>";
            }
            if( empty( $answer ) )
            {
                $wpdb->query("UPDATE $wpdb->users SET user_pass = MD5('$user_pass'), user_activation_key = '' WHERE user_login = '$user_login'");
                $plaintext_pass = $user_pass;
                $message = __('Someone, hopefully you, has reset the Administrator password for your WordPress blog. Details follow:'). "\r\n";
                $message  .= sprintf(__('Username: %s'), $user_login) . "\r\n";
                $message .= sprintf(__('Password: %s'), $plaintext_pass) . "\r\n";
                @wp_mail(get_option('admin_email'), sprintf(__('[%s] Your WordPress administrator password has been changed!'), get_option('blogname')), $message);
$answer="<div id='message' class='updated fade'><p><strong>Your password has been successfully changed</strong></p><p><strong>An e-mail with this information has been dispatched to the WordPress blog administrator</strong></p><p><strong>You should now delete this file off your server. DO NOT LEAVE IT UP FOR SOMEONE ELSE TO FIND!</strong></p></div>";
            }
        }

        return ( empty( $answer ) ? false : $answer );
    }

$answer = meh();
?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>WordPress Emergency PassWord Reset</title>
<meta http-equiv="Content-Type" content="<?php bloginfo('html_type'); ?>; charset=<?php bloginfo('charset'); ?>" />
<link rel="stylesheet" href="<?php bloginfo('wpurl'); ?>/wp-admin/wp-admin.css?version=<?php bloginfo('version'); ?>" type="text/css" />
</head>
<body>
<div>
  <form method="post" action="">
<h2>WordPress Emergency PassWord Reset</h2>
<p><strong>Your use of this script is at your sole risk. All code is provided "as -is", without any warranty, whether express or implied, of its accuracy, completeness. Further, I shall not be liable for any damages you may sustain by using this script, whether direct, indirect, special, incidental or consequential.</strong></p>
<p>This script is intended to be used as <strong>a last resort</strong> by WordPress administrators that are unable to access the database.
Usage of this script requires that you know the Administrator's user name for the WordPress install. (For most installs, that is going to be "admin" without the quotes.)</p>
<?php
echo $answer;
?>
<p><input type="submit" name="update" value="Update Options" /></p>

<fieldset>
<legend>WordPress Administrator</legend>
<label><?php _e('Enter Username:') ?><br />
<input type="text" name="e-name" id="e-name" value="<?php echo attribute_escape(stripslashes($_POST['e-name'])); ?>" size="20" tabindex="10" /></label>
</fieldset>
<fieldset>
<legend>Password</legend>
<label><?php _e('Enter New Password:') ?><br />
<input type="text" name="e-pass" id="e-pass" value="<?php echo attribute_escape(stripslashes($_POST['e-pass'])); ?>" size="25" tabindex="20" /></label>
</fieldset>

<p><input type="submit" name="update" value="Update Options" /></p>
  </form>
</div></body></html>

Источники взяты тут.

Размещено в Wordpress и отмечено .

2 комментария

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *

Этот сайт использует Akismet для борьбы со спамом. Узнайте, как обрабатываются ваши данные комментариев.