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

復盤Node項目中遇到的13+常見問題和解決方案

系統
筆者之前陸陸續續接手過幾個nodejs項目, 也參與過幾個有點意思的nodejs開源項目, 最近把其中遇到的一些問題和解決方案做一個梳理, 避免大家繼續踩坑. 話不多說我們開始吧~

筆者之前陸陸續續接手過幾個nodejs項目, 也參與過幾個有點意思的nodejs開源項目, 最近把其中遇到的一些問題和解決方案做一個梳理, 避免大家繼續踩坑. 話不多說我們開始吧~

1. window和mac下設置NODE_ENV變量的問題

我們都知道在前端項目中會根據不同的環境變量來處理不同的邏輯, 在nodejs中也一樣, 我們需要設置本地開發環境, 測試環境, 線上環境等, 此時有一直設置環境變量的方案是在package.json中的script屬性中設置, 如下:

  1. "scripts": { 
  2.    "start""export NODE_ENV=development && nodemon -w src --exec \"babel-node src\""
  3.    "build""babel src --out-dir dist"
  4.    "run-build""node dist"
  5.    "test""echo \"Error: no test specified\" && exit 1" 
  6.  } 

從start指令中我們可以發現我們用export NODE_ENV=development來定義開發環境的環境變量,由于筆者采用的是mac電腦,所以可以用export來定義一個node環境變量. 但是在和朋友合作開發項目時發現執行yarn start后會報錯, 后面看錯誤信息才發現window下不識別export, 后面筆者發現window定義環境變量可以用set, 所以對于window用戶, 如果你使用了以上方法設置NODE_ENV, 可以采用如下方式:

  1. "scripts": { 
  2.    "start""set NODE_ENV=development && nodemon -w src --exec \"babel-node src\"" 
  3.  } 

2. 執行npm install發生node-gyp報錯的問題

在項目開發過程中有時候拉取新的node項目代碼后執行npm install, 會報如下錯誤:


node-gyp就是在node環境中使用的生成不同平臺不同編譯器的項目文件, 如果你遇到了相同的問題, 我們可以采用如下方案:

  1. npm install -g node-gyp 

或者直接刪除package-lock.json或者yarn.lock, 然后重新yarn install或者npm install即可, 筆者親測有效.

3. node + koa2項目中刪除已設置的cookie的解決辦法

  • 由于HTTP是無狀態協議,所以需要cookie來區分用戶之間的身份。我們可以把cookie作為是一個由瀏覽器和服務器共同協作實現的規范。

cookie的處理分為以下3步(基礎且重要的知識):

  1. 服務器向客戶端發送cookie
  2. 瀏覽器將cookie保存(可以在后端設置expires或者maxAge,以session形式存在)
  3. 每次瀏覽器都會將之前設置好的cookie發向服務器

在開發node后臺項目時我們經常涉及用戶管理模塊, 這意味我們需要對用戶進行登錄態管理, 在用戶退出時能及時刪除用戶的cookie, 好在koa2自帶了處理cookie的方法, 我們可以通過如下的方式設置cookie:

  1. router.post(api.validVip, 
  2.     async ctx => { 
  3.       ctx.cookies.set('vid''xuxiaoxi', { maxAge: 24 * 3600 * 1000 }); 
  4.     } 
  5. ); 

以上我們隨便設置了一個有效期為1天的cookie, 那如果業務有變動, 需要在有效期內清空此cookie, 我們該如何處理呢? 解析來給出一個相對可用的解決方案:

  1. ctx.cookies.set('vid''', { maxAge: 0 }); 

此時客戶端的cookie將在下次請求時自動失效.

4. socket.io如何與koa/egg配合使用

我們都知道完整的socket.io通信由兩部分組成:

  1. 與NodeJS HTTP 服務器集成(或安裝在其上)的socket.io
  2. 在瀏覽器端加載的客戶端庫socket.io-client

如果我們直接使用koa或者egg, 我們需要將它們內部集成的http和socket.io做兼容, 此時我們可以這樣處理:

  1. import koa from 'koa'
  2. import http from 'http'
  3.  
  4. const app = new koa(); 
  5. const server = http.createServer(app.callback()); 
  6. const io = require('socket.io')(server); 
  7. //  正常的業務處理 
  8. // io 
  9. io.on('connection', (socket) => { 
  10.     console.log('a user connected'); 
  11.     socket.on('doc load', (msg) => { 
  12.       console.log('doc load', msg) 
  13.       io.emit('getData', users) 
  14.     }) 
  15.   }); 
  16.  
  17. server.listen(3000, () => { 
  18.     // ... 
  19. }); 

