Angular请求报魔性400错误

HttpGet或 HttpPost都不能传包含 " 、“{"、"}"这样的参数,需要对特殊字符进行转义,把 " 转成%22,把 { 转成%7b,把 } 转成%7d
如果url中含有这些特殊字符,都需要进行转义,否则请求报400错误,这个问题还是花了一天时间都无法解决,最后加angular学习群(788980451)问大佬才解决的,感谢各位群里的各位大佬

原始URL:包含{ ' ' }  字符需要转义
     this.genanUrl = "http://localhost:4200/genan/api/MCU32/getDataCollect?skip=0&limit=500&jsonSql={sequence_id:'00022'}";
手动转义:
     this.genanUrl = "http://localhost:4200/genan/api/MCU32/getDataCollect?jsonSql=%7bsequence_id:%2700022%27%7d&limit=50&skip=0";
调用encodeURI()转义:
    this.genanUrl ="http://localhost:4200/genan//api/MCU32/getDataCollect?jsonSql={sequence_id:'00022'}&limit=500&skip=0";
    return this.http.post( encodeURI(this.genanUrl),{headers:headers});
   }

转义之后访问就可以成功了
Angular请求报魔性400错误_第1张图片

你可能感兴趣的:(angular)