首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Angular2 ES5 -覆盖内容-在HTTP报头中键入

Angular2 ES5 -覆盖内容-在HTTP报头中键入
EN

Stack Overflow用户
提问于 2016-09-28 13:56:23
回答 3查看 1.5K关注 0票数 3

试图重写标题的内容类型,但它仍然在文本/纯文本中。有一种方法可以使用Ben的GateWayAPI,但希望有一个不涉及自定义包装的解决方案。

代码语言:javascript
运行
复制
    var url = this.url;
    var body = JSON.stringify({email_login: "login", password_login: "password"});
    var headers = new Headers({ 'Content-Type': 'application/x-www-form-urlencoded' });


    return this.http.post(url, body, {headers:headers})
        .map(function (response) {
            return response.json();
        })
        .catch(this.handleError);
EN

Stack Overflow用户

回答已采纳

发布于 2016-09-28 17:18:40

Request post of Http具有以下签名:

代码语言:javascript
运行
复制
post(url: string, body: any, options?: RequestOptionsArgs)

第三个参数是带有RequestOptionsArgs类型的参数,这意味着必须将RequestOptions传递给它,而不是Headers。您还应该使用箭头运算符(=>)而不是function。你要找的是这样的东西:

代码语言:javascript
运行
复制
result: any;

httpPostTest() {

var url = this.url;
var body = JSON.stringify({email_login: "login", password_login: "password"});

let headers: Headers = new Headers({'Content-Type': 'application/x-www-form-urlencoded' });
let options: RequestOptions = new RequestOptions({ headers: headers });

this.http.post(url, body, options)
    .map(response => {
        response = response.json();
    })
    .catch(this.handleError);
}

在此之后,您需要使用订阅来获取response,因此假设这个函数名为httpPostTest (我将在上面添加它),我们希望将响应存储在名为result的变量中

代码语言:javascript
运行
复制
this.httpPostTest().subscribe(
            response => { this.result = response; },
            error => { console.log('ERROR'); },
            () => { console.log('FINISHED')}
);
票数 3
EN
查看全部 3 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/39749667

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档