Работа с авторизацией \ регистрацией пользователя в Битрикс
Rus
Eng
Работа с авторизацией \ регистрацией пользователя в Битрикс

Генерация ссылок "Выйти" и "Регистрация"

if ($USER->IsAuthorized()){
	<a href="<?echo $APPLICATION->GetCurPageParam("logout=yes", array(
	"login",
	"logout",
	"register",
	"forgot_password",
	"change_password"));?>">Выйти</a>
}else{
	<a href="<?echo $APPLICATION->GetCurPageParam("register=yes", array(
	"login",
	"logout",
	"forgot_password",
	"change_password"));?>">Регистрация</a>
}

Проверяем, является ли $password текущим паролем пользователя

/**
 * Проверяем, является ли $password текущим паролем пользователя.
 *
 * @param int $userId
 * @param string $password
 *
 * @return bool
 */
function isUserPassword($userId, $password)
{
    $userData = CUser::GetByID($userId)->Fetch();

    $salt = substr($userData['PASSWORD'], 0, (strlen($userData['PASSWORD']) - 32));

    $realPassword = substr($userData['PASSWORD'], -32);
    $password = md5($salt.$password);

    return ($password == $realPassword);
}

За функцию спасибо Шокову Алексею

Проверяем пароль штатными средствами

$login = CUser::GetLogin(); //получаем логин текущего юзера
$USERcheck = new CUser;
$check = $USERcheck->Login($login, 'fsdfsfO', 'N', 'Y'); //проверяем верный ли пароль
print_r($check); //Если пароль верный, то вернет 1, в ином случае массив с ошибкой

Смена пароля пользователя

global $USER;
$arResult = $USER->ChangePassword("admin", "WRD45GT", "123456", "123456");
if($arResult["TYPE"] == "OK") echo "Пароль успешно сменен.";
else ShowMessage($arResult);

Валидация пароля средствами Битрикс

$policy = \CUser::GetGroupPolicy([3]); //Получаем политику безопасности для группы пользователей с id = 3
$password = 'gdf';//Проверяем удовлетворяет ли правилам Битрикс новый пароль
$user = new CUser; //CheckPasswordAgainstPolicy метод нестатический поэтому объявляем новый экземпляр класса CUser
$errors = user->CheckPasswordAgainstPolicy($password, $policy); //Если пароль подходит, то вернется пустой массив иначе в массиве будут перечислены все ошибки связанные с паролем

Боремся с проблемой конфликта сессий между основным сайтом и поддоменом

Добавляем в файл init.php

session_name(\Bitrix\Main\Config\Option::get('main', 'cookie_name') . '_PHPSESSID');

Сквозная авторизация на поддоменах

В первую очередь идем в настройки главного модуля и включаем опции

Распространять куки на все домены (только для https)
Распространять авторизацию на все домены (только для https)

Если авторизация до сих пор не работает, то смотрим настройки session.cookie_domain в php.ini

Здесь нужно указать домен сайт без протокола и поддомена. Точка перед переменной обязательна

.domain.com

Интересно будет ознакомиться со статьей:

Комментарии

Комментариев еще нет, Вы можете стать первым кто его оставит

Оставьте комментарий

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

Вы отвечаете на комментарий пользователя

Отправить

ОБРАТНАЯ СВЯЗЬ

Напишите мне

Вы разрабатываете новый сервис, вносите доработки в существующий и хотите лучше чем у конкурентов? Вы обратились по адресу. Предлагаю вам комплексную разработку сайтов студийного уровня. У меня вы можете заказать дизайн, верстку, програмированние, разработку нетрадиционного функционала, реализацию связи между CMS, CRM и Data Analitics, а так же все остальное касаемое сайтов, кроме продвижения.

Обращайтесь, я всегда проконсультирую по всем вопросам и помогу подобрать наиболее эффективное решение для Вашего бизнеса. Я занимаюсь созданием сайтов в Новосибирске и в других регионах России, также работаю со странами СНГ. Вы останетесь довольны нашим сотрудничеством

Во время отправки произошла ошибка, пожалуйста попробуйте еще раз через некоторое время
Сообщение отправлено успешно

Телефоны

+7(993) 007-18-96

Email

info@tichiy.ru

Адрес

Россия, г. Москва

Отправляя форму Вы автоматически подтверждаете, что ознакомились и принимаете Политику конфиденциальности сайта

Написать мне
Отправить
Отправляя форму Вы автоматически подтверждаете, что ознакомились и принимаете Политику конфиденциальности сайта
Отправка успешна!
Thank you for your feedback. I will answer you within the next working hours
Отправка не удалась
Во время отправки запроса произошла ошибка. Пожалуйста, подождите и попробуйте снова через некоторое время или свяжитесь со мной