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

前端代碼異常日志收集與監(jiān)控

開發(fā) 后端 前端
在復雜的網(wǎng)絡環(huán)境和瀏覽器環(huán)境下,自測、QA測試以及 Code Review 都是不夠的,如果對頁面穩(wěn)定性和準確性要求較高,就必須有一套完善的代碼異常監(jiān)控體系,本文從前端代碼異常監(jiān)控的方法和問題著手,盡量全面地闡述錯誤日志 收集各個階段中可能遇到的阻礙和處理方案。

在復雜的網(wǎng)絡環(huán)境和瀏覽器環(huán)境下,自測、QA測試以及 Code Review 都是不夠的,如果對頁面穩(wěn)定性和準確性要求較高,就必須有一套完善的代碼異常監(jiān)控體系,本文從前端代碼異常監(jiān)控的方法和問題著手,盡量全面地闡述錯誤日志 收集各個階段中可能遇到的阻礙和處理方案。

收集日志的方法

平時收集日志的手段,可以歸類為兩個方面,一個是邏輯中的錯誤判斷,為主動判斷;一個是利用語言給我們提供的捷徑,暴力式獲取錯誤信息,如 try..catchwindow.onerror。

1. 主動判斷

我們在一些運算之后,得到一個期望的結果,然而結果不是我們想要的

  1. // test.js 
  2. function calc(){  // code... 
  3.   return val;}if(calc() !== "someVal"){ Reporter.send({ position: "test.js::<Function>calc" msg: "calc error"  });} 

這種屬于邏輯錯誤/狀態(tài)錯誤的反饋,在接口 status 判斷中用的比較多。

2. try..catch 捕獲

