微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

无法在 Angular 中进行 x-www-form-urlencoded POST

如何解决无法在 Angular 中进行 x-www-form-urlencoded POST

我有一个可用的 POST 和 GET 服务,并且没有发现 CORS 等问题。但是,我只是无法模仿在 Postman(它工作的地方)中执行的调用,我唯一能想象的是我以某种方式错误地设置了 x-www-form-urlencoded 格式。出于某种原因,谷歌搜索示例给了我很多的西班牙语和中文站点。但是,从那里复制示例并没有解决任何问题。

getToken(code: string): Observable<any> {

  let url = "https://localhost:44301/connect/token";

  let payload = {
    client_id: "awesome_client",client_secret: "HakunaMatata",redirect_uri: "http://localhost:44304/page01",code: code,grant_type: "authorization_code"
  };

  let headers = { "Content-Type": "x-www-form-urlencoded" };
  let options = { headers: headers };
  
  return this.http.post<any>(url,payload,options);
}

我知道有一些 changes in Angular 12 所以我尝试了一个不同的版本(也是基于谷歌搜索和示例)。同样的问题。

getToken(code: string): Observable<any> {
  ...
  return this.http.post<any>(
    url,payload.toString(),{
      headers: new HttpHeaders()
        .set('Content-Type','application/x-www-form-urlencoded')
    });
}

我只是看不到我错过了什么。 Postman 产生预期结果(body/x-www 已启用)。

https://localhost:44301/connect/token
client_id:awesome_client
client_secret:HakunaMatata
redirect_uri:http://localhost:44304/page01
代码:4B822...
grant_type:authorization_code

解决方法

当您使用 objet 作为 HTTP 客户端的主体时,它会将其序列化为 json。 如果您想将数据作为 x-www-form-urlencoded 发送,您需要使用 HttpParams 作为正文。

  getToken(code: string) {
    let url = 'https://localhost:44301/connect/token';

    let param = {
      client_id: 'awesome_client',client_secret: 'HakunaMatata',redirect_uri: 'http://localhost:44304/page01',code: code,grant_type: 'authorization_code'
    };
    var payload = new HttpParams({ fromObject: param });

    let headers = { 'Content-Type': 'x-www-form-urlencoded' };
    let options = { headers: headers };

    return this.http.post<any>(url,payload,options);
  }

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?