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

如何在 Node.js 和 Express 中使用 Auth0

譯文
開發(fā)
了解如何將Auth0登錄功能添加到Node.js/Express應(yīng)用程序,并使用經(jīng)過身份驗證的用戶信息顯示/隱藏UI信息和安全API。

 [[418735]]

【51CTO.com快譯】基于云計算的身份驗證和授權(quán)平臺(有時稱為 IDaaS 或身份即服務(wù))是云工具的一個不斷擴展的領(lǐng)域,原因很容易理解。應(yīng)用程序安全性困難且容易出錯,幾乎每個項目都需要云計算。將大部分工作轉(zhuǎn)移到專門且經(jīng)過驗證的服務(wù)上的能力很有吸引力。

Auth0是一個身份驗證和授權(quán)服務(wù)(以及開源軟件)新興提供商。在本文中,您將看到如何將 Auth0 登錄功能合并到一個具有 Node.js/Express 后端的應(yīng)用程序中,服務(wù)于一個直接的 JS 前端,然后使用經(jīng)過身份驗證的用戶信息(通過 JWT)來顯示/隱藏UI 信息并保護 RESTful 端點。

創(chuàng)建一個簡單的 Node.js/Express 應(yīng)用

首先,設(shè)置一個簡單的 Express 應(yīng)用程序。首先從命令行輸入npm init開始。也可以任意命名項目名稱。請注意,此示例應(yīng)用程序旨在以簡單和精簡的方式突出顯示安全元素,因此忽略了許多生產(chǎn)所需的功能,如錯誤處理和配置文件。

接下來,通過運行npm install Express從運行init的同一目錄安裝Express。

在您選擇的代碼編輯器中,在根目錄中添加一個 server.js 文件,并將以下內(nèi)容粘貼其中。