通過以上的方式就可以正常的將koa和socket.io 做兼容. 后面我們就可以正常的開發IM應用啦~

5. 由于nodejs第三方模塊依賴特定node版本導致的報錯解決方案

這個情況筆者之前也遇到過, 主要原因是第三方沒有和node版本做到很好的向后兼容, 此時解決方案就是更新此第三方包到最新版本(如果還在維護的情況), 或者使用node包管理工具(n)切換到適配的node版本, 如下:

  1. // 更新最新的包 
  2. npm i xxx@latest 
  3.  
  4. // 使用包管理工具n 
  5. npm i -g n 

使用n可以很方便的管理node版本, 感興趣可以嘗試一下.

6. nodejs如何創建定時任務

定時任務在后端開發中是很常見的功能之一, 其本質是根據時間規則,系統在后臺自動執行相應的任務. 在java, PHP 等后臺語言中有很豐富的定時任務的支持, 對于nodejs 這個興起之秀來說, 雖然沒有那么成熟的生態, 但是仍然有定時任務的模塊, 比如node-schedule.

  • Node Schedule 是用于Node.js的靈活的 cron 類和非 cron 類作業調度程序。它允許我們使用可選的重復規則來安排作業(任意函數)在特定日期執行。它在任何給定時間僅使用一個計時器(而不是每秒鐘/分鐘重新評估即將到來的作業)。

一個很實用的場景是我們想在每年的雙十一或者雙十二讓node程序自動抓取某電商的“商品羊毛”, 并推送到自己的郵箱, 此時我們就可以用Node Schedule來開啟一個定時任務來執行我們的業務操作, 筆者的很多node應用都采用了類似的模式.感興趣可以互相交流一下.

那什么是cron風格的Scheduling呢? 其github上給出了一個簡單的介紹:


所以我們可以像如下方式這樣來寫一個定時任務:

  1. let schedule = require('node-schedule'); 
  2.  
  3. let testJob = schedule.scheduleJob('42 * * * *'function(){ 
  4.   console.log('將在未來的每個時刻的42分時執行此代碼, 比如22:42, 23:42'); 
  5. }); 

7. 在nodejs項目中使用import, export和修飾器@decorator語法

我們都知道現在nodejs版本已經到14.0+版本了, 對最新的es語法支持的也足夠好, 但是目前仍然有一些語法不支持, 比如es的模塊導入導出(import, export), 裝飾器(@decorator)等, 此時我們要在node項目中使用這些新特性, 我們就不得不借助工具, 這里筆者采用babel7來解決上述問題, 如下:

  1. # .babelrc 
  2.   "presets": [ 
  3.     [ 
  4.       "@babel/preset-env"
  5.       { 
  6.         "targets": { 
  7.           "node""current" 
  8.         } 
  9.       } 
  10.     ] 
  11.   ], 
  12.   "plugins": [ 
  13.     ["@babel/plugin-proposal-decorators", { "legacy"true }], 
  14.     ["@babel/plugin-proposal-class-properties", { "loose" : true }] 
  15.   ] 

我們只需要在項目根目錄里新建并寫入如上文件, 并安裝babel對應的模塊即可, 如下:

  1. yarn add  
  2. @babel/cli  
  3. @babel/core  
  4. @babel/node  
  5. @babel/plugin-proposal-class-properties  
  6. @babel/plugin-proposal-decorators  
  7. @babel/preset-env 

此時就可以想寫前端項目一樣使用這些新語法特性啦~

8. nodejs中優雅的處理json文件以及提高json讀寫性能

