Задать вопрос
@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, все работает.
  • Вопрос задан
  • 100 просмотров
Подписаться 1 Простой 1 комментарий
Помогут разобраться в теме Все курсы
  • beONmax
    Профессия Frontend разработчик
    12 месяцев
    Далее
  • beONmax
    Профессия Веб разработчик
    10 месяцев
    Далее
  • Нетология
    Frontend-разработка на React
    10 недель
    Далее
Пригласить эксперта
Ваш ответ на вопрос

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

Похожие вопросы
ITK academy Нижний Новгород
от 50 000 до 90 000 ₽
ITK academy Воронеж
от 50 000 до 90 000 ₽