判斷一個代碼段中存在的錯誤:

  1. try {  init();  // code... 
  2. catch(e){  Reporter.send(format(e));} 

init 為程序的入口,代碼中所有同步執(zhí)行出現(xiàn)的錯誤都會被捕獲,這種方式也可以很好的避免程序剛跑起來就掛。

3. window.onerror

捕獲全局錯誤:

  1. window.onerror = function() {  var errInfo = format(arguments);  Reporter.send(errInfo);  return true;}; 

在上面的函數(shù)中返回 return true,錯誤便不會暴露到控制臺中。下面是它的參數(shù)信息:

  1. /** * @param {String}  errorMessage   錯誤信息 * @param {String}  scriptURI      出錯的文件 * @param {Long}    lineNumber     出錯代碼的行號 * @param {Long}    columnNumber   出錯代碼的列號 * @param {Object}  errorObj       錯誤的詳細信息,Anything */window.onerror = function(errorMessage, scriptURI, lineNumber,columnNumber,errorObj) {     // code.. 

window.onerror 算是一種特別暴力的容錯手段,try..catch 也是如此,他們底層的實現(xiàn)就是利用 C/C++ 中的 goto 語句實現(xiàn),一旦發(fā)現(xiàn)錯誤,不管目前的堆棧有多深,不管代碼運行到了何處,直接跑到頂層或者 try..catch 捕獲的那一層,這種一腳踢開錯誤的處理方式并不是很好。

收集日志存在的問題

收集日志的目的是為了及時發(fā)現(xiàn)問題,***日志能夠告訴我們,錯誤在哪里,更優(yōu)秀的做法是,不僅告訴錯誤在哪里,還告訴我們,如何處理這個錯誤。***目標是,發(fā)現(xiàn)錯誤,自動容錯,這一步是最難的。

1. 無具體報錯信息,Script error.

先看下面的例子,test.html

 

  1. <!-- http://barret/test.html --> 
  2. <script>  window.onerror = function(){    console.log(arguments);  };</script> 
  3. <script src="http://barret/test.js"></script> 
  4.  
  5. test.js 
  6.  
  7. // http://barret/test.js 
  8. function test(){  ver a = 1;  return a+1;}test(); 

我們期望收集到的日志是下面這樣具體的信息:

為了對資源進行更好的配置和管理,我們通常將靜態(tài)資源放到異域上

  1. <!-- http://barret/test.html --> 
  2. <script>  window.onerror = function(){    console.log(arguments);  };</script> 
  3. <script src="http://localhost/test.js"></script> 

而拿到的結果卻是:

翻開 Chromium 的 WebCore 源碼,可以看到:

跨域情況下,返回的結果是 Script error.。

// http://trac.webkit.org/browser/branches/chromium/1453/Source/WebCore/dom/ScriptExecutionContext.cpp#L333
String message = errorMessage;
int line = lineNumber;
String sourceName
= sourceURL;
// 已經(jīng)拿到了所有的錯誤信息,但如果發(fā)現(xiàn)是非同源情況,`sanitizeScriptError` 中復寫錯誤信息
sanitizeScriptError(message, line, sourceName, cachedScript);

舊版 的 WebCore 中只判斷了 securityOrigin()->canRequest(targetURL),新版中還多了一個 cachedScript 的判斷,可以看出瀏覽器對這方面的限制越來越嚴格。

在本地測試了下:

可見在 file:// 協(xié)議下,securityOrigin()->canRequest(targetURL) 也是 false。

 為何Script error.?

簡單報錯: Script error,目的是避免數(shù)據(jù)泄露到不安全的域中,一個簡單的例子:

<script src="bank.com/login.html"></script>

上面我們并沒有引入一個 js 文件,而是一個 html,這個 html 是銀行的登錄頁面,如果你已經(jīng)登錄了 bank.com,那 login 頁面就會自動跳轉到 Welcome xxx...,如果未登錄則跳轉到 Please Login...,那么 JS 報錯也會是 Welcome xxx... is not defined,Please Login... is not defined,通過這些信息可以判斷一個用戶是否登錄他的銀行帳號,給 hacker 提供了十分便利的判斷渠道,這是相當不安全的。

crossOrigin參數(shù)跳過跨域限制

image 和 script 標簽都有 crossorigin 參數(shù),它的作用就是告訴瀏覽器,我要加載一個外域的資源,并且我信任這個資源。

<script src="http://localhost/test.js" crossorigin></script>

然而,卻報錯了:

這是意料之中的錯誤,跨域資源共享策略要求,服務器也設置 Access-Control-Allow-Origin 的響應頭:

header('Access-Control-Allow-Origin: *');

回頭看看我們 CDN 的資源,

Javascript/CSS/Image/Font/SWF 等這些靜態(tài)資源其實都已經(jīng)早早地加上了 CORS 響應頭。

2. 壓縮代碼無法定位到錯誤的具體位置

線上的代碼幾乎都是經(jīng)過打包壓縮的,幾十上百的文件壓縮后打包成一個,而且只有一行。當我們收到 a is not defined 的時候,如果只在特定場景下才報錯,我們根本無法定位到這個被壓縮的 a 是個什么東西,那么此時的錯誤日志就是無效的。

***個想到的辦法是利用 sourceMap,利用它可以定位到壓縮代碼某一點在未壓縮代碼的具體位置。下面是 sourceMap 引入的格式,在代碼的***一行加入:

//# sourceMappingURL=index.js.map

以前使用的是 ‘//@’ 作為開頭,現(xiàn)在使用 ‘//#’,然而對于錯誤上報,這玩意兒沒啥用。JS 不能拿到他真實的行數(shù),只能通過 Chrome DevTools 這樣的工具輔助定位,而且并不是每個線上資源都會添加 sourceMap 文件。sourceMap 的用途目前還只能體現(xiàn)在開發(fā)階段。

當然,如果理解了 sourceMap 的 VLQ編碼和位置對應關系,也可以將拿到的日志進行二次解析,映射到真實路徑位置,這個成本比較高,貌似暫時也沒人嘗試過。

那么,有什么辦法,可以定位錯誤的具體位置,或者說有什么辦法可以縮小我們定位問題的難度呢?

可以這樣考慮:打包的時候,在每兩個合并的文件之間加上 1000 個空行,***上線的文件就會變成

  1. (function(){var longCode.....})(); // file 1 
  2.  
  3. // 1000 個空行 
  4.  
  5. (function(){var longCode.....})(); // file 2 
  6.  
  7. // 1000 個空行 
  8.  
  9. (function(){var longCode.....})(); // file 3 
  10.  
  11. // 1000 個空行 
  12.  
  13. (function(){var longCode.....})(); // file 4 
  14.  
  15.  
  16. var _fileConfig = ['file 1''file 2''file 3''file 4'

如果報錯在第 3001 行,

  1. window.onerror = function(msg, url, line, col, error){  // line = 3001 
  2.   var lineNum = line;  console.log("錯誤位置:" + _fileConfig[lineNum % 1000 - 1]); // -> "錯誤位置:file 3" 
  3. }; 

可以計算出,錯誤出現(xiàn)在第三個文件中,范圍就縮小了很多。

3. error 事件的注冊

多次注冊 error 事件,不會重復執(zhí)行多個回調:

  1. var fn = window.onerror = function() {  console.log(arguments);};window.addEventListener("error", fn);window.addEventListener("error", fn); 

觸發(fā)錯誤之后,上面代碼的結果為:

window.onerroraddEventListener 都執(zhí)行了,并只執(zhí)行了一次。

4. 收集日志的量

沒有必要將所有的錯誤信息全部送到 Log 中,這個量太大了。如果網(wǎng)頁 PV 有 1kw,那么一個必現(xiàn)錯誤發(fā)送的 log 信息將有 1kw 條,大約一個 G 的日志。我們可以給 Reporter 函數(shù)添加一個采樣率:

  1. function needReport (sampling){  // sampling: 0 - 1 
  2.   return Math.random() <= sampling;}Reporter.send = function(errInfo, sampling) {  if(needReport(sampling || 1)){    Reporter._send(errInfo);  }}; 

這個采樣率可以按需求來處理,可以同上,使用一個隨機數(shù),也可以使用 cookie 中的某個字段(如 nickname)的***一個字母/數(shù)字來判定,也可以將用戶的 nickname 進行 hash 計算,再通過***一位的字母/數(shù)字來判斷,總之,方法是很多的。

收集日志布點位置

為了更加精準的拿到錯誤信息,有效地統(tǒng)計錯誤日志,我們應該更多地采用主動式埋點,比如在一個接口的請求中:

  1. // Module A Get Shops Data 
  2. $.ajax({  url: URL,  dataType: "jsonp", success: function(ret) { if(ret.status === "failed") { // 埋點 1 return Reporter.send({ category: "WARN", msg: "Module_A_GET_SHOPS_DATA_FAILED" }); } if(!ret.data || !ret.data.length) { // 埋點 2 return Reporter.send({ category: "WARN", msg: "Module_A_GET_SHOPS_DATA_EMPTY" }); } }, error: function() { // 埋點 3 Reporter.send({ category: "ERROR", msg: "Module_A_GET_SHOPS_DATA_ERROR"    });  }}); 

上面我們精準地布下了三個點,描述十分清晰,這三個點會對我們后續(xù)排查線上問題提供十分有利的信息。

關于 try..catch 的使用

對于 try..catch 的使用,我的建議是:能不用,盡量不要用。JS代碼都是自己寫出來的,哪里會出現(xiàn)問題,會出現(xiàn)什么問題,心中應該都有個譜,平時用到 try..catch 的一般只有兩個地方:

  1. // JSON 格式不對 
  2. try{  JSON.parse(JSONString);}catch(e){} 
  3. // 存在不可 decode 的字符 
  4. try{  decodeComponentURI(string);}catch(e){} 

類似這樣的錯誤都是不太可控的。可以在使用到 try..catch 的地方思考是否可以使用其他方式做兼容。

關于 window.onerror 的使用

可以嘗試如下代碼:

// test.js
throw new Error("SHOW ME"); window.onerror = function(){ console.log(arguments); // 阻止在控制臺中打印錯誤信息 return true;
};

上面的代碼直接報錯了,沒有繼續(xù)往下執(zhí)行。頁面中可能有好幾個 script 標簽,但是 window.onerror 這個錯誤監(jiān)聽一定要放到最前頭!

錯誤的警報與提示

什么時候該警報?不能有錯就報。上面也說了,因為網(wǎng)絡環(huán)境和瀏覽器環(huán)境因素,復雜頁面我們允許千分之一的錯誤率。日志處理后的數(shù)據(jù)圖:

圖中有兩根線,橙色線是今日的數(shù)據(jù),淺藍色線是往日平均數(shù)據(jù),每隔 10 分鐘產(chǎn)生一條記錄,橫坐標是 0-24 點的時間軸,縱坐標是錯誤量。可以很明顯的看出,在凌晨一兩點左右,服務出現(xiàn)了異常,錯誤信息是平均值的十幾倍,那么這個時候就改報警了。

報警的條件可以設置得嚴苛一點,因為誤報是件很煩人的事情,短信、郵件、軟件等信息轟炸,有的時候還是大半夜。那么,一般滿足如下條件可以報警:

  • 錯誤超過閾值,比如 10分鐘最多允許 100 個錯誤,結果超過了 100

  • 錯誤超過平均值的 10 倍,超過平均值就報警,這個邏輯顯然不正確,但是超過了平均值的 10 倍,基本可以認定服務出問題了

  • 在納入對比之前,要過濾同 IP 出現(xiàn)的錯誤,比如一個錯誤出現(xiàn)在 for 循環(huán)或者 while 循環(huán)中,再比如一個用戶在蹲點搶購,不停的刷新

友好的錯誤提示

對比下面兩條日志,catch 的錯誤日志:

Uncaught ReferenceError: vd is not defined

自定義的錯誤日志:

“生日模塊中獲取后端接口信息時,eval 解析出錯,錯誤內容為:vd is not defined.”
該錯誤在最近 10 分鐘內出現(xiàn) 1000 次,這個錯誤往日的平均出錯量是 50 次 / 10 分鐘

網(wǎng)絡錯誤日志工作草案

W3C Web Performance工作組發(fā)布了網(wǎng)絡錯誤日志工作草案。該文檔定義了一個機制,允許Web站點聲明一個網(wǎng)絡錯誤匯報策略,瀏覽器等用戶代理可以利用這 一機制,匯報影響資源正確加載的網(wǎng)絡錯誤。該文檔還定義了一個錯誤報告的標準格式及其在瀏覽器和Web服務器之間的傳輸機制。

詳細草案:http://www.w3.org/TR/2015/WD-network-error-logging-20150305/

小結

功能、測試和監(jiān)控是程序開發(fā)的三板斧,很多工程師可以將功能做的盡善盡美,也了解一些測試方面的知識,可是在監(jiān)控這個方向上基本處于大腦空白。錯誤 日志的收集、整理算是監(jiān)控的一個小部分,但是它對我們了解網(wǎng)站穩(wěn)定性至關重要。文中有忽略的地方希望讀者可以補充,錯誤的地方還望斧正。

責任編輯:王雪燕 來源: 博客園
相關推薦

2023-03-01 09:07:44

前端監(jiān)控異常

2018-09-14 16:20:37

2012-11-05 13:59:12

WebFdSafeJS

2022-11-28 07:35:52

前端錯誤

2024-02-23 14:57:40

2022-06-10 14:09:18

前端監(jiān)控異常數(shù)據(jù)

2020-09-04 13:50:35

前端異常監(jiān)控代碼

2020-05-18 14:55:34

監(jiān)控系統(tǒng)架構技術

2017-05-04 21:30:32

前端異常監(jiān)控捕獲方案

2012-11-28 11:09:28

IBMdW

2019-05-16 09:00:06

云原生監(jiān)控日志管理

2022-05-31 08:04:30

前端設計模式

2022-06-12 21:28:26

Fluentd開源

2022-05-11 10:58:11

MetricKitiOS13系統(tǒng)崩潰診斷

2025-10-31 10:30:56

2021-09-07 09:34:04

CentOSfilebeatkafka

2023-08-31 07:46:54

KubernetesLoki

2022-12-29 08:00:26

Loki網(wǎng)絡設備

2020-09-02 08:03:28

NginxGrafana日志

2021-05-31 08:30:50

監(jiān)控網(wǎng)站性能
點贊
收藏

51CTO技術棧公眾號

一区二区三区欧美在线观看| 成人免费在线播放| 亚洲一区二区三区免费视频| 久久精品中文字幕一区二区三区 | 黄av在线播放| 成人午夜激情片| 国产精品极品尤物在线观看| 免费在线一级片| 欧美色就是色| 亚洲成年网站在线观看| 亚洲最大成人在线观看| 91福利在线尤物| 中文字幕不卡在线观看| 国产精品综合久久久久久| 中文字幕一区二区人妻| 亚洲精品乱码| 久久综合亚洲社区| 精品成人无码一区二区三区| 成人精品毛片| av大片在线观看| 国产一区二区三区四区在线观看| 欧美亚洲伦理www| 欧美成人黄色网| 日产精品一区二区| 亚洲欧美国产精品专区久久| 无码人妻一区二区三区免费n鬼沢| 欧美在线va视频| 欧美日韩在线第一页| 日本精品福利视频| 免费黄网在线观看| 国产欧美日韩综合| 久久综合九色99| 免费激情视频网站| 国产成人在线看| 亚洲在线第一页| 国产又黄又大又爽| 日本亚洲免费观看| 热久久免费视频精品| 亚洲免费激情视频| 日日干夜夜操s8| 婷婷视频在线| 国产拍欧美日韩视频二区| 韩国一区二区三区美女美女秀| 99热这里只有精品3| 久国产精品韩国三级视频| 国产精品777| 尤物视频免费观看| 日韩精品电影在线| 91精品国产99久久久久久| 日本免费一二三区| 亚洲九九精品| 91高清视频免费| 东京热一区二区三区四区| 国产精品资源| 日韩av高清不卡| www.亚洲激情| 美腿丝袜亚洲色图| 国产日韩精品在线观看| 国产又黄又粗又长| 国产丶欧美丶日本不卡视频| y111111国产精品久久婷婷| 亚洲va欧美va| 成人av在线资源网站| 久久久久久国产精品mv| 神马久久高清| 国产女同性恋一区二区| 亚洲日本精品国产第一区| 日本韩国在线视频爽| 中文字幕一区不卡| 五月天激情图片| 第四色日韩影片| 一本到不卡免费一区二区| 搡女人真爽免费午夜网站| 国产精品.xx视频.xxtv| 欧美一个色资源| 成熟妇人a片免费看网站| 国产农村妇女毛片精品久久麻豆| 久久99视频精品| 三级影片在线看| 激情91久久| 欧美中文字幕在线观看| 最新中文字幕免费| 国产精品亚洲一区二区三区妖精 | 97人妻精品一区二区三区软件| 国产一区高清在线| 国产欧美一区二区视频| 福利在线播放| 一区二区三区在线视频免费| 日韩a在线播放| aa亚洲一区一区三区| 欧美精品一区二区三区蜜臀| 国产精品久久久久久久av| 亚洲国产精品日韩专区av有中文| 午夜精品一区二区三区在线播放 | 国产精品18久久久久久久久| 久久久久久久久久久久久久一区 | 特级西西人体wwwww| 成人看的视频| 久久久综合av| 亚洲视频久久久| 成人午夜碰碰视频| 伊人久久大香线蕉精品| 国产一二在线播放| 91精选在线观看| 在哪里可以看毛片| 国产综合久久| 国产欧美精品日韩| 少妇精品高潮欲妇又嫩中文字幕 | 亚洲欧美制服综合另类| 久久国产美女视频| 日韩中文字幕麻豆| 狠狠干一区二区| 最新黄网在线观看| 欧美一a一片一级一片| 男女污污视频在线观看| 草莓视频一区二区三区| 亚洲色图25p| 久久免费播放视频| 男人的天堂亚洲一区| 国产综合 伊人色| 熟女高潮一区二区三区| 51精产品一区一区三区| 国产成人高潮免费观看精品| 成 人 黄 色 片 在线播放| 国产人妖乱国产精品人妖| 国产中文字幕在线免费观看| 日韩成人18| 久久精品电影网站| 中文字幕日本人妻久久久免费| 99精品热视频| 国产亚洲黄色片| 国产一区2区在线观看| 精品国内产的精品视频在线观看| 亚洲图片欧美日韩| 久久蜜桃av一区二区天堂| 97成人在线免费视频| 第四色中文综合网| 久久久久久91香蕉国产| 精品人妻一区二区三区三区四区| 亚洲人成精品久久久久久| 手机免费看av网站| 99九九热只有国产精品| 国产精品香蕉在线观看| 日本在线免费中文字幕| 欧美日韩中文一区| 欧美xxxooo| 狠狠色综合色综合网络| 亚洲自拍的二区三区| 亚洲黑人在线| 色综合久久悠悠| 免费观看a视频| 亚洲va欧美va天堂v国产综合| 最近日本中文字幕| 国产一区二区三区久久久久久久久| 国产伦精品一区二区三区四区免费| 黄页网站大全在线免费观看| 亚洲国产精品电影| 欧美videossex极品| 久久伊99综合婷婷久久伊| 国产福利视频在线播放| 精品久久中文| 成人免费直播live| 丁香花在线电影小说观看| 亚洲精品一区二区网址| 欧美一级黄视频| 亚洲欧美电影院| 少妇精品无码一区二区三区| 免费在线成人| 亚洲国产精品视频一区| 欧美午夜在线播放| 45www国产精品网站| 99re在线视频| 日韩欧美黄色影院| 一区二区三区在线观看av| 国产精品美女久久久久高潮| 日本黄色三级网站| 亚洲免费在线| 欧美a级黄色大片| 鲁大师精品99久久久| 国产成人aa精品一区在线播放 | 91精品国产高清自在线| 天天干天天插天天操| 欧美性猛交视频| 国产三级在线观看完整版| 韩国成人精品a∨在线观看| 丝袜人妻一区二区三区| 26uuu亚洲| 中国成人亚色综合网站| 国产精品日韩精品在线播放| 97国产一区二区精品久久呦| 国产在线视频网站| 91精品国产高清一区二区三区| 国产精品第56页| 国产精品―色哟哟| 波多野结衣有码| 麻豆传媒一区二区三区| 国产精彩视频一区二区| 欧美一区二区三区高清视频| 官网99热精品| 四虎视频在线精品免费网址| 91chinesevideo永久地址| 麻豆影院在线| 亚洲人成在线电影| 亚洲国产一二三区| 欧美日韩精品一二三区| 日本高清不卡码| 亚洲一二三四区不卡| 国产三级aaa| 26uuu另类欧美亚洲曰本| 一区二区在线免费观看视频| 免费成人美女在线观看| 黄页网站在线观看视频| 久久久国产精品| 日韩精品不卡| 日韩母乳在线| 国产欧美一区二区三区另类精品 | 91网站在线免费观看| 亚洲男人av| 性视频1819p久久| 污影院在线观看| 久久精品美女视频网站| 国产一级网站视频在线| 亚洲精品福利视频| 丰满人妻妇伦又伦精品国产| 欧美美女bb生活片| 亚洲成人1区2区| 午夜激情影院在线观看| 久久中文欧美| 久久精品免费一区二区| 极品裸体白嫩激情啪啪国产精品| 女人床在线观看| 亚洲色图网站| 综合视频在线观看| 四虎成人av| 一区二区日本伦理| 国产国产精品| 国产高清精品软男同| 国产精品videosex性欧美| 视频一区国产精品| 日韩电影免费在线观看| 亚洲成人午夜在线| 欧美激情理论| 桥本有菜av在线| 68国产成人综合久久精品| 一级做a爰片久久| 91综合视频| 乱子伦一区二区| 国产精品vip| 日本a在线免费观看| 亚洲免费大片| 97xxxxx| 久久中文在线| 亚洲va综合va国产va中文| 九一九一国产精品| 99国产精品免费视频| 香港三日本8a三级少妇三级99| 涩涩av在线| 97香蕉超级碰碰久久免费软件| 俄罗斯一级**毛片在线播放| 国产精品国产三级国产普通话蜜臀| 色一情一交一乱一区二区三区| 国产欧美精品在线观看| 亚欧精品视频一区二区三区| 国产精品国产三级国产专播品爱网| 国产一区在线观看免费| 亚洲黄色性网站| 日本一区二区三区免费视频| 日韩欧美精品网址| 97人妻精品视频一区| 欧美高清视频www夜色资源网| 精品久久在线观看| 日韩电影中文 亚洲精品乱码| 噜噜噜在线观看播放视频| 日韩中文在线视频| 福利成人导航| 国产精品普通话| 囯产精品一品二区三区| 日韩精品欧美激情一区二区| 久久爱av电影| 成人婷婷网色偷偷亚洲男人的天堂| 在线无限看免费粉色视频| 在线国产精品一区| 久久午夜夜伦鲁鲁一区二区| 国产高清不卡二三区| 国产精品无码久久久久一区二区| 中文字幕亚洲在| 一级片中文字幕| 在线综合视频播放| 神马久久高清| 欧美老女人xx| 欧美日韩亚洲国产| 97视频资源在线观看| 九九久久成人| 国产av人人夜夜澡人人爽麻豆| 日产欧产美韩系列久久99| 俄罗斯女人裸体性做爰| 国产农村妇女精品| 天天操天天射天天爽| 欧美二区乱c少妇| 欧美女同网站| 欧美精品videossex性护士| 久久影视精品| 天天色综合天天| 天天干天天曰天天操| 久久久影视传媒| 久久伊人成人网| 欧美日韩免费视频| 天堂在线中文字幕| 欧美激情欧美激情在线五月| 国产成人亚洲一区二区三区| 欧美精彩一区二区三区| 伊人久久大香线蕉综合热线| www.com久久久| 国产欧美日韩在线| 日韩精品在线免费视频| 日韩欧美电影一区| 黄网页在线观看| 国产精品偷伦一区二区| 国产精品一线天粉嫩av| 日本少妇高潮喷水视频| 成人免费视频一区| 国产少妇在线观看| 欧美精品粉嫩高潮一区二区| 成年人免费在线视频| 国产成人精品av| 免费看日本一区二区| 欧美日韩中文在线视频| 97精品久久久午夜一区二区三区| 国产在线拍揄自揄拍无码视频| 日韩一区二区在线观看视频播放| 蜜桃av在线免费观看| 国产欧亚日韩视频| 日韩在线综合| 手机免费av片| 亚洲欧美电影一区二区| 国产三级漂亮女教师| 欧美理论电影在线播放| 91国内精品| 丰满的少妇愉情hd高清果冻传媒| 国产99一区视频免费| 久久精品www人人爽人人| 日韩免费看网站| 日本欧美电影在线观看| 国产精品污www一区二区三区| 国产精品久久| 北京富婆泄欲对白| 精品美女久久久久久免费| 欧美一级特黄aaaaaa| 午夜精品视频网站| 天堂网av成人| 天天色综合天天色| 亚洲天天做日日做天天谢日日欢| a级片在线免费看| 久久久久亚洲精品成人网小说| 欧美影院天天5g天天爽| 国产l精品国产亚洲区久久| 久久精品日韩一区二区三区| 国产偷人爽久久久久久老妇app| 日韩一区二区三区在线播放| 深夜福利一区二区三区| 久草免费福利在线| 99国产精品久久| 国产午夜无码视频在线观看| 色婷婷综合成人| 99国产精品久久一区二区三区| 欧美日韩亚洲一| 国产精品三级av| 高清国产mv在线观看| 热久久美女精品天天吊色| 91综合网人人| 中国极品少妇xxxx| 91精品91久久久中77777| 精产国品自在线www| 国产精品一区二区在线观看 | 人人爱人人干婷婷丁香亚洲| 欧美人成在线观看| 国产日韩欧美精品综合| 99久久免费国产精精品| 97香蕉超级碰碰久久免费软件| 成人免费在线播放| youjizz.com国产| 欧美色偷偷大香| 51漫画成人app入口| 日韩三级电影免费观看| 国产精品一区二区91| 久久午夜免费视频| 久热爱精品视频线路一| 窝窝社区一区二区| 久久久久久综合网| 日韩欧美视频一区二区三区| 搞黄网站在线观看| 欧美日韩在线不卡一区| 国产精品1区二区.| 亚洲精品国产欧美在线观看| 国产+人+亚洲| 国产精品久久久久久久免费观看| 国产一级二级在线观看| 日韩一区二区电影| 亚洲电影有码| 北条麻妃在线视频观看|