Размер шрифта
Цвет фона и шрифта
Изображения
Озвучивание текста
Обычная версия сайта
«8 Ядер» - готовые сайты, интернет-магазины на 1С-Битрикс
Сертифицированный партнёр 1С-Битрикс Аккредитация на портале Госзакупок 44-ФЗ и 223-ФЗ Участник Московского инновационного кластера
+7 906 740 88 03
+7 906 740 88 03
E-mail
customer@8cores.ru
Адрес
г. Москва, ул. Окская, 20к2, пом. 5/1
Режим работы
Пн. – Пт.: с 08:00 до 18:00 (мск)
Продукты
  • Готовые сайты
    • Интернет-магазины
    • Корпоративные сайты
    • Отраслевые сайты
  • Лицензии 1С-Битрикс
  • Продления лицензий
Услуги
  • Разработка сайтов и приложений
    • Запуск сайта на готовом решении 1С-Битрикс
    • Хостинг. Регистрация доменов
    • Разработка сайтов
    • Перенос сайта на 1С-Битрикс
    • Разработка модулей для 1С-Битрикс
    • Лендинг/визитка
  • Интеграция
    • Интеграция сайта с 1С
    • Интеграция с CRM Битрикс24
    • ERP для Производственной компании
    • Интеграция с ФГИС "АРШИН"
    • Интеграция с ФГИС ФСА
  • Поддержка
    • Техническая поддержка
    • Доработка существующего сайта
  • Дизайн
    • Разработка дизайна сайта
  • Информационная безопасность
    • Проверка сайта и удаление вирусов
  • Импорт/Парсинг
Кейсы
  • Разработка сайта
  • Техподдержка сайта
  • Интеграция систем
Блог
Компания
  • О компании
  • Как мы работаем
  • Сертификаты
  • Реквизиты
  • Документы
  • Партнёры
  • Вакансии
Контакты
Москва
«8 Ядер» - готовые сайты, интернет-магазины на 1С-Битрикс
Сертифицированный партнёр 1С-Битрикс Аккредитация на портале Госзакупок 44-ФЗ и 223-ФЗ Участник Московского инновационного кластера
Продукты
  • Готовые сайты
    Готовые сайты
  • Лицензии 1С-Битрикс
    Лицензии 1С-Битрикс
  • Продления лицензий
    Продления лицензий
Услуги
  • Разработка сайтов и приложений
    Разработка сайтов и приложений
  • Интеграция
    Интеграция
  • Поддержка
    Поддержка
  • Дизайн
    Дизайн
  • Информационная безопасность
    Информационная безопасность
  • Импорт/Парсинг
    Импорт/Парсинг
Кейсы
  • Разработка сайта
  • Техподдержка сайта
  • Интеграция систем
Блог
Компания
  • О компании
  • Как мы работаем
  • Сертификаты
  • Реквизиты
  • Документы
  • Партнёры
  • Вакансии
