精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

三步法解析Axios源碼

開發 前端
宏觀的事聊完了,下面就詳細聊幾個核心細節吧:整個流程、請求/響應攔截器、dispatchRequest是個啥、請求/響應數據轉換器。

[[421684]]

一、領悟思想

Axios是一個基于Promise的HTTP庫,根據官網介紹,有以下幾個特點:

  • 在瀏覽器端會創建XMLHttpRequests
  • 在Node端會創建HTTP請求
  • 由于Axios是一個基于Promise的HTTP庫,所以其支持Promise API
  • 支持請求和響應攔截器
  • 支持請求和響應數據轉換
  • 支持取消請求
  • 自動轉換JSON數據
  • 客戶端支持防御XSRF攻擊

通過上述官網介紹的特點,我認為其突出的優點有三個:

  • 支持Promise API,可以方便進行鏈式調用;
  • 支持請求和響應攔截器,該攔截器將Node中中間件思想引入該庫,在請求發送之前和響應接收之后可以對其進行處理。
  • 支持數據轉換器,轉換器主要負責數據發送前以及響應接收后對數據的處理。

二、把握設計

理解了該庫設計的特點,下面從源碼目錄、抽象接口及核心設計原理三個層面對Axios進行整體的把握。

2.1 源碼目錄

如下所示是Axios的源碼目錄及各個文件的作用

2.2 抽象接口

對源碼的目錄有了一定了解,下面利用UML類圖對該系統各個模塊的依賴關系進一步了解,為后續源碼分析打好基礎。(看該圖注意對著源碼一起看)

2.3 設計原理

首先看一段代碼,這段代碼的執行順序包含著Axios的核心原理。

  1. axios.defaults.baseURL = 'http://localhost:8080' 
  2.  
  3. // 請求攔截器一 
  4. axios.interceptors.request.use( 
  5.     config => { 
  6.         console.log('請求攔截器一', config); 
  7.         return config; 
  8.     }, 
  9.     error => { 
  10.         console.log('request interceptor rejected1'); 
  11.         return Promise.reject(error); 
  12.     } 
  13. ); 
  14.  
  15. // 請求攔截器二 
  16. axios.interceptors.request.use( 
  17.     config => { 
  18.         console.log('請求攔截器二', config); 
  19.         return config; 
  20.     }, 
  21.     error => { 
  22.         console.log('request interceptor rejected2'); 
  23.         return Promise.reject(error); 
  24.     } 
  25. ); 
  26.  
  27. // 響應攔截器一 
  28. axios.interceptors.response.use( 
  29.     response => { 
  30.         console.log('響應攔截器一', response); 
  31.         return response; 
  32.     }, 
  33.     error => { 
  34.         console.log('response interceptor rejected1'); 
  35.         return Promise.reject(error); 
  36.     } 
  37. ); 
  38.  
  39. // 響應攔截器二 
  40. axios.interceptors.response.use( 
  41.     response => { 
  42.         console.log('響應攔截器二', response); 
  43.         return response; 
  44.     }, 
  45.     error => { 
  46.         console.log('response interceptor rejected2'); 
  47.         return Promise.reject(error); 
  48.     } 
  49. ); 
  50.  
  51. axios('/', { 
  52.     method: 'post'
  53.     headers: { 
  54.         'Content-Type''application/json' 
  55.     }, 
  56.     data: { 
  57.         test: 'test' 
  58.     }, 
  59.     // 請求轉換器 
  60.     transformRequest: [(data, headers) => { 
  61.         console.log('請求轉換器', data); 
  62.         return JSON.stringify(data) 
  63.     }], 
  64.     // 響應轉換器 
  65.     transformResponse: [(response, headers) => { 
  66.         console.log('響應轉換器', response); 
  67.         return response; 
  68.     }] 
  69. }) 
  70. .then((response) => { 
  71.     console.log(response.data) 
  72. }) 

寫了這么多代碼,大家肯定對這段代碼的執行結果很感興趣,為了滿足各位看客的好奇心,下面就直接拋出來這段結果。

不過單看執行結果也不能了解其核心設計原理呀,老鐵別急,其實小小代碼就已經包含了Axios的整個執行過程,通過觀察結果及代碼可以將整個過程簡化為下圖:

其核心原理就是這個嗎?是的,你沒有看錯,這就是Axios的核心設計原理,通過一系列鏈式的處理就能夠得到所需要的結果。

