加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

rest – Angular 2如何从后端读取自定义错误消息

发布时间:2020-12-17 18:05:11 所属栏目:安全 来源:网络整理
导读:我在AngularJS中不存在Angular 2的问题,我发送错误消息作为带有后端API调用的字符串,以防我有错误,错误状态401为例,问题现在我无法读取此消息来自Angular2的http响应消息,而我可以从AngularJS那样做: 我尝试了以下代码,没有任何帮助: 诺言: this._http.po
我在AngularJS中不存在Angular 2的问题,我发送错误消息作为带有后端API调用的字符串,以防我有错误,错误状态401为例,问题现在我无法读取此消息来自Angular2的http响应消息,而我可以从AngularJS那样做:

我尝试了以下代码,没有任何帮助:

诺言:

this._http.post('/login',{email: 'email@example.com',password: '123'})
            .toPromise()
            .then((resp) => console.log(resp),(error) => console.log(error));

观察到:

this._http.post('/login',password: '123'})
    .subscribe(response =>console.log(response),(error) => console.log(error));

从后端我发送响应作为文本,对于OK或Unauthorized,对于OK我发回String token == UUID.randomUUID().toString();,对于错误我发回消息如String error =“无效的凭据“;问题是console.log工作并打印文本以便成功(在这种情况下是令牌),但是如果出现错误,它只是打印:响应状态:200表示URL:null.

如果我将代码更改为JSON.stringify(错误),我得到这样的东西:

{"_body":{},"status":401,"ok":false,"statusText":"Unauthorized","headers":{"null":["HTTP/1.1 401 Unauthorized"],"Access-Control-Allow-Headers":["Origin"," X-Requested-With"," Content-Type"," Accept"," Referer"," User-Agent"],"Access-Control-Allow-Met
hods":["POST"," GET"," PUT"," DELETE"," OPTIONS"],"Access-Control-Allow-Origin":["*"],"Allow":["*"],"Content-Length":["36"],"Content-Type":["text/plain; charset=utf-8"],"Date":["Tue"," 23 Aug 2016 14:53:25 GMT"]},"type":2,"url":null}

正如你所看到的,甚至在Object内部都没有提到错误测试!!

我试图将后端的错误响应更改为返回json,如下所示:

{
   "message": "invalid email or password"
}

我可以在_body中得到结果,我只能这样读:console.log(error._body.message)!但我觉得这样做有些不对劲,我不想在这种情况下作为json回应.

对于angularjs(角度1),它只是打印响应,一切都很酷,而在角度2,这是一个真正的问题.

问题是什么,以及如何在没有任何重构后端的情况下解决这个问题?

编辑:

我正在使用Angular 2.0.0-rc.4和http:`“@ angular / http”:“2.0.0-rc.4”

解决方法

Mothanfar
在我的情况下,我正在使用Asp Web Api作为后端,这件事让我变得疯狂,我找到的唯一解决方案是转换为json并阅读消息,我知道这真的很丑,但对我有用.
问候.

CheckError(error: any) {
    let servermsg: any = JSON.parse(error._body)["ModelState"]["Login"][0];
    if (servermsg) {
        this.showMsg = true;
        this.msg = servermsg;
    }
}

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读