Контакты
    Москва
    +7 906 740 88 03
    +7 906 740 88 03
    E-mail
    customer@8cores.ru
    Адрес
    г. Москва, ул. Окская, 20к2, пом. 5/1
    Режим работы
    Пн. – Пт.: с 08:00 до 18:00 (мск)
    «8 Ядер» - готовые сайты, интернет-магазины на 1С-Битрикс
    Продукты
    • Готовые сайты
      Готовые сайты
    • Лицензии 1С-Битрикс
      Лицензии 1С-Битрикс
    • Продления лицензий
      Продления лицензий
    Услуги
    • Разработка сайтов и приложений
      Разработка сайтов и приложений
    • Интеграция
      Интеграция
    • Поддержка
      Поддержка
    • Дизайн
      Дизайн
    • Информационная безопасность
      Информационная безопасность
    • Импорт/Парсинг
      Импорт/Парсинг
    Кейсы
    • Разработка сайта
    • Техподдержка сайта
    • Интеграция систем
    Блог
    Компания
    • О компании
    • Как мы работаем
    • Сертификаты
    • Реквизиты
    • Документы
    • Партнёры
    • Вакансии
    Контакты
      Москва
      +7 906 740 88 03
      E-mail
      customer@8cores.ru
      Адрес
      г. Москва, ул. Окская, 20к2, пом. 5/1
      Режим работы
      Пн. – Пт.: с 08:00 до 18:00 (мск)
      «8 Ядер» - готовые сайты, интернет-магазины на 1С-Битрикс
      Телефоны
      +7 906 740 88 03
      E-mail
      customer@8cores.ru
      Адрес
      г. Москва, ул. Окская, 20к2, пом. 5/1
      Режим работы
      Пн. – Пт.: с 08:00 до 18:00 (мск)
      «8 Ядер» - готовые сайты, интернет-магазины на 1С-Битрикс
      • Продукты
        • Продукты
        • Готовые сайты
          • Готовые сайты
          • Интернет-магазины
          • Корпоративные сайты
          • Отраслевые сайты
        • Лицензии 1С-Битрикс
        • Продления лицензий
      • Услуги
        • Услуги
        • Разработка сайтов и приложений
          • Разработка сайтов и приложений
          • Запуск сайта на готовом решении 1С-Битрикс
          • Хостинг. Регистрация доменов
          • Разработка сайтов
          • Перенос сайта на 1С-Битрикс
          • Разработка модулей для 1С-Битрикс
          • Лендинг/визитка
        • Интеграция
          • Интеграция
          • Интеграция сайта с 1С
          • Интеграция с CRM Битрикс24
          • ERP для Производственной компании
          • Интеграция с ФГИС "АРШИН"
          • Интеграция с ФГИС ФСА
        • Поддержка
          • Поддержка
          • Техническая поддержка
          • Доработка существующего сайта
        • Дизайн
          • Дизайн
          • Разработка дизайна сайта
        • Информационная безопасность
          • Информационная безопасность
          • Проверка сайта и удаление вирусов
        • Импорт/Парсинг
      • Кейсы
        • Кейсы
        • Разработка сайта
        • Техподдержка сайта
        • Интеграция систем
      • Блог
      • Компания
        • Компания
        • О компании
        • Как мы работаем
        • Сертификаты
        • Реквизиты
        • Документы
        • Партнёры
        • Вакансии
      • Контакты
      • +7 906 740 88 03
        • Телефоны
        • +7 906 740 88 03
      • г. Москва, ул. Окская, 20к2, пом. 5/1
      • customer@8cores.ru
      • Пн. – Пт.: с 08:00 до 18:00 (мск)
      Сертифицированный партнёр 1С-Битрикс Аккредитация на портале Госзакупок 44-ФЗ и 223-ФЗ Участник Московского инновационного кластера
      Главная
      —
      Блог
      —
      1С-Битрикс
      —Перенос пользователей с паролями

      Перенос пользователей с паролями

      перенос пользователей с паролями
      1С-Битрикс
      18 сентября 2024

      Задача по переносу пользователей из одного Битрикс в другой.

      Для начала составьте таблицу соответствия групп пользователей, где ключи - id группы пользователей на первом сайте, а значения id соответствующей ему группы пользователей на втором. Примерно так:

      $tableOfGroups = [
          '1' => 1,
          '2' => 2,
          '3' => 3,
          '4' => 4,
          '5' => 9,
          '6' => 10,
          '7' => 11,
      ];
      Затем вам потребуется вручную внести на второй сайт Доп. поля (если они есть) с теми же самыми кодами. После чего разместите на первом сайте файл exportUSERS.php, а во втором importUSERS.php и пропишите соответствующие пути.

      Листинг файла exportUSERS.php:

      require_once($_SERVER['DOCUMENT_ROOT'].'/bitrix/modules/main/include/prolog_before.php');
      
      //Получаем список пользователей
      $rsUsers = CUser::GetList($by="", $order="",[],array("SELECT"=>array("UF_*")));
      while ($user = $rsUsers->Fetch()){
      
          $arUsers[$user['ID']] = $user;
      
          if($user['PERSONAL_PHOTO']){
              $arFileTmp = CFile::ResizeImageGet(
                  $user['PERSONAL_PHOTO'],
                  array("width" => 1000, "height" => 1000),
                  BX_RESIZE_IMAGE_PROPORTIONAL,
                  true
              );
      
              $arUsers[$user['ID']]['PERSONAL_PHOTO'] = 'http://' . $_SERVER['SERVER_NAME'] . $arFileTmp["src"];
          }
      
          $userGroups = CUser::GetUserGroup($user['ID']);
      
          $arUsers[$user['ID']]['A']['GROUPS'] = $userGroups;
      }
      
      echo json_encode($arUsers);
      
      die();
      
      require_once($_SERVER['DOCUMENT_ROOT'].'/bitrix/modules/main/include/prolog_after.php');
      Листинг файла importUSERS.php:

      require_once($_SERVER['DOCUMENT_ROOT'].'/bitrix/modules/main/include/prolog_before.php');
      
      $arTotal = array();
      
      $url = 'https://your_site.ru/exportUSERS.php';
      
      $postdata = array();
      
      $post = http_build_query($postdata);
      $ch = curl_init($url);
      curl_setopt($ch, CURLOPT_RETURNTRANSFER, TRUE);
      curl_setopt($ch, CURLOPT_POST, 1);
      curl_setopt($ch, CURLOPT_POSTFIELDS, $post);
      $response = curl_exec($ch);
      curl_close($ch);
      
      //Преобразовываем std в массив
      $response = json_decode($response, True);
      
      $arTotal['Получено пользователей'] = count($response);
      $arTotal['Занесено'] = 0;
      
      if(!CModule::IncludeModule("iblock")){die();}
      
      $tableOfGroups = [
          '1' => 1,
          '2' => 2,
          '3' => 3,
          '4' => 4,
          '5' => 9,
          '6' => 10,
          '7' => 11,
      ];
      
      $connection = Bitrix\Main\Application::getConnection('default');
      $sqlHelper = $connection->getSqlHelper();
      
      foreach ($response as $key => $value){
      
          $arFields = [];
      
          foreach ($value as $k => $v){
      
              switch ($k) {
                  case 'PERSONAL_PHOTO':
                      if($v){
                          $arIMAGE = CFile::MakeFileArray($value['PERSONAL_PHOTO']);
                          $arIMAGE["MODULE_ID"] = "main";
                          $arFields[$k] = $arIMAGE;
                      }
                      break;
                  case 'A':
                      $groupIDS = [];
                      //По таблице соответствия групп проставляем требуемые уровни доступа
                      foreach ($v['GROUPS'] as $name => $val){
                          array_push($groupIDS,$tableOfGroups[$val]);
                      }
                      $arFields['GROUP_ID'] = $groupIDS;
                      break;
                  case 'LID':
                      break;
                  case 'IS_ONLINE':
                      break;
                  case 'PASSWORD':
                      break;
                  case 'CHECKWORD':
                      break;
                  default:
                      if($v){
                          $arFields[$k] = $v;
                      }
                      break;
              }
          }
      
          $arFields['PASSWORD'] = 'blabla';
          $arFields['CHECKWORD'] = 'blabla';
      
          $user = new CUser;
      
          $ID = $user->Add($arFields);
          if (intval($ID) > 0){
              $arTotal['Занесено'] += 1;
      
              $connection->queryExecute("UPDATE b_user SET PASSWORD='".$sqlHelper->forSql ($value["PASSWORD"])."', CHECKWORD='".$sqlHelper->forSql ($value["CHECKWORD"])."' WHERE ID='".$ID."'");
      
          }else{
              $arTotal['Ошибки'] = $arTotal['Ошибки'].'
              '.$user->LAST_ERROR;
          }
      
      }
      Не забудьте запустить ваш файл importUSERS.php и дождаться окончания процесса импорта. После окончания импорта удалите оба файла.
      • Комментарии
      Загрузка комментариев...
      Назад к списку
      • 1С Администрирование 2
      • 1С-Битрикс 30
      • HTML/CSS 1
      • jQuery 2
      • PHP 2
      • Оптимизация 9
      1с 1С ajax apache api bitrix clean-param CRM cron curl etext get google htaccess html jivo jquery json market marketplace nginx openserver PageSpeed php php8 post robots robots.txt search seo web агенты администрирование артикул аспро битрикс боты вирус директория защита каталог композит кэш логи магазин маркетплейс метрика модальные окна настройка обмен онлайн консультант оптимизация ордер ошибки пагинация папка парсинг поиск покупка сервера склад скрипт спам страница тестирование троян ускорение установка ут цвета чпу юkassa яндекс
      Продукты
      Услуги
      Компания
      Блог
      Контакты
      Сертифицированный партнёр 1С-Битрикс Аккредитация на портале Госзакупок 44-ФЗ и 223-ФЗ Участник Московского инновационного кластера
      +7 906 740 88 03
      +7 906 740 88 03
      E-mail
      customer@8cores.ru
      Адрес
      г. Москва, ул. Окская, 20к2, пом. 5/1
      Режим работы
      Пн. – Пт.: с 08:00 до 18:00 (мск)
      customer@8cores.ru
      г. Москва, ул. Окская, 20к2, пом. 5/1
      © 2010-2025 «8 Ядер» - веб-студия полного цикла
      Политика конфиденциальности
      Разработано в