對于nodejs優化方面其實有很多要聊的, 這里主要來說說json相關的優化方案. 我們需要從2個方面來優化, 一個就是json文件的讀寫性能, 此時我們可以采用fast-json-stringify 來大大提高json的讀寫速度, 其本質是提供了一套json-schema約束, 讓json結構更加有序, 從而提高json的讀取查詢速度. 如下使用方式:

  1. const fastJson = require('fast-json-stringify'
  2. const stringify = fastJson({ 
  3.   title: 'H5 Dooring Schema'
  4.   type: 'object'
  5.   properties: { 
  6.     firstName: { 
  7.       type: 'string' 
  8.     }, 
  9.     lastName: { 
  10.       type: 'string' 
  11.     }, 
  12.     age: { 
  13.       description: 'Age in years'
  14.       type: 'integer' 
  15.     }, 
  16.     reg: { 
  17.       type: 'string' 
  18.     } 
  19.   } 
  20. }) 

比如說在H5-Dooring的后臺中, 有很多需要頻繁讀寫json數據的接口, 此時使用fast-json-stringify對讀寫性能會有很大的提升.

另一方面, 我們在node 端操作json, 如果用原生的寫法會非常麻煩, 此時我們最好自己對json讀取進行封裝來提高代碼的簡約性, 或者我們直接使用第三方庫jsonfile 來輕松讀寫json文件, 如下使用案例:

  1. const json = require('jsonfile'
  2. const fileName = 'h5-dooring.json' 
  3. const jsonData = jsonFile.readFileSync(fileName) 

9. nodejs讀取大文件報錯解決方案

在nodejs中 我們可以使用兩種方式來讀寫文件, 如下:

  1. fs.readFile() 一次性將文件讀取進內存中, 如果文件過大會導致node內存不夠而報錯
  2. fs.createReadStream() 以文件流的方式讀取, 此時可以不用擔心文件的大小

由以上介紹可知如果我們要讀取的文件可能會很大(比如視頻等大文件), 我們一開始就要使用fs.createReadStream(), 其實如果我們需要對文件進行解析, 比如要對簡歷等文件進行逐行解析提取關鍵語料, 我們可以使用node的readline模塊, 此時我們就可以對文件進行逐行讀取并解析, 如下案例:

  1. const fs = require("fs"); 
  2. const path = require("path"); 
  3. const readline = require("readline"); 
  4.  
  5. const readlineTask = readline.createInterface({ 
  6.     input: fs.createReadStream(path.join(__dirname, './h5-dooring')), 
  7. }); 
  8.   
  9. readlineTask.on('line'function(chunk) { 
  10.   // 讀取每一行數據 
  11. }); 
  12.   
  13. readlineTask.on('close'function() { 
  14.   //文件讀取結束的邏輯 

10. nodejs如何開啟gzip優化網站性能

對于nodejs開啟gzip 的操作也屬于node性能優化的一部分, 經過這樣的處理可以讓我們的網站加載更快, 我們可以使用koa的koa-compress中間件來實現gzip 功能. 具體實現如下:

  1. import koa from 'koa'
  2. import compress from 'koa-compress'
  3.  
  4. const app = new koa(); 
  5. // 開啟gzip 
  6. const options = { threshold: 2048 }; 
  7. app.use(compress(options)); 

當然koa-compress還有很多自定義的配置項, 大家可以感受一下.

11. 解決window和linux系統下路徑分隔符不一致的問題

這個問題也是系統之間的差異導致的, 也是需要考慮的問題, 我們都知道在linux系統下路徑的分隔符為/, 比如h5-dooring/src/pages, 但是在window下解析的可能就是h5-dooring\\src\\pages這樣的路徑, 此時我們需要做適配, 不然我們部署到不同系統上報錯是必然的, 所以我們需要全局配置路徑通配符, 筆者的解決方案如下:

  1. import os from 'os' 
  2. const _$ = (os.platform().toLowerCase() === 'win32') ? '\\' : '/'; 

此時涉及到具體路徑的地方我們用_$ 代替即可, 以上代碼我們用到了node的os模塊, 感興趣的可以研究一下, 我們可以用os模塊處理很多有意思的因為系統差異導致的問題.

12. nodejs如何實現父子進程通信

由于nodejs是單線程的, 但是有時候我們需要支持處理多個進程的業務, 目前nodejs可以通過哦父子進程的模式來模擬多進程, 我們可以用到child_process, 大致流程如下:


筆者之前分享的很多node實戰項目都采用了child_process, 大致實現過程如下:

  1. // child.js 
  2. function computedTotal(arr, cb) { 
  3.     // 耗時計算任務 
  4.  
  5. // 與主進程通信 
  6. // 監聽主進程信號 
  7. process.on('message', (msg) => { 
  8.   computedTotal(bigDataArr, (flag) => { 
  9.     // 向主進程發送完成信號 
  10.     process.send(flag); 
  11.   }) 
  12. }); 
  13.  
  14. // main.js 
  15. const { fork } = require('child_process'); 
  16.  
  17. app.use(async (ctx, next) => { 
  18.   if(ctx.url === '/fetch') { 
  19.     const data = ctx.request.body; 
  20.     // 通知子進程開始執行任務,并傳入數據 
  21.     const res = await createPromisefork('./child.js', data) 
  22.   } 
  23.    
  24.   // 創建異步線程 
  25.   function createPromisefork(childUrl, data) { 
  26.     // 加載子進程 
  27.     const res = fork(childUrl) 
  28.     // 通知子進程開始work 
  29.     data && res.send(data) 
  30.     return new Promise(reslove => { 
  31.         res.on('message', f => { 
  32.             reslove(f) 
  33.         }) 
  34.     })   
  35.   } 
  36.    
  37.   await next() 
  38. }) 

13. node端實現圖片編輯/壓縮

圖片編輯壓縮在很多場景中用前端的技術實現比較常見, 其實在node端也有很多需要處理的圖片需要, 畢竟客戶端處理的質量不好控制, 此時我們可以采用node-images, 他是一款node 端輕量級跨平臺圖像編解碼庫, 其主要特性如下:

  • 輕量級:無需安裝任何圖像處理庫。
  • 跨平臺:Windows下發布了編譯好的.node文件,下載就能用。
  • 使用簡單:jQuery風格的API,簡單可依賴

我們可以使用它來裁剪, 壓縮圖片, 基本使用如下:

  1. const images = require("images"); 
  2.  
  3. images("input.jpg")                     //加載圖像文件                             
  4.   .size(400)                          //等比縮放圖像到400像素寬 
  5.      .draw(images("logo.png"), 10, 10)   //在(10,10)處繪制Logo 
  6.        .save("output.jpg", {             //保存圖片到文件,圖片質量為50 
  7.         quality : 50                     
  8.        }); 

H5-Dooring 編輯器中哦你也使用了它來做圖片處理和編輯, 大家也可以更根據實際業務來使用.

14. node端解析“命令行指令字符串”實現線上自動打包部署項目

關于node解析cmd字符串并執行命令行指令的方式筆者之前在寫自己實現一個自動化工作流的文章中也介紹過, 使用了child_process模塊的exec, 具體實現可以參考文章:

基于NodeJS從零構建線上自動化打包工作流(H5-Dooring特別版)

這里寫一個簡單的例子:

  1. const cmdStr = `cd ${outWorkDir} && yarn build ${fid}` 
  2. // 解析命令行指令, 實現線上自動打包構建項目 
  3. exec(cmdStr, function(err, stdout, stderr){ 
  4.   if(err) { 
  5.     console.log('api error:'+stderr); 
  6.     io.emit('htmlWorked', { result: 'error', message: stderr }) 
  7.   } else { 
  8.     // ... 
  9.   } 
  10. }) 

15. 如何解決node應用崩潰, 負載均衡和進程管理

解決此問題最好的方式就是采用pm2 或者forever, 其提供了強大的node進程管理, 負載均衡的能力, 并提供了一定程度的應用監控, 建議在線上環境使用pm2 來管理我們的node應用.

 

責任編輯:姜華 來源: 趣談前端
相關推薦

2022-03-26 13:31:18

項目node變量

2023-04-12 11:32:33

網絡

2019-10-08 16:05:19

Redis數據庫系統

2014-01-07 13:54:02

HadoopYARN

2024-07-08 08:45:41

2010-08-31 16:09:04

DIV+CSS

2022-03-31 10:25:20

物聯網工業 4.0大數據分析

2023-10-16 16:08:42

工業 4.0物聯網邊緣計算

2016-09-27 21:14:53

JavaURL

2010-08-04 10:20:30

Flex組件開發

2019-04-04 13:11:37

React內存泄露memory leak

2010-08-26 12:59:29

marginCSS

2024-05-09 15:00:38

Python編碼開發

2011-07-26 16:05:19

Oracle數據庫服務器

2025-02-19 08:00:00

移動端移動設備移動開發

2025-09-03 10:12:47

移動端JavaScript開發

2021-08-05 08:32:27

React開發項目

2024-05-24 10:56:24

PythonURL代碼

2024-10-30 11:00:00

Python列表索引

2010-12-27 11:00:53

Virtualbox
點贊
收藏

51CTO技術棧公眾號

欧美一进一出视频| 欧美一区二区| 麻豆91精品视频| 欧美xingq一区二区| 日韩欧美亚洲日产国产| 日韩欧美中文字幕一区二区| 秋霞午夜在线观看| 国产精品一区二区av日韩在线| 亚洲视频一区二区免费在线观看| 青草成人免费视频| 99久久免费看精品国产一区| 日本精品600av| 国产在线看一区| 色偷偷偷亚洲综合网另类| 国产精品第12页| 日韩专区一区二区| 日韩一级免费| 亚洲国产美女精品久久久久∴| 天天想你在线观看完整版电影免费| 99成人精品视频| 国产精品一区二区99| 欧美一二三四区在线| 久久国产精品免费观看| 天天色综合久久| 亚洲一区区二区| 亚洲精品小视频| 成年人在线看片| 免费黄色在线| 国产日韩欧美综合在线| 国产精品盗摄久久久| 精品无码在线观看| 欧美成人黄色| 亚洲日本护士毛茸茸| 欧美精品在线一区| 伊人久久成人网| 中国成人一区| 亚洲第一视频在线观看| 成年人视频观看| 高清毛片在线看| 久久国产精品72免费观看| 久久精品视频一| 天堂va欧美va亚洲va老司机| www.51av欧美视频| 久久久亚洲高清| 国产日韩精品一区二区| 中文字幕在线观看成人 | 国产日韩av在线| 精品国产午夜福利| 三级电影一区| 精品国产乱码久久久久久1区2区 | 波多野结衣一本| 一区二区视频免费完整版观看| 欧美国产欧美综合| 成人午夜黄色影院| 国产精品6666| 欧美日韩国产在线观看网站| 欧美一区二区三区色| 国产成人精品视频免费看| 都市激情一区| 国产精品萝li| 国产精品一区视频| 成人黄色三级视频| 久久大逼视频| 欧美成人在线网站| 性高潮久久久久久久| 免费看日产一区二区三区| 黑人欧美xxxx| 麻豆视频传媒入口| 直接在线观看的三级网址| 久久女同精品一区二区| 亚洲影院在线看| 久久亚洲精品石原莉奈| 欧美日本久久| 爽爽爽爽爽爽爽成人免费观看| 伊人影院综合网| 另类春色校园亚洲| 欧美一区二区三区色| 日批视频免费看| 欧美亚洲大陆| 日韩一区二区精品在线观看| 国产精品99久久久精品无码| 国产精品香蕉| 日韩一区二区高清| 国产激情视频网站| 日本一区二区三区视频在线看| 色视频欧美一区二区三区| 欧美一区二区激情| 成人免费看片| 国产精品久久久99| 欧洲久久久久久| 久操视频在线观看| 国产精品三级av在线播放| 无码人妻精品一区二区三区99v| 国产乱子伦三级在线播放| 国产精品久久久久久久久久久免费看 | 亚洲视频 欧洲视频| 大荫蒂性生交片| 日本中文字幕电影在线免费观看| xfplay精品久久| 99在线热播| 国产欧美日韩综合精品一区二区三区 | 91在线国产福利| www.久久艹| 久久经典视频| 91麻豆精东视频| 亚洲一区二区在线免费观看| 国产黄在线看| 亚洲一区影音先锋| www.avtt| 精品久久99| 日韩精品极品毛片系列视频| 午夜不卡久久精品无码免费| 2021年精品国产福利在线| 日韩一二在线观看| 在线视频第一页| 在线日韩欧美| 国产69久久精品成人看| 韩国av中文字幕| 国产农村妇女精品一二区| 91国自产精品中文字幕亚洲| 久久国产精品系列| 国产一区二区精品久久99| 任我爽在线视频精品一| 国产美女福利在线观看| 精品成人乱色一区二区| 国产网站免费在线观看| 永久免费精品视频| zzijzzij亚洲日本成熟少妇| 欧美成人一二三区| 奇米色一区二区| 91精品在线观| 韩国中文字幕hd久久精品| 成人激情免费网站| 免费日韩电影在线观看| 国产高清视频在线观看| 五月婷婷综合激情| jizz欧美激情18| 亚洲成人a级片| 欧美大片国产精品| 香蕉视频黄色在线观看| 影音先锋亚洲一区| 国产xxx69麻豆国语对白| 一级黄色片免费| 国产v综合v亚洲欧| 欧美少妇一区| 中文字幕人成乱码在线观看| 91久久精品一区二区二区| 无码人妻精品一区二区三| 欧美激情aⅴ一区二区三区| 成人在线视频网| 日本在线免费| 在线不卡免费av| 欧美精品欧美极品欧美激情| 国产精品sm| 97激碰免费视频| 丰满熟女人妻一区二区三| 国产人伦精品一区二区| 黄色一级片av| 深夜激情久久| 国外成人免费在线播放| 中文字幕在线观看欧美| 国产精品美日韩| 国内自拍第二页| 同性恋视频一区| 美女久久久久久久| 国产99久久九九精品无码免费| 91最新地址在线播放| 国产精品沙发午睡系列| 国产精品视频一区二区三区四蜜臂| 国产成人精品一区二区三区| aaa在线免费观看| 午夜精品在线看| 好吊日免费视频| 奇米综合一区二区三区精品视频| 亚洲三区在线观看| 国产一区二区三区免费在线| 亚洲欧美另类在线观看| 久久久久久久久久综合| 蜜桃精品视频在线| 看高清中日韩色视频| 欧美日韩视频免费观看| 久久精品国产一区| 视频污在线观看| 在线免费观看视频一区| 免费a在线观看播放| 欧美91视频| 久久久久网址| 国产第一页在线| 亚洲欧美日韩精品久久亚洲区 | 在线不卡免费av| 日本高清www免费视频| 国产精品视频一区二区三区不卡| 在线免费黄色小视频| 精品国产a一区二区三区v免费| 91精品久久久久久久久青青| a毛片不卡免费看片| 日韩精品一区二区三区视频 | 欧美精品一二三区| 国产主播在线播放| 国产另类ts人妖一区二区| 亚洲一区二区高清视频| 91久久精品无嫩草影院| 色偷偷av亚洲男人的天堂| 国产又粗又猛又黄又爽无遮挡 | 亚洲欧美卡通动漫| 奇米综合一区二区三区精品视频| 青青草视频国产| 日韩中文字幕在线一区| 国产成人av在线播放| 天堂亚洲精品| 色婷婷综合久久久久中文字幕1| 亚洲aaa在线观看| 色综合一区二区| 亚洲 小说 欧美 激情 另类| 久久国产成人| 国产 欧美 日韩 一区| 日韩黄色大片| 免费中文日韩| 欧美一区在线观看视频| 国产精品入口日韩视频大尺度 | 久久精品中文字幕电影| 久久久久久久久亚洲精品| 丁香五六月婷婷久久激情| 永久av免费网站| 国产精品亚洲第一| jizz18女人| 综合久久十次| 日韩在线电影一区| 欧美**vk| 国产人妖伪娘一区91| 国产高清不卡| 最近2019年好看中文字幕视频| 午夜视频免费在线| 精品国产百合女同互慰| www国产在线| 欧美视频13p| 影音先锋制服丝袜| 久久精品亚洲麻豆av一区二区| 精品无码国产一区二区三区51安| 国产精品18久久久久| 僵尸世界大战2 在线播放| 亚洲第一论坛sis| 国产精品自在线| 日本小视频在线免费观看| 久久亚洲私人国产精品va| 性生活三级视频| 一本久道中文字幕精品亚洲嫩| 日本少妇裸体做爰| 精品久久久视频| 中日韩黄色大片| 天天影视网天天综合色在线播放 | 91美女视频在线| 伊是香蕉大人久久| 精品人妻一区二区三区四区不卡 | 亚洲欧美视频一区二区| 在线观看欧美日韩国产| 国产高清在线| 精品国产一区久久久| 9191在线播放| 欧美国产一区二区三区| 国际av在线| 在线观看国产欧美| 免费黄色网页在线观看| 精品自拍视频在线观看| 精华区一区二区三区| 亚洲天堂一区二区三区| 亚洲第一天堂影院| 欧美岛国在线观看| 五十路在线观看| 亚洲午夜小视频| 欧美黑人激情| 欧美激情一区二区三区成人| 在线观看完整版免费| 日韩亚洲欧美成人| 黑人极品ⅴideos精品欧美棵| 97久久伊人激情网| 青青热久免费精品视频在线18| 亚洲 日韩 国产第一| 波多野结衣久久精品| 国产精品日日做人人爱| 日韩在线观看中文字幕| 欧美日韩精品久久久免费观看| 日韩美女一区二区三区在线观看| 成人在线观看www| 亚洲精品偷拍| 99sesese| 9久草视频在线视频精品| 欧美一区二区三区影院| 久久精品国产99| 91porn在线| 国产亚洲一二三区| 69av.com| 欧美在线看片a免费观看| 动漫精品一区一码二码三码四码| 欧美性极品少妇精品网站| 一级全黄裸体免费视频| 亚洲福利视频免费观看| 日本高清中文字幕在线| 91精品国产91久久久久久不卡| 日韩成人精品一区二区三区| 国产欧美日韩一区| 69精品国产久热在线观看| 欧美激情导航| 亚洲网站视频| 亚洲综合av在线播放| 美腿丝袜亚洲三区| 亚洲啪av永久无码精品放毛片 | 国产福利视频一区二区三区| 男人天堂av电影| 亚洲综合色区另类av| 麻豆亚洲av成人无码久久精品| 亚洲综合一二区| 中文字幕无线码一区| 日韩经典一区二区三区| 最新国产在线拍揄自揄视频| 国产精品第七影院| 日韩美女毛片| 日本欧美视频在线观看| 国产一区二区福利| 337人体粉嫩噜噜噜| 一本色道综合亚洲| 欧美一区二区三区激情| 亚洲国模精品一区| 在线电影福利片| 国产一区二区色| 欧美日韩黑人| 日本美女高潮视频| 波多野结衣中文字幕一区 | 国产小视频在线播放| 久久久这里只有精品视频| 麻豆精品久久| 路边理发店露脸熟妇泻火| 久草精品在线观看| 成人无码精品1区2区3区免费看| 日本精品视频一区二区| 欧美精品a∨在线观看不卡| 91av免费观看91av精品在线| 国内精品偷拍| 国产黄色片免费在线观看| 国产成人精品一区二区三区网站观看| 国产美女福利视频| 亚洲高清免费在线| 中国a一片一级一片| 亚洲欧美日韩国产中文| 三上悠亚亚洲一区| 亚洲最大成人免费视频| 仙踪林久久久久久久999| 霍思燕三级露全乳照| 成人免费av网站| 天堂网av2018| 五月婷婷久久丁香| 天堂v在线观看| 91超碰caoporn97人人| 日韩电影不卡一区| 国产淫片av片久久久久久| 国产丝袜美腿一区二区三区| 姑娘第5集在线观看免费好剧| 一本一本久久a久久精品牛牛影视 一本色道久久综合亚洲精品小说 一本色道久久综合狠狠躁篇怎么玩 | 日本欧美中文字幕| 免费观看性欧美大片无片| 日韩一级片一区二区| 成人av电影免费在线播放| 久久国产精品免费看| 亚洲美女黄色片| 国产极品久久久久久久久波多结野| 小说区图片区图片区另类灬| 亚洲激情在线| 中文字幕一区二区人妻在线不卡| 色天使色偷偷av一区二区| 五月婷婷在线视频| 97超级在线观看免费高清完整版电视剧| 免费视频亚洲| 久久精品影视大全| av电影天堂一区二区在线观看| 少妇一级淫片免费放中国 | 国内老司机av在线| 久久久久久久久一区二区| 青青草成人在线观看| 四虎免费在线视频| 精品一区二区电影| 24小时成人在线视频| 欧美12av| 九色综合国产一区二区三区| 久久丫精品久久丫| 亚洲天堂网在线观看| 视频精品二区| 成人在线观看黄| 亚洲精品国产无天堂网2021| 国产一区二区小视频| 久久久久久久成人| 精品国产乱码久久久| 亚洲美女高潮久久久| 亚洲免费大片在线观看| 亚洲综合一区中| 中文字幕日韩精品在线观看| 中文字幕这里只有精品| 亚洲一卡二卡三卡| 26uuuu精品一区二区| 国产高清视频免费| 国产精品免费一区|