欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

Angular8Http攔截器簡單使用教程

攔截器

創(chuàng)新互聯(lián)建站是一家集網(wǎng)站建設(shè),濱城企業(yè)網(wǎng)站建設(shè),濱城品牌網(wǎng)站建設(shè),網(wǎng)站定制,濱城網(wǎng)站建設(shè)報價,網(wǎng)絡(luò)營銷,網(wǎng)絡(luò)優(yōu)化,濱城網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強企業(yè)競爭力??沙浞譂M足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時我們時刻保持專業(yè)、時尚、前沿,時刻以成就客戶成長自我,堅持不斷學(xué)習(xí)、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實用型網(wǎng)站。

Http攔截器就是攔截發(fā)出的請求,對其進行統(tǒng)一添加額外處理,然后放行;對響應(yīng)進行攔截并作出業(yè)務(wù)上的判斷,決定是否給與返回。

先看一組常見的業(yè)務(wù)請求:

this.http.post('http://127.0.0.1:8080/api/getList', {
   header: {
    token: 'asdasdas'
   },
   observe: 'body',
   params: {
    pageSize: 10,
    pageIndex: 1
   },
   responseType: 'json',
   withCredentials: true
  });

可以看出有些配置是幾乎所有請求都共通得,有的需要token等參數(shù),一個項目全部手動寫得話,第一容易漏寫,第二以后如果有改動,需要所有接口都調(diào)整,不利于維護,最理想得狀態(tài)就是只修改參數(shù)和api地址,其他得交給特別得機制去處理,這就引出了今天的主角-HttpInterceptor

定義攔截器

按照官方約定,文件應(yīng)該是以‘.interceptor.ts'作為后綴

import { Injectable } from '@angular/core';
import { HttpInterceptor, HttpEvent, HttpHandler, HttpRequest, HttpResponse } from '@angular/common/http';
import { Observable } from 'rxjs';
import { tap } from 'rxjs/operators';
const ignoreToken = ['login', 'logout', 'table'];
@Injectable()
export class CommonInterceptor implements HttpInterceptor {
 intercept(req: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>> {
  // 先補全請求協(xié)議
  let url = req.url;
  const needToken = ignoreToken.filter(u => url.match(u));
  if (url.indexOf('http://') < 0 || url.indexOf('https://') < 0) {
   url = 'http://' + url;
  }
  // 過濾掉不需要token的請求
  if (!needToken.length) {
   req = req.clone({
    url
   });
  } else {
   req = req.clone({
    url,
    headers: req.headers.set('token', 'asdqwe')
   });
  }
  return next.handle(req).pipe(
   tap(
    event => {
     if (event instanceof HttpResponse) {
      console.log(event);
      if (event.status >= 500) {
       // 跳轉(zhuǎn)錯誤頁面
      }
     }
    },
    error => {
     // token過期 服務(wù)器錯誤等處理
    })
  );
 }
}

組件:

getTemp() {
  this.http.post('172.16.10.161:3000/table', {
   params: {
    pageSize: 10,
    pageIndex: 1
   }
  }).subscribe(res => {
   console.log(res);
  });
 }

該攔截器實現(xiàn)的功能比較簡單,但是結(jié)構(gòu)算是完整的,和管道類似,想應(yīng)用此攔截器需要注入在app模塊,

在providers數(shù)組種添加

{ provide: HTTP_INTERCEPTORS, useClass: CommonInterceptor, multi: true }

攔截器根據(jù)業(yè)務(wù)復(fù)雜度,其內(nèi)容也隨著復(fù)雜,通常管理下共通的配置,核心是處理各類異常,甚至錯誤碼處理。

總結(jié)

以上所述是小編給大家介紹的Angular8 Http攔截器簡單使用教程,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復(fù)大家的!

網(wǎng)頁名稱:Angular8Http攔截器簡單使用教程
文章網(wǎng)址:http://www.aaarwkj.com/article38/pjcesp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供商城網(wǎng)站、網(wǎng)站策劃App開發(fā)、網(wǎng)站設(shè)計、建站公司、品牌網(wǎng)站制作

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

綿陽服務(wù)器托管
国产福利三级在线观看| 视频精品一区二区在线观看| 自由成熟性生活免费视频| 日韩人妻精品久久免费| 性感91美女白丝在线精品| 日韩欧美啪啪一区二区| 国产精品久久久久精品爆| 国产无人区码一区二区| 亚洲五月综合激情综合久久| 国产一级二级三级黄色| 超碰97精品在线观看| 欧美日韩国产精品乱人伦| 大香蕉欧美视频伊在线| 又黄又湿又刺激中文字幕| 亚洲av午夜福利麻豆av | 国语自产拍在线观看不卡| 欧美国产综合欧美一区二区三区| 精品人妻一区二区三区四| 理论三级麻豆国产在线| 在线观看亚洲av日韩av| 日韩精品一区二区国产| 日本免费的高清一区二区| 亚洲精品成人一区二区| 日韩最新视频一区二区三| 久久精品国产亚洲av麻豆花絮 | 亚洲福利视频在线观看免费 | 日韩欧美一区二区三区在线| 欧美成人精品资源在线观看| 麻豆国产97在线精品一区| 偷拍一区二区三区夫妻| 翔田千里精品久久一区二| 91国产精品视频在线| 91精品手机在线观看| 国产精品国产三级国产av野外| 亚洲欧美午夜激情啪啪视频 | 久久精品一偷一偷国产| 国产一区二区精品久久岳| 国语对白自拍视频在线播放| 综合激情四射亚洲激情| 日本一区二区高清网址| 亚洲五月六月激情综合|