wp_signon() не аутентифицирует пользователя, нужна помощь
Я использую форму для отправки POST-запроса на страницу и для входа пользователя с помощью wp_signon()
, чтобы аутентифицировать пользователя в моей установке WordPress, как описано в документации WP:
$creds = array();
$creds['user_login'] = $_POST["user-login"];
$creds['user_password'] = $_POST["user-password"];
$creds['remember'] = true;
$user = wp_signon( $creds, false );
После этого небольшого фрагмента кода я проверяю, вошел ли пользователь в систему:
if ( is_user_logged_in() ) { echo "SUCCESS"; } else { echo "FAIL!"; }
Но я постоянно получаю FAIL!
. Затем, после поисков, я нашел такой трюк:
wp_set_current_user( $user );
if ( is_user_logged_in() ) { echo "SUCCESS"; } else { echo "FAIL!"; }
Я получил SUCCESS
в этом случае, но когда я покидаю эту страницу, я снова и снова получаю FAIL
.
Может кто-нибудь объяснить мне, как войти в систему с помощью wp_signon()
так, чтобы пользователь не выходил из системы после смены страницы, перезагрузки или чего-либо еще.
Я получаю желаемый результат, когда захожу в /wp-admin
и вхожу через стандартную форму входа WP. Я могу перемещаться по всем страницам моего сайта WP, оставаясь в системе все время. Но когда я пытаюсь сделать это вне стандартной формы, я получаю FAIL
.
Помогите! ПОЖАЛУЙСТА!

Наконец-то это заработало на моей локальной установке WordPress после замены дефисов на подчеркивания в имени атрибута input и использования полных PHP-тегов <?php
вместо <?
. Финальный код приведен ниже - просто скопируйте и вставьте его в ваш шаблон.
<?php if ( isset($_POST["user_email"]) && isset($_POST["user_password"]) ) {
$user_login = esc_attr($_POST["user_email"]);
$user_password = esc_attr($_POST["user_password"]);
$user_email = esc_attr($_POST["user_email"]);
$user_data = array(
'user_login' => $user_login,
'user_pass' => $user_password,
'user_email' => $user_email,
'role' => 'student'
);
// Вставка нового пользователя в базу данных
//wp_insert_user( $user_data );
$creds = array();
$creds['user_login'] = $user_login;
$creds['user_password'] = $user_password;
$creds['remember'] = true;
$user = wp_signon( $creds, false );
$userID = $user->ID;
wp_set_current_user( $userID, $user_login );
wp_set_auth_cookie( $userID, true, false );
do_action( 'wp_login', $user_login );
}
if ( is_user_logged_in() ) : echo 'УСПЕХ'; ?>
<h1>HTML для авторизованного пользователя</h1>
<?php else : echo 'ОШИБКА!'; ?>
<form id="user-credentials" method="post" action="<?php the_permalink(); ?>">
<p><input name="user_email" type="text" placeholder="Email" /></p>
<p><input name="user_password" type="password" placeholder="Пароль" /></p>
<p><input type="submit" class="button blue size-s" value="Отправить" /></p>
</form>
<?php endif; ?>

Он сохраняет вас в системе при переходе на страницу, отличную от той, где находится форма? Где установлен wp_set_current_user();
?

да, у меня всё работает нормально, проверьте настройки cookies в вашем браузере

Я проверил cookies во всех браузерах. Они везде включены. Когда я использую этот код, пользователь входит в систему только при отправке POST-запроса формы. При перезагрузке страницы без отправки данных никто не авторизован. Я попробовал global $current_user; var_dump($current_user);
и получил дамп информации о пользователе только при отправке POST, в противном случае возвращается object(WP_User)#206 (7) { ["data"]=> NULL ["ID"]=> int(0) ...

также, когда я вхожу через стандартную форму входа WP с тем же пользователем, переменная $current_user
выводится корректно в обоих случаях. В чем моя ошибка??!!

вы вызываете и wp_insert_user()
, и wp_signon()
при каждом запросе? если да, попробуйте закомментировать wp_insert_user()
и затем войти, чтобы увидеть результат.

я загрузил файлы шаблонов на удаленный сервер, и все работает. Извините, что беспокоил вас так долго... это была моя ошибка. Похоже, что wp_signon();
работает как ожидалось

Если ваш пароль содержит символы # и/или @, необходимо выполнить urlencode перед отправкой в форме, а затем urldecode перед установкой учетных данных в wp_signon.
URL-кодировка для @ — это %40, для # — %23, а для ! — %21.
Например, если ваш пароль — mY!p@ssWord#, то перед отправкой POST-запроса его следует закодировать в mY%21p%40ssWord%23, а затем раскодировать перед установкой учетных данных для wp_signon.