基本 server.js 文件

  1. const express = require('express'); 
  2.   const app = express(); 
  3.  
  4. app.get('/api/open', function(req, res) { 
  5.   console.log("/api/open"); 
  6.   res.json({ 
  7.     message: "Open Endpoint" 
  8.   }); 
  9. }); 
  10.  
  11. app.get('/api/members-only', function(req, res){ 
  12.   console.log("/api/members-only"
  13.   res.json({ 
  14.     message: 'Members Only Endpoint' 
  15.   }); 
  16. }) 
  17.  
  18. app.get('/api/protected', function(req, res) { 
  19.   console.log("/api/protected"
  20.   res.json({ 
  21.     message: 'Protected Endpoint' 
  22.   }); 
  23. }); 
  24.  
  25. app.listen(3000); 
  26. console.log('Listening on http://localhost:3000'); 

這段代碼概述了主要是:三個 API 端點,一個開放,一個需要主動登錄,一個需要登錄和特定權(quán)限。

現(xiàn)在將開發(fā)腳本添加到 package.json 文件的腳本部分:

  1. "dev""nodemon server.js" 

下一步需要安裝 nodemon 工具:

  1. npm install -g nodemon 

然后,使用npm run dev運行簡單服務(wù)器,并在 localhost:3000/api/open 查看 API 響應(yīng)。

提供靜態(tài)文件

接著使用 express.static 從 /public/index.html 為客戶端提供服務(wù)。該文件包含所有 HTML 和 JS,以便于理解所有內(nèi)容,因此,Auth0文檔稱之為單頁應(yīng)用程序 (SPA)。我們的客戶端將調(diào)用上面定義的后端 API。

在server.js中的app.listen行之前,添加以下行:app.use(express.static(join(__dirname, "public")));

意思是指示Node.js在/public中提供文件。然后創(chuàng)建文件 /public/index.html 并將以下的內(nèi)容放入其中。

步驟三:開始 index.html

  1. <html> 
  2.   <head> 
  3.   <style> 
  4.       .hidden { 
  5.         display: none; 
  6.       } 
  7.       label { 
  8.         margin-bottom: 10px; 
  9.         display: block; 
  10.       } 
  11.     </style> 
  12.   </head> 
  13.   <body> 
  14.     <h1>Infoworld: Intro to Auth0</h1> 
  15.     <button id="btn-login" disabled="true" onclick="login()">Log in</button> 
  16.     <button id="btn-logout" disabled="true" onclick="logout()">Log out</button> 
  17.  
  18.     <h2>Fetch Open API</h2> 
  19.     <h3 id="openMessage"></h3> 
  20.     <button onclick="fetchOpenApi()">Open API</button> 
  21.  
  22.     <h2>Fetch Members Only API</h2> 
  23.     <h3 id="moMessage"></h3> 
  24.     <button onclick="fetchMembersOnlyApi()">Members Only API</button> 
  25.  
  26.     <h2>Fetch Protected API</h2> 
  27.     <h3 id="protectedMessage"></h3> 
  28.     <button onclick="fetchProtectedApi()">Protected API</button> 
  29.     <hr> 
  30.     <div class="hidden" id="gated-content"> 
  31.       <p> 
  32.         This content is hidden until user is logged in. 
  33.       </p> 
  34.       <label> 
  35.         Access token: 
  36.         <pre id="ipt-access-token"></pre> 
  37.       </label> 
  38.       <label> 
  39.         User profile: 
  40.         <pre id="ipt-user-profile"></pre> 
  41.       </label> 
  42.     </div> 
  43.   </body> 
  44. </html> 
  45.  
  46. <script> 
  47.   async function fetchOpenApi(){ 
  48.     let result = await fetch("/api/open"); 
  49.     let json = await result.json(); 
  50.     document.getElementById("openMessage").innerHTML = JSON.stringify(json.message); 
  51.   } 
  52.   async function fetchMembersOnlyApi(){ 
  53.     const token = await auth0.getTokenSilently(); 
  54.     let result = await fetch("/api/members-only"); 
  55.     let json = await result.json(); 
  56.     document.getElementById("moMessage").innerHTML = JSON.stringify(json.message); 
  57.   } 
  58.   async function fetchProtectedApi(){ 
  59.     const token = await auth0.getTokenSilently(); 
  60.     let result = await fetch("/api/protected"); 
  61.     let json = await result.json(); 
  62.     document.getElementById("protectedMessage").innerHTML = JSON.stringify(json.message); 
  63.   } 
  64. </script> 

完成上述操作,就可以轉(zhuǎn)到 localhost:3000/,將看到一個基本的 HTML 頁面,其中包含點擊三個端點的三個按鈕。在此階段,如果單擊按鈕,這三個按鈕都將返回結(jié)果,因為安全端點尚不安全。此外,登錄和注銷按鈕尚未執(zhí)行任何操作,頁面底部的內(nèi)容仍處于隱藏狀態(tài)。

保護端點

現(xiàn)在,還需要一個 Auth0 帳戶,該帳戶可免費滿足基本的使用。當注冊賬戶時,Auth0 將為用戶創(chuàng)建一個默認的“系統(tǒng) API”。這是一個的特殊 API,每個用戶只有一個,并讓用戶訪問 Auth0 平臺。公鑰(在本例中為 RS256 的 jwks)通過此 API 公開。

接下來,將在 Auth0 系統(tǒng)中創(chuàng)建一個 API。單擊“CreateAPI”按鈕,這將打開如圖 1 所示的屏幕。

圖 1. 創(chuàng)建一個 Auth0 API

圖 1. Auth0 API創(chuàng)建界面

對于name領(lǐng)域,可以使用任何名字。對于identifier,應(yīng)該使用一個 URL,但不必公開 URL — 它只是一個在代碼中引用的標識符。當然,在實際項目中,則需使用實際域名。對于表單上的最后一個字段,可以將算法保留為 RS256。

使用 Auth0 API

RS256公鑰托管在 URL 中,格式為 https://[your_domain].auth0.com/.well-known/jwks.json。可以通過單擊它旁邊的“設(shè)置”找到新 API 的詳細信息。注意,您現(xiàn)在提供的標識符的格式為 https://[your_domain].us.auth0.com/api/v2/,很快就會看到這兩個 URL 正在運行。

下一步要做的就是定義權(quán)限。在這種情況下,需要訪問之前創(chuàng)建的受保護端點所需的權(quán)限。在設(shè)置頁面中,選擇“權(quán)限”選項卡。創(chuàng)建一個read:protected權(quán)限并點擊“添加”按鈕。

使用 Express auth 中間件

使用 Express 中間件來強制執(zhí)行權(quán)限策略。繼續(xù)安裝步驟三中的依賴項,其中分別包括 Express JWT(JSON Web 令牌)、JSON Web 密鑰和 Express JWT 授權(quán)擴展。請記住,JWT 是一個帶有身份驗證信息的加密令牌。它將用于前端、后端和 Auth0 平臺之間的通信。

清單 3. 添加身份驗證依賴項

  1. npm install --save express-jwt jwks-rsa express-jwt-authz 

將checkJwt與必要的導(dǎo)入一起添加到server.js,如清單 4 所示。請注意,您將使用詳細信息填充一些元素(在方括號中)。

清單 4. 保護端點

  1. //... 
  2. const jwt = require('express-jwt'); 
  3. const jwtAuthz = require('express-jwt-authz'); 
  4. const jwksRsa = require('jwks-rsa'); 
  5. //... 
  6. const checkJwt = jwt({ 
  7.   secret: jwksRsa.expressJwtSecret({ 
  8.     cache: true
  9.     rateLimit: true
  10.     jwksRequestsPerMinute: 5
  11.     jwksUri: `https://[YOUR SYSTEM API DOMAIN].us.auth0.com/.well-known/jwks.json` 
  12.   }), 
  13.  
  14.   audience: '[THE IDENTIFIER FROM YOUR API]'
  15.   issuer: [`https://[YOUR SYSTEM API DOMAIN].us.auth0.com/`], 
  16.   algorithms: ['RS256'
  17. }); 
  18. var options = { customScopeKey: 'permissions'};  // This is necessary to support the direct-user permissions 
  19. const checkScopes = jwtAuthz([ 'read:protected' ]); 
  20. //... 
  21.  
  22. app.get('/api/members-only', checkJwt, function(req, res){ 
  23.   console.log("/api/members-only"
  24.   res.json({ 
  25.     message: 'Members Only Endpoint' 
  26.   }); 
  27. }) 
  28.  
  29. app.get('/api/protected', checkJwt, checkScopes, function(req, res) { 
  30.   console.log("/api/protected"
  31.   res.json({ 
  32.     message: 'Protected Endpoint' 
  33.   }); 
  34. }); 

概括地說,上面的內(nèi)容是創(chuàng)建了一個 Express 中間件checkJwt,它將檢查有效的 JSON Web 令牌。被配置為使用之前創(chuàng)建的 Auth0 API 中的信息。

請注意,issuerjwksUri指向您的系統(tǒng) API 帳戶,該帳戶是在您注冊時為您創(chuàng)建的。同樣,每個用戶有一個系統(tǒng) API 帳戶,而不是每個 API。此帳戶提供密鑰(在本例中為 JSON Web 密鑰集)以對特定 API 的身份驗證信息進行標記。

訪問群體字段將引用您創(chuàng)建的API的標識符,而不是系統(tǒng)API帳戶。

最后,請注意,還有checkScopes應(yīng)用于受保護的端點。這將檢查read:protected(讀取:受保護)權(quán)限。

檢查你的進度

此時,如果返回瀏覽器并單擊“Members Only API”(或“Protected API”)按鈕,服務(wù)器將響應(yīng)錯誤:

UnauthorizedError: No authorization token was found. 

創(chuàng)建 Auth0 客戶端應(yīng)用程序

像創(chuàng)建一個 Auth0 API 來為后端應(yīng)用程序建模一樣,您現(xiàn)在將創(chuàng)建并配置安全端點的客戶端或使用者。同樣,Auth0 將它們稱為 SPA(它們過去被稱為“客戶端”,現(xiàn)在仍然在一些 Auth0 文檔中)。轉(zhuǎn)到 Auth0 儀表板,然后在左側(cè)菜單中選擇“應(yīng)用程序 -> 應(yīng)用程序”,就在配置服務(wù)器時使用的 API 鏈接上方。

現(xiàn)在選擇“創(chuàng)建應(yīng)用程序”按鈕。給它起個名字(也許稱它為“客戶端”以區(qū)別于后端應(yīng)用程序)并確保選擇“SPA”作為類型。點擊“創(chuàng)建”。

然后通過從列表中選擇來打開客戶端應(yīng)用程序。在這里,可以找到設(shè)置測試應(yīng)用程序客戶端所需的信息:域和客戶端 ID。記下這些信息;后面會使用到。

在應(yīng)用程序設(shè)置中配置回調(diào)、注銷和 Web 源 URL

但是,如圖 2 所示,將開發(fā)應(yīng)用程序的 localhost 地址 (http://localhost:3000) 添加到允許的回調(diào)中。這讓 Auth0 知道它可以將您的開發(fā) URL 用于這些目標。

圖 2. 將 localhost 添加到客戶端配置

圖 2. 將 localhost 添加到客戶端配置 

建立客戶端身份驗證

接著,返回應(yīng)用程序代碼,并在index.html中將Auth0 SDK添加到客戶端。在這種情況下,我們將使用 CDN。將以下內(nèi)容添加到文件的標題中:

  1. < script  src ="https://cdn.auth0.com/js/auth0-spa-js/1.13/auth0-spa-js.production.js"></ script > 

現(xiàn)在可以連接 auth.。首先連接登錄和注銷按鈕。它們的處理程序見清單 5。

清單 5. 登錄和注銷處理程序

  1. const configureClient = async () => { 
  2.         auth0 = await createAuth0Client({ 
  3.           domain: "[YOUR SYSTEM API URL].us.auth0.com"
  4.           client_id: "[YOUR CLIENT ID]"
  5.           audience: "[YOUR API IDENTIFIER]" // The backend api id 
  6.         }); 
  7.       } 
  8. const login = async () => { 
  9.         await auth0.loginWithRedirect({ 
  10.           redirect_uri: "http://localhost:3000" 
  11.         }); 
  12.       }; 
  13.       const logout = () => { 
  14.         auth0.logout({ 
  15.           returnTo: window.location.origin 
  16.         }); 
  17.       }; 

對于清單 5,首先使用前面提到的設(shè)置信息配置 Auth0 客戶端。再次注意,域字段指的是每個用戶一個系統(tǒng) API。

兩個處理程序都依賴于之前導(dǎo)入的 Auth0 庫。如果應(yīng)用此選項并刷新應(yīng)用程序,則可以單擊“登錄”按鈕并重定向到 Auth0 登錄頁面。這個頁面是“通用登錄”入口(Auth0 也支持集成一個“鎖箱”組件)。注意,它自動支持用戶名/密碼和社交登錄。

基于身份驗證顯示和隱藏內(nèi)容 

清單 6 對 index.html 進行了一些更多的腳本更改,以實現(xiàn)顯示/隱藏功能。

【51CTO譯稿,合作站點轉(zhuǎn)載請注明原文譯者和出處為51CTO.com】

 

責任編輯:梁菲 來源: InfoWord
相關(guān)推薦

2021-07-30 11:20:53

JavaScriptNode.jsWeb Develop

2020-08-05 08:31:51

SSL TLSNode.js

2021-07-03 17:43:03

Node.jsNode變量

2014-07-11 14:16:15

AbsurdJSExpress

2020-08-07 10:40:56

Node.jsexpress前端

2021-10-25 09:00:37

Node.jsJS前端

2021-07-26 05:24:59

Node.js SO_RESUEPORLibuv

2021-06-15 15:03:21

MongoDBNode.jsCRUD

2022-11-17 09:52:12

RHEL 9Node.js

2017-05-10 09:40:57

Ubuntupm2Nginx

2011-09-09 14:23:13

Node.js

2022-08-22 07:26:32

Node.js微服務(wù)架構(gòu)

2011-10-18 10:17:13

Node.js

2021-01-18 08:06:38

Node.js 追蹤JSON

2025-10-28 01:00:00

NestJSCSVJSON

2021-07-15 10:15:52

Node.jsJSON前端

2021-05-18 09:01:39

Node.jsJSON文件

2022-08-12 07:01:00

Node.jsXSS腳本

2013-03-28 14:54:36

2017-04-24 08:31:26

Node.jsExpress.jsHTTP
點贊
收藏

51CTO技術(shù)棧公眾號

男女全黄做爰文章| 337p粉嫩大胆噜噜噜鲁| 亚洲第一成人av| 亚洲三级免费| 国产午夜精品一区二区三区 | h片在线免费观看| 丁香啪啪综合成人亚洲小说| 日本免费在线精品| 国产精品嫩草影院俄罗斯 | 精品卡一卡二| 正在播放木下凛凛xv99| 黄色综合网站| 在线看片第一页欧美| 久久久精品人妻一区二区三区| 亚洲精华液一区二区三区| 国产精品成人一区二区三区夜夜夜| 91成人理论电影| 免费视频网站在线观看入口| 欧美99在线视频观看| 亚洲美女视频网站| 青青草精品在线| 久久精品女人天堂av免费观看 | 亚洲国产精品一区二区久| 九色porny91| 国内老司机av在线| 日韩一区在线看| 日本高清视频一区二区三区 | 久草这里只有精品视频| 亚州精品天堂中文字幕| 亚洲伦理一区二区三区| 精品久久91| 精品爽片免费看久久| 伊人av在线播放| 色综合一区二区日本韩国亚洲| 欧美日韩中文字幕| 无码人妻精品一区二区蜜桃网站| 亚洲麻豆精品| 久久亚洲精精品中文字幕早川悠里| 97免费资源站| 亚洲在线观看av| 日韩中文字幕一区二区三区| 91国内在线视频| 久久精品亚洲无码| 欧美午夜一区| 久久高清视频免费| 国产极品美女在线| 93在线视频精品免费观看| 亚洲欧美精品伊人久久| 风间由美一二三区av片| 精品伊人久久久| 欧美一区二区三区思思人| 奇米影视四色在线| 成人国产一区二区三区精品麻豆| 色综合久久久久综合体| 岳毛多又紧做起爽| 天堂中文在线播放| 欧美日韩午夜激情| 亚洲成人动漫一区| 日韩免费电影一区| 五月天av在线播放| 韩国精品视频在线观看| 欧美色中文字幕| 亚洲最大综合网| 国产69精品久久久久9999人| 欧美日韩精品一区二区天天拍小说| 国产成人精品视频ⅴa片软件竹菊| 欧美aa免费在线| 日韩欧美精品网址| 中文字幕国产传媒| www一区二区三区| 日韩精品自拍偷拍| 插我舔内射18免费视频| 日韩mv欧美mv国产网站| 亚洲男女性事视频| 国产激情av在线| 91精品国产91久久综合| 欧美大片大片在线播放| 日韩精品久久久久久久| 久久综合五月| 国产日韩欧美影视| www.色播.com| 91丨九色丨尤物| 日韩国产欧美一区| 成年人黄视频在线观看| 亚洲综合自拍偷拍| 色综合av综合无码综合网站| 欧美在线va视频| 欧美一区二区三区喷汁尤物| 中文字幕乱视频| 精品国产91久久久久久浪潮蜜月| 久久精品国产96久久久香蕉| 欧美亚洲天堂网| 秋霞影院一区二区| av资源一区二区| 国产色a在线| 伊人开心综合网| 男女午夜激情视频| 韩国三级成人在线| 亚洲免费一级电影| 波多野结衣不卡视频| 久久精品伊人| 97人人干人人| 国产色在线 com| 亚洲综合视频网| 日本爱爱免费视频| jazzjazz国产精品麻豆| 最新91在线视频| 99视频在线看| 久久成人麻豆午夜电影| 久久综合九九| av在线看片| 色94色欧美sute亚洲线路一ni| 天天久久综合网| 欧美**字幕| 欧美激情a在线| 中文字幕av资源| 26uuu亚洲综合色欧美| 国产免费xxx| 电影久久久久久| 亚洲黄色www| 欧美色图一区二区| 久久国产精品99久久人人澡| 免费看成人午夜电影| 日本高清成人vr专区| 欧美性videosxxxxx| 中文字幕在线永久| 亚洲性感美女99在线| 成人性生交大片免费看视频直播 | 午夜影视一区二区三区| 欧美一级片在线看| 91无套直看片红桃在线观看| 久久国产精品久久w女人spa| 国产精品久久久一区二区三区| 国产理论在线观看| 欧美日韩小视频| 性欧美13一14内谢| 99这里有精品| 国产精品一区二区三区观看| 中文字幕资源网在线观看| 欧美日本韩国一区二区三区视频| 久久精品无码一区| 99热免费精品| 久久精品一二三区| 九色porny丨首页入口在线| 日韩欧美亚洲国产精品字幕久久久| 国产小视频你懂的| 激情偷乱视频一区二区三区| 在线日韩av永久免费观看| 97人人做人人爽香蕉精品| 国产亚洲精品久久久优势| 好吊色在线视频| 久久久精品黄色| 亚洲少妇第一页| 成人免费在线观看av| 国产精品福利网| 国产福利小视频在线| 欧美日韩亚洲丝袜制服| 久久人妻无码aⅴ毛片a片app| 久久国产人妖系列| 影音先锋男人的网站| 精品欧美视频| 欧美精品久久久久久久免费观看| 成人毛片在线精品国产| 亚洲h精品动漫在线观看| xxxx黄色片| 丝袜诱惑亚洲看片| 艳色歌舞团一区二区三区| 91精品视频一区二区| 久久av红桃一区二区小说| 亚洲a视频在线| 欧美日韩在线影院| 女人十八毛片嫩草av| 精品亚洲成a人在线观看| 国产内射老熟女aaaa| 精品国产一区二区三区不卡蜜臂| 国产69精品久久久久99| 欧洲毛片在线| 欧美日韩三级一区二区| 婷婷久久综合网| 99麻豆久久久国产精品免费| 日本精品久久久久中文字幕| 日本一区二区在线看| 97netav| 国产高清自产拍av在线| 一本色道久久88亚洲综合88| 国产视频一二三四区| 亚洲成av人综合在线观看| 久久久久亚洲av成人无码电影| 久久99国内精品| 五十路熟女丰满大屁股| 成人a'v在线播放| 99视频在线播放| 四虎4545www精品视频| 久久最新资源网| 青青草免费观看免费视频在线| 欧美日韩在线一区二区| 国产在线视频第一页| 国产欧美精品一区二区色综合朱莉| 成年人网站av| 久久综合九色| 18黄暴禁片在线观看| 青草国产精品| 国内精品久久国产| 色综合视频一区二区三区日韩| 97香蕉久久超级碰碰高清版| 免费高清完整在线观看| 亚洲美女福利视频网站| 亚洲老妇色熟女老太| 欧美日韩亚州综合| 91精品国产高清一区二区三密臀| 亚洲美女屁股眼交3| 久久久久久久久久久久| 成年人国产精品| 性欧美在线视频| 久久久久久一区二区| 青青青青草视频| 欧美a级在线| 亚洲精品中字| 蜜桃一区二区三区| 国产精品swag| 欧美片网站免费| 国产欧美精品久久久| 综合日韩av| 午夜精品一区二区三区av| 91高清在线观看视频| 中文字幕久久久| 黄色片在线看| 亚洲欧美国产视频| 少妇喷水在线观看| 欧美哺乳videos| aaa国产视频| 6080午夜不卡| 国产又粗又猛又爽又黄视频| 在线观看国产日韩| 国产精品第六页| 色综合久久久久网| 久久久黄色大片| 欧美日韩一区二区精品| 好吊操这里只有精品| 亚洲成人黄色影院| xxxxxx国产| 天天做天天摸天天爽国产一区| 国产在线观看免费av| 亚洲午夜av在线| av资源吧首页| 婷婷成人综合网| av大片在线免费观看| 欧美香蕉大胸在线视频观看| www.国产高清| 色老综合老女人久久久| 天天操天天干天天摸| 欧美在线免费观看视频| 中文字幕在线播出| 欧美精品国产精品| 国产精品永久久久久久久久久| 欧美夫妻性生活| 亚洲av无码一区二区乱子伦 | 欧美专区在线播放| 粉嫩一区二区| 国产精品久久一区主播| 日韩护士脚交太爽了| 亚洲精品欧美日韩专区| 日韩欧美一级| 粉嫩av免费一区二区三区| 久久精品国产亚洲5555| 欧美日韩在线观看一区二区三区| 国产精品亚洲二区| 亚洲免费久久| 欧美片第1页综合| a级黄色一级片| 日韩国产欧美在线播放| 午夜一区二区视频| 成人免费视频免费观看| 黄色工厂在线观看| 国产精品青草综合久久久久99| av激情在线观看| 性做久久久久久免费观看 | 制服丝袜在线91| 亚洲国产精彩视频| 国产视频精品xxxx| 亚洲免费视频一区二区三区| 欧美精品久久一区二区| abab456成人免费网址| 91网免费观看| 视频一区欧美| 992tv快乐视频| 久久国产成人| 欧美人与性动交α欧美精品| 91在线视频免费观看| 你懂得视频在线观看| 亚洲国产wwwccc36天堂| 国产情侣小视频| 欧美一级国产精品| 国产中文字幕在线视频| 免费av一区二区| 精品成人免费一区二区在线播放| 亚洲最大的网站| 国产精品入口久久| 国内少妇毛片视频| 久久国产精品无码网站| 成人手机在线免费视频| 亚洲女同ⅹxx女同tv| 欧美a视频在线观看| 日韩欧美成人一区| 91社区在线观看播放| 午夜精品理论片| 亚洲午夜国产成人| 欧美一级片免费观看| 黄色av日韩| 欧美性猛交xxxx乱大交91| 国产亚洲污的网站| 国产精品999久久久| 51精品久久久久久久蜜臀| 黄色的视频在线免费观看| 久久久免费在线观看| 动漫一区二区三区| 日韩av一区二区三区在线| 亚洲精品麻豆| 国模大尺度视频| 成人欧美一区二区三区在线播放| 无码人妻精品一区二区三区不卡| 欧美精品一区二| а√天堂8资源在线官网| 国产热re99久久6国产精品| 欧美男gay| 国产网站免费在线观看| 高清不卡一区二区在线| www.毛片com| 欧美乱妇一区二区三区不卡视频| 精品视频一二三| 欧美中文字幕在线播放| 欧美黄色录像| 狠狠干 狠狠操| 不卡免费追剧大全电视剧网站| 欧美卡一卡二卡三| 91精品国产高清一区二区三区蜜臀 | 蜜桃视频在线观看播放| 国产精品xxxx| 欧美日韩一视频区二区| 无码人妻少妇色欲av一区二区| 日韩美女精品在线| 国产精品欧美久久久久天天影视| 国产一区二区精品丝袜| 日韩在线观看不卡| 午夜精品亚洲一区二区三区嫩草| 久久亚洲欧洲| 老熟妇一区二区| 欧美性大战久久久久久久蜜臀| 1769在线观看| 国产精品一区久久久| 97久久夜色精品国产| 夜夜夜夜夜夜操| 亚洲嫩草精品久久| 亚洲第一视频在线播放| 欧美精品18videos性欧| 成人av资源网址| 无码人妻丰满熟妇区96| 久久网站最新地址| 波多野结衣黄色| 日韩视频在线免费观看| 精品麻豆剧传媒av国产九九九| 成人区一区二区| 99精品国产热久久91蜜凸| 99精品人妻国产毛片| 中文字幕欧美在线| 91精品国产色综合久久不卡粉嫩| 红桃一区二区三区| 粉嫩嫩av羞羞动漫久久久| 国产专区第一页| 欲色天天网综合久久| 99视频这里有精品| 欧美亚洲黄色片| 久久久国产一区二区三区四区小说 | 国产中文字幕在线观看| 国产热re99久久6国产精品| 亚洲一级影院| 干b视频在线观看| 欧美二区在线观看| 国产传媒在线观看| 亚洲精品一区国产精品| 国产98色在线|日韩| 男人天堂av在线播放| 日韩中文字幕在线视频| 777久久精品| 少妇性l交大片| 一区二区在线观看视频| 亚洲色偷精品一区二区三区| 国产精品自在线| 亚洲国产日本| 91社区视频在线观看| 亚洲精品一区二区精华| 欧美三级精品| 男人c女人视频| 国产日韩欧美精品一区| 亚洲va欧美va| 国产精品看片资源| 影音先锋久久资源网| 99久久精品久久亚洲精品| 日韩成人在线免费观看| 秋霞影院一区|