Я пытаюсь создать приложение с использованием Angular2 в качестве интерфейса и cakephp 3 как REST Api, аутентификация работает нормально, но когда я пытаюсь получить доступ к любому другому URL-адресу, я получаю 401 Несанкционированное статус, и я заметил, что метод запроса OPTIONS вместо GET, что я использовал в моем коде, и Авторизация заголовок с моим маркером не отправляется на сервер:Угловая 2 не отправляет заголовок авторизации с использованием аутентификации JWT
Вот мой user.service.ts код:
constructor(private http: Http,
private router: Router,
) { }
login(email: string, password: string){
let headers: Headers = new Headers({ 'Accept': 'application/json','Content-Type': 'application/json' });
let options: RequestOptions = new RequestOptions({headers: headers});
return this.http.post('http://www.students.com/api/users/token.json', {email: email, password: password}, options)
.map((data: Response)=> data.json())
.subscribe(
(data)=> this.handlData(data),
(error)=> this.handlError(error)
);
}
getSessionData(){
let token = localStorage.getItem('usr_token');
let headers = new Headers({ 'Accept': 'application/json', 'Authorization': 'Bearer ' + token });
let options: RequestOptions = new RequestOptions({headers: headers});
return this.http.get('http://www.students.com/api/users/getSessionData', options).subscribe(
data => console.log(data),
err => console.log(err)
);
}
handlData(data){
if(data.success){
let usrData = data.data.user;
this.user = new User(usrData.email, usrData.firstname, usrData.lastname, usrData.role, data.data.token);
localStorage.setItem('id_token', data.data.token);
}
}
handlError(error){
console.log(error);
}
я пытался использовать angular2-JWT модуль, но я имел ту же ошибку, и чтобы убедиться, что мой API работает отлично, я проверил его с Почтальон хрома расширение, и она работала, как ожидалось:
и вот моя конфигурация Apache2 VirtualHost
<VirtualHost *:80>
ServerAdmin [email protected]
DocumentRoot /var/www/html/students
ServerName www.students.com
<Directory /var/www/html/students>
Require all granted
Options Indexes FollowSymLinks Includes
AllowOverride all
</Directory>
Header always set Access-Control-Allow-Origin "*"
Header always set Access-Control-Allow-Methods "POST, GET, OPTIONS"
Header always set Access-Control-Allow-Headers "Origin, X-Requested-With, Content-Type, Accept, Authorization"
</VirtualHost>
у кого-то была такая же проблема? любые идеи, почему это происходит?
вы смотрели на [этот ответ] (http://stackoverflow.com/a/38186000/2435473) –
спасибо за быстрый ответ , к сожалению, я уже это сделал, но не повезло –