NativeScript - NotFound()上的补丁没有从后端获得任何响应

时间:2017-10-18 05:32:18

标签: asp.net-web-api nativescript

在我的后端上,我在该操作中得到了两个可能的响应。

第一个:

return Ok(new { Message = "email_confirmed" });

第二个:

return NotFound();

在我的前端上我得到了这个:

let url: string = "http://10.0.2.2:53286/api/Home/AccountValidation?codeActivation=" + this.code;

        this.http.patch(url, {

        }).subscribe((res) => {
            console.log(JSON.stringify(res));

            if(res.status != 404) {
                alert({title: "Sistema 3 Esferas", message: "¡Tu cuenta ha sido activada satisfactoriamente! :)", okButtonText: "¡Entendido!"});
                this.router.navigate(["/Miembro"]);
            } else {
                this.btnEnabled = true;
                alert({title: "Sistema 3 Esferas", message: "Has introducido un código inválido. :(", okButtonText: "Entiendo..."});
            }
        });

如果后端到达Ok(),则if会被执行,一切正常。 但是,如果我的后端到达第二个返回值,即NotFound(),则不会发生任何事情。您在log

的开头看到此subscribe()
console.log(JSON.stringify(res));

好吧,如果返回NotFound(),则日志中不会显示任何内容。这几乎就像订阅从未执行过一样。

为什么会这样?

1 个答案:

答案 0 :(得分:2)

您需要添加catch处理程序来捕获除200(OK)之外的所有其他响应,因为它们被视为错误,如下所示 -

this.http.patch(url, {

    }).subscribe((res) => {
        console.log(JSON.stringify(res));
            alert({title: "Sistema 3 Esferas", message: "¡Tu cuenta ha sido activada satisfactoriamente! :)", okButtonText: "¡Entendido!"});
            this.router.navigate(["/Miembro"]);
    }).catch(this.handleError);
};

private handleError(error: any) {
    let errMsg = (error.message) ? error.message :
        error.status ? `${error.status} - ${error.statusText}` : 'Server error';
    console.error(errMsg);

    this.btnEnabled = true;
            alert({title: "Sistema 3 Esferas", message: "Has introducido un código inválido. :(", okButtonText: "Entiendo..."});
}

更多信息请参阅https://hassantariqblog.wordpress.com/2016/12/03/angular2-http-patch-with-complex-object-using-observable-in-angular-2-application/