angular调用接口方式_如何在Angular优雅编写HTTP请求

本文介绍了在Angular中如何优雅地处理HTTP请求,包括API设计原则,如版本号、业务节点和统一响应格式。通过引入HttpClientModule和HttpInterceptor,实现了身份认证、错误处理和状态码处理。示例展示了如何创建JWTInterceptor,处理请求前的身份验证,以及通过mergeMap和catch操作符进行异常处理。最后提到了async管道在模板中的使用以及将HTTP请求放在Service中的最佳实践。
摘要由CSDN通过智能技术生成

引言

基本上当下的应用都会分为前端与后端,当然这种前端定义不在限于桌面浏览器、手机、APP等设备。一个良好的后端会通过一套所有前端都通用的 RESTful API 序列接口作为前后端之间的通信。

这其中对于身份认证都不可能再依赖传统的Session或Cookie;转而使用诸如OAuth2、JWT等这种更适合API接口的认证方式。当然本文并不讨论如何去构建它们。

一、API 设计

首先虽然并不会讨论身份认证的技术,但不管是OAuth2还是JWT本质上身份认证都全靠一个 Token 来维持;因此,下面统一以 token 来表示身份认证所需要的值。

一套合理的API规则,会让前端编码更优雅。因此,希望在编写Angular之前,能与后端相互达成一种“协议”也很有必要。可以尝试从以下几点进行考虑。

版本号

可以在URL(例:https://demo.com/v1/)或Header(例:headers: { version: 'v1' })中体现,相比较我更喜欢前者的直接。

业务节点

以一个节点来表示某个业务,比如:

商品 https://demo.com/v1/product/

商品SKU https://demo.com/v1/product/sku/

动作

由HTTP动词来表示:

GET 请求一个商品 /product/${ID}

POST 新建一个商品 /product

PUT 修改一个商品 /product/${ID}

DELETE 删除一个商品 /product/${ID}

统一响应

这一点非常重要,特别是当我们新建一个商品时,商品的属性非常多,但如果我们缺少某个属性时。可以使用这样的一种统一的响应格式:

{

"code": 100, // 0 表示成功

"errors": { // 错误明细

"title": "商品名称必填"

}

}

其中 code 不管成功与否都会有该属性。

状态码

后端响应一个请求是包括状态码和响应内容,而每一种状态码又包含着不同的含义。

200 成功返回请求数据

401 无权限

404 无效资源

二、如何访问Http?

首先,需要导入 HttpClientModule 模块。

import { HttpClientModule } from '@angular/common/h

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值