三、體會細節

宏觀的事聊完了,下面就詳細聊幾個核心細節吧:整個流程、請求/響應攔截器、dispatchRequest是個啥、請求/響應數據轉換器。

3.1 整體運行流程

在第二章中闡述了該核心原理,老鐵們一定對該整體是如何運轉起來的很感興趣吧,下面就來解答各位老鐵的疑惑——Axios

  1. function Axios(instanceConfig) { 
  2.   this.defaults = instanceConfig; 
  3.   // 攔截器實例化 
  4.   this.interceptors = { 
  5.     request: new InterceptorManager(), 
  6.     response: new InterceptorManager() 
  7.   }; 
  8.  
  9. // 通過一系列的繼承綁定操作,該函數其實就是axios函數 
  10. Axios.prototype.request = function request(config) { 
  11.   // …… 
  12.   config = mergeConfig(this.defaults, config); 
  13.  
  14.   // Set config.method 
  15.   // …… 
  16.  
  17.   // ****核心**** 
  18.   // 存儲該調用鏈的數組 
  19.   var chain = [dispatchRequest, undefined]; 
  20.   var promise = Promise.resolve(config); 
  21.  
  22.   // 將請求攔截器的內容塞到數組前面(注意用的unshift函數,這就很好的解釋了為什么先調用的請求攔截器后執行) 
  23.   this.interceptors.request.forEach(function unshiftRequestInterceptors(interceptor) { 
  24.     chain.unshift(interceptor.fulfilled, interceptor.rejected); 
  25.   }); 
  26.   // 將響應攔截器的內容塞到數組后面 
  27.   this.interceptors.response.forEach(function pushResponseInterceptors(interceptor) { 
  28.     chain.push(interceptor.fulfilled, interceptor.rejected); 
  29.   }); 
  30.    
  31.   // 利用Promise將整個數組中的內容串起來,這樣就可以按照順序鏈式執行了 
  32.   while (chain.length) { 
  33.     promise = promise.then(chain.shift(), chain.shift()); 
  34.   } 
  35.  
  36.   return promise; 
  37. }; 

是不是很巧妙?通過利用數組先來存儲需要的內容,先處理的在數組的前面(請求攔截器),后處理的在數組的后面(響應攔截器),然后利用Promise將整個內容串起來,很好的處理網絡請求屬于異步的問題——Perfect。

3.2 請求/響應攔截器

通過觀察第二部分的執行結果我們已經了解了請求/響應攔截器,下面就做一下總結:

  • 請求攔截器就是在發送請求前執行的回調函數,個人認為其最大功用就是對多個請求的配置進行統一修改
  • 仔細觀察發現請求攔截器1先加入但是后執行,是不是與整體運行流程中的代碼對上了。
  • 響應攔截器就是在請求得到響應后執行的回調函數,成功回調的參數就是響應response,其可以對多個請求的響應進行統一修改。

先拋出請求/響應攔截器的核心代碼

  1. function InterceptorManager() { 
  2.   this.handlers = []; 
  3.  
  4. // 注冊攔截器 
  5. InterceptorManager.prototype.use = function use(fulfilled, rejected) { 
  6.   this.handlers.push({ 
  7.     fulfilled: fulfilled, 
  8.     rejected: rejected 
  9.   }); 
  10.   return this.handlers.length - 1; 
  11. }; 
  12.  
  13. // 刪除攔截器 
  14. InterceptorManager.prototype.eject = function eject(id) { 
  15.   if (this.handlers[id]) { 
  16.     this.handlers[id] = null
  17.   } 
  18. }; 
  19.  
  20. // 對攔截器進行分發 
  21. InterceptorManager.prototype.forEach = function forEach(fn) { 
  22.   utils.forEach(this.handlers, function forEachHandler(h) { 
  23.     if (h !== null) { 
  24.       fn(h); 
  25.     } 
  26.   }); 
  27. }; 

看看攔截器的核心源碼,是不是發現與一種設計模式很像?對的,就是觀察者模式。當調用use方法的時候就會將回調函數(成功、失敗)保存至handlers屬性上,方便后期的調用;當調用eject方法的時候就會刪除對應索引位置回調函數;當調用forEach方法的時候就會就會對handlers屬性(存儲的攔截器回調)中的內容進行分發。

3.3 dispatchRequest是個啥

前面聊了整個請求的請求前(請求攔截器)和請求后(響應攔截器),是不是感覺少點東西,如何發請求,這就是我們本次要與大家一起嘮的dispatchRequest(config)。

  1. module.exports = function dispatchRequest(config) { 
  2.   // …… 
  3.  
  4.   //請求數據轉換 
  5.   config.data = transformData( 
  6.     config.data, 
  7.     config.headers, 
  8.     config.transformRequest 
  9.   ); 
  10.   // …… 
  11.    
  12.   // 獲取適配器:自己配置了就選自己的,自己沒有設置就選默認的(瀏覽器端就選xhrAdapter、node端就選httpAdapter;這也就是為什么Axios即支持瀏覽器又支持Node的原因) 
  13.   var adapter = config.adapter || defaults.adapter; 
  14.  
  15.   return adapter(config).then(function onAdapterResolution(response) { 
  16.     // …… 
  17.  
  18.     // 響應數據轉換器 
  19.     response.data = transformData( 
  20.       response.data, 
  21.       response.headers, 
  22.       config.transformResponse 
  23.     ); 
  24.  
  25.     return response; 
  26.   }, function onAdapterRejection(reason) { 
  27.     if (!isCancel(reason)) { 
  28.       // …… 
  29.  
  30.       // 響應數據轉換器 
  31.       if (reason && reason.response) { 
  32.         reason.response.data = transformData( 
  33.           reason.response.data, 
  34.           reason.response.headers, 
  35.           config.transformResponse 
  36.         ); 
  37.       } 
  38.     } 
  39.  
  40.     return Promise.reject(reason); 
  41.   }); 
  42. }; 

通過觀察整個請求流程中的中間環節——dispatchRequest,它一共做了三件事:

  • 調用請求數據轉換器轉換請求數據
  • 選擇合適的適配器發起請求——自己配置了就選自己的,自己沒有配置就選默認的(瀏覽器端就選xhrAdapter、node端就選httpAdapter;這也就是為什么Axios即支持瀏覽器又支持Node的原因)
  • 當請求數據返回后,調用響應數據轉換器轉換響應數據

3.4 請求/響應數據轉換器

既然3.3中提到了請求/響應轉換器,本節就來聊一聊它倆。

  1. // 核心源碼 
  2. module.exports = function transformData(data, headers, fns) { 
  3.   utils.forEach(fns, function transform(fn) { 
  4.     data = fn(data, headers); 
  5.   }); 
  6.  
  7.   return data; 
  8. }; 

請求數據轉換調用,實質上就是利用請求數據轉換器對請求頭和請求數據進行特定的處理(transformRequest為處理函數的數組,defaults中包含默認的配置)

  1. config.data = transformData( 
  2.   config.data, 
  3.   config.headers, 
  4.   config.transformRequest 
  5. ); 

響應數據轉換調用類似于請求數據轉換調用,對響應體進行一系列的處理(transformResponse為處理函數的數組,defaults中包含默認的配置)

  1. response.data = transformData( 
  2.   response.data, 
  3.   response.headers, 
  4.   config.transformResponse 
  5. ); 

四、結語

上述三章對Axios進行整體的分析,從Axios的特點、整體設計及關鍵環節三個方面進行了講述,通過閱讀源碼學到了很多知識,也能夠更加熟練的使用Axios。為了保證各位老鐵的學習Axios源碼的效果,對學習Axios源碼的兩條建議:

邊閱讀本文邊看源碼,能夠有更深入的理解。

 

不要糾結于具體的實現,從宏觀的角度去看源碼,這樣能夠節省大量時間。

 

責任編輯:武曉燕 來源: 前端點線面
相關推薦

2020-11-02 10:51:17

Express源碼Web

2021-09-04 23:26:26

源碼ExpressNode

2010-11-22 10:57:57

職場

2019-10-24 10:00:13

歸類分組分解問題代碼

2022-11-02 13:16:58

數據分析

2022-05-10 11:31:44

經營分析財務指標

2024-05-06 13:15:45

2025-09-12 07:00:00

網絡攻擊數據管理AI系統

2025-03-10 00:28:00

2021-03-02 07:02:45

Linux操作系統

2023-09-26 12:32:21

數據分析領導數據

2012-10-31 09:31:06

SSD使用壽命固態存儲

2020-11-04 00:00:29

Kerberos協議身份

2011-07-13 09:54:22

VMware故障vSphere

2009-02-04 09:45:05

Java SocketSocket APIJava編程

2012-08-08 17:05:36

App運營

2011-06-28 11:03:55

郵件歸檔

2012-12-24 09:49:24

產品經理產品設計

2022-05-21 23:56:16

Python庫搜索Python

2009-10-12 13:41:00

RHEL 內核
點贊
收藏

51CTO技術棧公眾號

91精品久久久久久久久不口人| 亚洲黄色成人网| 中文字幕乱码一区二区三区| 99久久久久久久| 国产一区二区三区四区三区四| 精品少妇一区二区三区视频免付费| 我的公把我弄高潮了视频| 国产高清视频在线| 国产福利一区二区三区视频在线| 久久久久亚洲精品| 在线观看日本中文字幕| 国产亚洲高清一区| 日韩欧美在线视频| 在线观看18视频网站| 水莓100国产免费av在线播放| 青青草国产精品97视觉盛宴| 欧美精品久久久久久久久久| 中文字幕第24页| 精品久久免费| 色老综合老女人久久久| 成年在线观看视频| aaa在线观看| 99精品视频在线观看免费| 成人黄在线观看| 久久精品视频1| 欧美激情91| 这里只有精品视频| 亚洲av无码一区二区三区网址| 日韩毛片免费看| 精品国产乱码久久久久久虫虫漫画| 一区二区在线观看网站| 精品福利视频导航大全| 成人av网站大全| 国产主播喷水一区二区| 国产精品va无码一区二区三区| 亚洲色图国产| 在线观看视频99| 爱爱的免费视频| 97品白浆高清久久久久久| 欧美性xxxxxxxx| 少妇av一区二区三区无码| 超碰电影在线播放| 国产精品久久久久久久久晋中 | 亚洲加勒比久久88色综合| 欧美男女交配视频| 午夜无码国产理论在线| 亚洲成人7777| 日韩成人三级视频| 日本在线视频www鲁啊鲁| 国产精品免费aⅴ片在线观看| 秋霞毛片久久久久久久久| 日本黄视频在线观看| 国产成人在线影院| 91视频网页| www.国产精品视频| 国产黄色精品视频| 亚洲最大的网站| 成人av无码一区二区三区| 狠狠色伊人亚洲综合成人| 国产精品一区二区久久久| 日韩精品在线一区二区三区| 久久久久国产精品一区二区| 欧洲精品久久久| 国产无套丰满白嫩对白| 国产一区二区你懂的| 欧美性做爰毛片| 欧美性猛交bbbbb精品| 国产日韩欧美高清免费| 欧美最顶级的aⅴ艳星| caoporn国产| 首页亚洲欧美制服丝腿| 国产精品久久久久久亚洲影视| 亚洲中文字幕无码爆乳av | 992tv成人免费影院| 日韩三级av在线| 国产一区二区精品| 国产精品福利在线| 亚洲字幕av一区二区三区四区| 精品一区二区成人精品| 91青青草免费观看| 午夜在线视频免费| 国产日产欧美一区| 只有这里有精品| 欧美黑人猛交的在线视频| 亚洲成人在线观看视频| 红桃av在线播放| 国产第一精品| 欧美xxx久久| 国产艳俗歌舞表演hd| 成人3d动漫在线观看| 欧美久久久精品| 一区二区三区视频免费看| 日韩一区精品视频| 97伦理在线四区| 色视频精品视频在线观看| 欧美国产国产综合| 国产精品啪啪啪视频| 欧美13videosex性极品| 欧美色大人视频| 色悠悠在线视频| 欧美一站二站| 久久免费观看视频| 伊人久久成人网| 成人综合在线视频| 先锋影音一区二区三区| 日本无删减在线| 色av一区二区| 免费黄色在线播放| 欧美在线观看视频一区| 国内精品伊人久久| 一二三区中文字幕| 26uuu精品一区二区三区四区在线| 亚洲三区在线| 精品众筹模特私拍视频| 欧美精品v日韩精品v韩国精品v| 日本不卡视频一区| 日韩电影二区| 欧美一区二区三区艳史| 99久久一区二区| 国产视频一区二区在线观看| 欧美中文字幕在线观看视频| 久久青草视频| 亚洲精品在线观看www| 青青草手机在线视频| 日本aⅴ免费视频一区二区三区| 国产精品一区免费观看| a级影片在线| 欧美日韩在线精品一区二区三区激情 | 精品呦交小u女在线| 中文字幕av播放| 日韩精品成人一区二区在线| 国产日韩在线一区二区三区| 好操啊在线观看免费视频| 色狠狠一区二区| 久久人妻少妇嫩草av无码专区| 中文字幕亚洲综合久久五月天色无吗''| 日本高清不卡的在线| 日韩专区第一页| 一区二区三区日本| 少妇愉情理伦片bd| 亚洲综合自拍| 成人网址在线观看| 免费黄色电影在线观看| 欧美综合欧美视频| 国产综合精品久久久久成人av| 国产精品久久久久久久免费软件 | 国产视频欧美视频| 亚洲精品视频在线观看免费视频| 国产精品一区二区不卡| 在线国产99| 日韩综合久久| www日韩中文字幕在线看| 91禁在线观看| 中文字幕欧美一| 污视频网站观看| 久久中文视频| 成人在线免费观看视视频| 日日夜夜精品一区| 欧美麻豆精品久久久久久| 天堂а√在线中文在线鲁大师| 日本欧美一区二区三区| 亚洲午夜激情| 高清不卡一区| 久久99久久亚洲国产| 亚洲国产精品久久久久久久| 亚洲综合视频网| 无码国产精品一区二区免费式直播| 国产精品hd| 国产一区二区黄色| 激情都市亚洲| 中文字幕综合在线| 99久久精品国产色欲| 亚洲精品国产视频| 日韩av无码一区二区三区不卡| 亚洲欧洲日本mm| 欧美综合激情| 日本亚洲欧洲无免费码在线| 久久成人18免费网站| 丰满少妇被猛烈进入| 天天av天天翘天天综合网色鬼国产| 国产成人无码一区二区在线观看| 日韩精品午夜视频| 亚洲免费视频播放| 欧美黄色影院| 国产精品亚洲自拍| 尤物yw193can在线观看| 日韩激情片免费| 中文字幕在线播放av| 亚洲精品一二三四区| 国产精品无码在线| 美国一区二区三区在线播放 | 久草在线青青草| 欧美日本在线播放| 久久高清无码视频| 国产日韩欧美综合一区| 超碰在线资源站| 国产欧美精品久久| 最新不卡av| 美女一区2区| 国产在线播放91| 啊啊啊久久久| xxxx性欧美| 日本私人网站在线观看| 91精品蜜臀在线一区尤物| 欧美bbbbbbbbbbbb精品| 中文字幕av一区二区三区| 日本一区二区免费视频| 久久精品国产99久久6| 尤物av无码色av无码| 91成人精品视频| 日本一区二区三区精品视频| 99久久免费精品国产72精品九九 | 成人午夜精品一区二区三区| 亚洲三级视频网站| 影音先锋中文字幕一区二区| 在线视频不卡国产| 欧美极品在线观看| 韩国精品一区二区三区六区色诱| 日韩在线你懂得| 清纯唯美日韩制服另类| 好看的中文字幕在线播放| 日韩最新中文字幕电影免费看| 先锋av资源站| 精品久久久久香蕉网| 国产精品欧美亚洲| 欧洲视频一区二区| 成人免费视频毛片| 亚洲福利视频导航| 久久久久久久久久网站| 国产精品伦理一区二区| 色欲av无码一区二区三区| 成人永久免费视频| 青娱乐国产精品视频| 久久国产精品区| 爆乳熟妇一区二区三区霸乳| 国产欧美三级| 免费国产黄色网址| 亚洲精品免费观看| 亚洲色成人www永久在线观看| 天天天综合网| 最新精品视频| 香蕉久久网站| 中国成人在线视频| 99久久九九| 欧美亚洲视频一区| 天堂美国久久| a级片一区二区| 欧美一区亚洲| 777久久精品一区二区三区无码| 91久久国产| 超级碰在线观看| 午夜国产欧美理论在线播放 | 91黄色免费看| 男人天堂av在线播放| 色综合婷婷久久| 亚洲第一网站在线观看| 色综合久久中文综合久久97 | 免费日本一区二区三区视频| www国产91| 丝袜美女在线观看| 久久久伊人日本| av资源网在线播放| 欧美综合激情网| 成人免费一区| 91免费国产网站| 999久久精品| 国产偷国产偷亚洲高清97cao| 精品视频自拍| 日韩中文不卡| 香蕉国产精品| 日韩xxxx视频| 天堂一区二区在线| 亚洲老女人av| 国产一区91精品张津瑜| 蜜臀av粉嫩av懂色av| 99国产精品久久久久久久久久| 亚洲熟妇一区二区三区| 中文字幕一区不卡| 久久综合色综合| 日韩欧中文字幕| 一本色道久久综合亚洲| 亚洲成人黄色网址| 黄色在线免费观看大全| 久久手机精品视频| 国产免费拔擦拔擦8x高清在线人| 国产成人精品久久| 麻豆精品在线| 久久亚洲精品欧美| 国产精品久久久久久久久久10秀| 免费网站在线观看视频 | 亚洲人成伊人成综合网小说| 国产精品theporn动漫| 欧美影视一区二区三区| 国产www视频| 亚洲精品有码在线| 国产黄网站在线观看| 国产91ⅴ在线精品免费观看| 五月天色综合| 久久久久久久久一区| 亚洲情侣在线| 麻豆av免费在线| 国产成人免费视| 波多野结衣一二三四区| 一区二区三区波多野结衣在线观看| 亚洲GV成人无码久久精品| 6080国产精品一区二区| 久久经典视频| 欧美华人在线视频| 未满十八勿进黄网站一区不卡| 免费成人在线观看av| 欧美午夜在线视频| 亚洲免费黄色网| 久久亚洲影视婷婷| 久久久久久久国产精品毛片| 欧美日韩国产综合一区二区| 无码国产伦一区二区三区视频 | 极品日韩久久| 91精品91| 美女少妇一区二区| 91麻豆.com| 国产一级二级毛片| 欧美丰满少妇xxxbbb| 国产小视频福利在线| 97视频com| 视频在线亚洲| 亚洲国产一区二区三区在线播| 国产九九精品| 波多野结衣办公室双飞| 一区二区三区在线影院| 国产一区二区在线视频聊天| 国产一区二区三区三区在线观看| 忘忧草在线日韩www影院| 国产成人精品免费视频大全最热 | 亚洲欧美国产一区二区三区| 变态调教一区二区三区| 97超碰在线播放| 亚洲影视一区| 91精品国产三级| 亚洲欧洲精品成人久久奇米网| 中日精品一色哟哟| 在线观看国产欧美| 精品123区| 色噜噜狠狠色综合网| 日韩中文字幕亚洲一区二区va在线| 人体私拍套图hdxxxx| 五月天网站亚洲| 无码国精品一区二区免费蜜桃 | 日韩欧美一区二区三区免费观看| 久久国产精品免费一区| 亚洲精选在线| 你懂的在线观看网站| 欧美日韩国产精品一区| 亚洲色大成网站www| 91成品人片a无限观看| 日韩欧美天堂| 国产91对白刺激露脸在线观看| 99久久国产综合精品女不卡| 久久夜靖品2区| 亚洲免费视频网站| 日韩成人亚洲| 椎名由奈jux491在线播放| 国产精品影音先锋| 国产亚洲精品成人| 亚洲韩国日本中文字幕| 中国字幕a在线看韩国电影| 日本一区视频在线| 久久成人麻豆午夜电影| 欧美成人精品激情在线视频| 精品日韩成人av| 麻豆国产在线| 视频在线一区二区三区| 国模无码大尺度一区二区三区| 久草资源在线视频| 亚洲精品天天看| 成人影院在线免费观看| 欧美大片免费播放| 99久久综合狠狠综合久久| 无码人妻一区二区三区免费| 中文字幕免费精品一区| 国产一区二区在线观| 免费一级特黄特色毛片久久看| 久久色在线视频| 一区二区三区午夜| 欧美精品激情blacked18| 国产成人精品三级高清久久91| www.精品在线| 亚洲国产精品视频| 成人不用播放器| 亚洲一区二区三区在线视频| 国产精品美女久久久| 日韩av毛片在线观看| 精品国产自在久精品国产| 超碰aⅴ人人做人人爽欧美| 在线视频亚洲自拍| 91麻豆swag| 精品国产av 无码一区二区三区| 91福利视频在线观看| 91久久夜色精品国产按摩| 日本黄色录像片| 欧美日韩成人一区二区|