Angular Загрузка файла с использованием contenturl с базовой аутентификацией

У меня есть contentUrl, когда пользователь нажимает на него, файл должен быть загружен. Если я пытаюсь просмотреть contentUrl в браузере, он запрашивает идентификатор пользователя и пароль. Я считаю, что это обычная аутентификация. Я не хочу, чтобы пользователь вводил идентификатор пользователя и пароль, поэтому я передаю его авторизации (см. Код ниже). URL выглядит примерно так: http://xxx.xxx.xx.xxx:8080/flowable-rest/service/runtime/tasks/90875/attachments/90555/content

let username : string = 'admin';
let pwd : string = 'test';

let headers = new Headers();
headers.set('Accept', 'text/json'); 
headers.append('Content-Type', 'application/json');
headers.set('Access-Control-Allow-Origin', '*');
headers.set('Access-Control-Allow-Methods','POST, GET, OPTIONS, PUT, DELETE');
headers.set('Access-Control-Allow-Headers', 'Origin, X-Requested-With, Content-Type, Accept');
headers.append("Authorization", "Basic " + btoa(username + ":" + pwd)); 
return this.http.get(url, { headers: headers })
    .pipe(map(r => {
        console.log(r);           

    })).pipe(catchError(this.handleError));

Я не уверен на 100%, подходит ли этот подход для моего требования.

Я попробовал contentUrl в PostMan. В PostMan в правом нижнем углу появилась кнопка "Загрузить" и попросил меня скачать. Ниже приведено сообщение

Этот ответ не может быть предварительно просмотрен. Загрузите ответ, чтобы открыть его с соответствующим приложением.

Если я нажму "Скачать", мое приложение будет загружено.

Программно http.get эквивалентно Download? Если нет, то как мне его кодировать? В основном, мое требование - если я нажму на ссылку, приложение должно быть загружено.

1 ответ

Попробуйте установить withCredentials: true.

т.е.

// let username : string = 'admin'; //don't do this
// let pwd : string = 'test';   //don't do this
const headerJson = {
    'Content-Type': 'application/json'
};

const headers = new HttpHeaders(headerJson);

return this.http.get(url, { headers: headers, withCredentials: true })
    .pipe(map(r => {
        console.log(r);
    })).pipe(catchError(this.handleError));
Другие вопросы по тегам