Задать вопрос
@Kermet123

Почему не проходит Basic authorization?

Доброго времени суток.
Имеется простейшее rest api на сервере(apache)
Такое же простое приложение на React.
Для авторизации при запросах используется Basic authorization

Файл .htaccess
Header set Access-Control-Allow-Origin "*"
AuthType Basic
AuthName "Access to the staging site"
AuthUserFile /var/www/restapi/.htpasswd
Require valid-user

Как правильно передать заголовки с параметрами авторизации?
Пробовал так:
const fetchData = async () => {
    const { data } = await axios.get('http://restapi/api/product/read.php', {
      auth: {
        username: 'alex',
        password: 'hello',
      },
    })

Не работает. И я не понял, как параметры должы кодироваться base64, возможно это происходит где то под капотом axios.

Пробовал создавать инстанс axios вот так, тоже не работает.
const instance = axios.create({})

const authInterceptor = (config) => {
  config.headers.authorization = `Basic YWxleDpoZWxsbw==`
  return config
}

export const getData = async () => {
  const res = await instance.get('http://restapi/api/product/read.php')
  console.log(res)
}

В последнем случаи вылетает ошибка cors, хотя cors настроен. И если на сервере отключить авторизацию, удалив соответсвующие строки в файле .htaccess, все работает.
  • Вопрос задан
  • 103 просмотра
Подписаться 1 Простой 1 комментарий
Помогут разобраться в теме Все курсы
  • Яндекс Практикум
    Мидл фронтенд-разработчик
    5 месяцев
    Далее
  • Javascript.ru
    Курс по React
    5 недель
    Далее
  • Нетология
    Fullstack-разработчик на Python + нейросети
    20 месяцев
    Далее
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы
ITK academy Нижний Новгород
от 50 000 до 90 000 ₽
IT ATLAS Москва
от 200 000 до 250 000 ₽
ITK academy Казань
от 50 000 до 90 000 ₽