使用自定义 HTTP Interceptor 记录 SAP Sp
2021-11-30 本文已影响0人
华山令狐冲
最后的效果:
data:image/s3,"s3://crabby-images/7a625/7a625dda423a2937352d5c8e5d0b0ff32c03b7c1" alt=""
请求的方法类型和 url 都被记录了下来,同响应一起。
data:image/s3,"s3://crabby-images/09fc4/09fc4fd8f11a04ebf6a4c452112d8d6934d34aff" alt=""
设置断点来观察自定义 HTTP interceptor 运行时原理:
data:image/s3,"s3://crabby-images/10545/1054522a6f833046cd222ea553d4ae00fdfa6392" alt=""
我们自定义的 intercept 也是通过依赖注入的方式被注入到 httpInterceptor 的调度器里。
data:image/s3,"s3://crabby-images/b7794/b77941df081e4d4f6c34eb5755b09d6e95811359" alt=""
首先把 method 和 urlWithParams 从 request 里提取出来:
data:image/s3,"s3://crabby-images/3eabf/3eabfa799c234df7d9619c782a326ddb0224d24d" alt=""
返回的 Observable pipe 方法里的 switchMap 里的处理函数,什么时候会被触发?
data:image/s3,"s3://crabby-images/caa18/caa18346d9db642362ad13c53ccd0f468df5eb69" alt=""
在响应式编程的世界里,不要太在意 switchMap 里指定的函数体是何时被调用的——充斥的全是 rxjs 的回调。
data:image/s3,"s3://crabby-images/68f41/68f418291d8bb445a31dbefb33281911ccf80704" alt=""
只需要注意 switchMap 里必须返回一个 Observable wrapper 对象。
再看这个 custom interceptor 什么时候被实例化的?
data:image/s3,"s3://crabby-images/315ff/315ff8894d174c321b3762c7d48e70bb1f28c809" alt=""
首先把系统所有的 HTTP_INTERCEPTORS 注入的实现都取出来,放到数组里,然后使用数组的 reduceRight 方法,逐一调用之。
我们自定义的 Custom HTTP Interceptor 赫然在数组里,所以可以被调用到:
data:image/s3,"s3://crabby-images/b9f39/b9f390125a29ea4cea1d2e7db77c8fad30d9f046" alt=""
更多Jerry的原创文章,尽在:"汪子熙":
data:image/s3,"s3://crabby-images/9d5ff/9d5fffea0e5ec258def5c77c56d04b5c06480366" alt=""