对于学校项目,我需要使用Angular创建一个简单的登录页面。单击登录按钮时,我需要在帖子中添加Authorization标头。我创建了一个后端,当我使用邮递员将我的授权值发布到该后端时,它的工作方式与后端没有任何问题。当我尝试使用我的前端发布到同一个后端时,它无法正常工作。向帖子添加标题的最佳方法是什么?似乎意见分歧。这是我的代码:
export class LoginComponent{
title = 'Login';
email = '';
password = '';
credentials = '';
basic = '';
constructor(private http:HttpClient){
}
createAuthorizationHeader(headers:Headers,basic){
headers.append('Authorization',basic);
}
login(event){
this.email = (<HTMLInputElement>document.getElementById("email")).value;
this.password = (<HTMLInputElement>document.getElementById("password")).value;
this.credentials = this.email + ":" + this.password;
this.basic = "Basic " + btoa(this.credentials);
console.log(this.basic);
let headers = new Headers();
headers.append('Content-Type','application/json');
headers.append('Authorization',this.basic);
let options = new RequestOptions({headers:headers});
console.log(headers);
return this.http.post('http://localhost:8000/api/v1/authenticate',options)
.subscribe(
res =>{
console.log(res);
},
err => {
console.log(err.message);
}
)
}
}
当我运行该代码时,我得到400状态响应并且不添加标题。
答案 0 :(得分:11)
HttpClient.post
期望第二个参数是POST请求的主体。在您的示例中,您提供Headers
作为正文,这不是您的意图。您可以使用以下方法正确提供标题:
return this.http.post('http://localhost:8000/api/v1/authenticate', null, options);
我在正文的示例中显示了null
,但您可能希望以某种形式包含email
和password
属性。
您正在混合Http
和HttpClient
。如果您要使用HttpClient
(现在是推荐的方法),则需要放弃RequestOptions
和Headers
以支持HttpHeaders
。这变为:
let headers = new HttpHeaders({
'Content-Type': 'application/json',
'Authorization': this.basic });
let options = { headers: headers };
其余代码与我上面显示的相同。重要的是要注意您的createAuthorizationHeader
函数将需要使用并返回HttpHeaders
,因为此类是不可变的,append
每次调用它时都会返回一个新对象。
您需要从HttpHeaders
导入@angular/common/http
。
答案 1 :(得分:2)
这可以帮助你
let headers = new Headers();
headers.append('Content-Type','application/json');
//post data missing(here you pass email and password)
data= {
"email":email,
"password":password
}
return this.http.post('http://localhost:8000/api/v1/authenticate',data,{ headers: headers})
.subscribe(
res =>{
console.log(res);
},
err => {
console.log(err.message);
}
)