Авторизация 1С на сайте PHP_AUTH_USER на CentOS apache / ~#root -i Авторизация 1С на сайте PHP_AUTH_USER на CentOS apache / ~#root -i Авторизация 1С на сайте PHP_AUTH_USER на CentOS apache / ~#root -i Авторизация 1С на сайте PHP_AUTH_USER на CentOS apache / ~#root -i Авторизация 1С на сайте PHP_AUTH_USER на CentOS apache / ~#root -i Авторизация 1С на сайте PHP_AUTH_USER на CentOS apache / ~#root -i Авторизация 1С на сайте PHP_AUTH_USER на CentOS apache / ~#root -i Авторизация 1С на сайте PHP_AUTH_USER на CentOS apache / ~#root -i
  • Создать интернет-магазин
  • Документация
  • Блог
    • Unix-подобные ОС
    • Php
    • MySQL
    • JavaScript
    • Менеджеры пакетов
    • Docker
    • Seo
  • Короткие ссылки
  • Вход
  • Регистрация
  • Главная
  • Php
  • Авторизация 1С на сайте PHP_AUTH_USER на CentOS apache

Авторизация 1С на сайте PHP_AUTH_USER на CentOS apache

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

Так вот, начитавшись литературы, понял что 1с обменивается хедерами с сайтом и прописывает ему PHP_AUTH_USER и PHP_AUTH_PW. Но в моем случае не получилось их словить в  $_SERVER (возможно какие-то настройки в 1с не проставил).

Изначально планировалось словить данные после авторизации так:

<?php
$dbSeq = ['user' => 'test', 'pass' => 'test'];
$this->login = isset($_SERVER['PHP_AUTH_USER']) ? trim($_SERVER['PHP_AUTH_USER']) : null;
$this->password = isset($_SERVER['PHP_AUTH_PW']) ? trim($_SERVER['PHP_AUTH_PW']) : null;

if ($this->password == $dbSeq['pass'] && $this->login == $dbSeq['user']) {
    return true;
}

Но 1с не отдавала ничего или сервер не мог принять эти данные (не смог найти причину).

1с авторизация

Моим решением стало пeренаправить HTTP:Authorization. Я использовал mod_rewrite на apache.

Обязательно в .htaccess должна быть строка:

RewriteEngine on

которая включает работу механизма преобразования в mod_rewrite.

В .htaccess после всех правил RewriteRule было добалвенно:

RewriteRule .* - [E=REMOTE_USER:%{HTTP:Authorization},L]

REMOTE_USER - указывает что {HTTP:Authorization} будет писаться в $_SERVER['REDIRECT_REMOTE_USER'].

Данные прилетели в base64.

var_dump($_SERVER['REDIRECT_REMOTE_USER']);

["REDIRECT_REMOTE_USER"]=>
  string(18) "Basic dGVzdDp0ZXN0"

Сделал с ними нехитрую манипуляцию:

<?php
$dbSeq = ['user' => 'test', 'pass' => 'test'];

if ($_SERVER["REDIRECT_REMOTE_USER"]) {
    $info = base64_decode(end(explode(' ',$_SERVER["REDIRECT_REMOTE_USER"])));
    $info = explode(':', $info);
    $this->login = $info[0]; // Прилетело test логин
    $this->password = $info[1]; // Прилетело test пароль
}

if ($this->password == $dbSeq['pass'] && $this->login == $dbSeq['user']) {
    return true;
}

root-i
14 Июня 18
620
0
Теги
CentOS 1С
Поделиться

Комментарии

Имя
Электронная почта
Рейтинг
Отзыв

Категории

  • Unix-подобные ОС
  • Php
  • MySQL
  • JavaScript
  • Менеджеры пакетов
  • Docker
  • Seo

Теги

Ubuntu 14.04 (15) Софт (11) Gearman (3) Сервисы (2) Framework (1) MVC (1) Php 5.6 (15) Cli (2) Propel (3) ORM (3) JavaScript (5) Css (1) Composer (4) Docker (3) Seo (4) MySQL (5) docker-compose (2) CentOS (1) 1С (1) Memcache (1) Memcached (1) Php 7 (5) Анализ (2) Ubuntu 18.04 (11) MySQL 5.7 (4) Генерация (2) Bower (1) Npm (1) NodeJs (3) Gulp (1) ImageCMS (2) Базы (1) JQuery (1) Сниппет (1)

Последние комментарии

Как вариант это может происходить из-за неизвестно...
root-i
21.01.22
Чтобы убрать ошибку Uncaught TypeError: $ is not a...
wlad2.ru
11.01.22
Спасибо!
Артём
04.09.21
tedy1, можно в index.php включить режим отладки и ...
root-i
18.03.21

Делюсь информацией в которой я требовал помощи и разбираясь затрачивал много времени. Если информация помогла хотя бы одному человеку, значит этот сайт создан не зря.

Благодарность, на продолжение работы сайта:
Контакты

Telegram Viber Mail

Поиск по сайту

  • Вход
  • Регистрация

Сайт работает на chmod -R