• <tr id="yyy80"></tr>
  • <sup id="yyy80"></sup>
  • <tfoot id="yyy80"><noscript id="yyy80"></noscript></tfoot>
  • 99热精品在线国产_美女午夜性视频免费_国产精品国产高清国产av_av欧美777_自拍偷自拍亚洲精品老妇_亚洲熟女精品中文字幕_www日本黄色视频网_国产精品野战在线观看 ?

    基于令牌認(rèn)證方案的改進(jìn)研究與實(shí)踐

    2021-04-18 23:45胡獻(xiàn)宇
    軟件工程 2021年4期

    摘? 要:就前后端分離的軟件開(kāi)發(fā)模式而言,保護(hù)后端數(shù)據(jù)接口不被非法調(diào)用是十分重要的。令牌作為獲取保護(hù)資源的憑證,需要提供過(guò)期時(shí)間,否則認(rèn)證功能就失去了意義。針對(duì)活躍用戶(hù),需要在有效時(shí)間內(nèi)提供自動(dòng)登錄功能,可以提升使用體驗(yàn)。本文研究了OAuth(Open Authorization,一種開(kāi)放的授權(quán)標(biāo)準(zhǔn))的認(rèn)證機(jī)制,并在ASP.NET Web API框架基礎(chǔ)上,實(shí)現(xiàn)身份認(rèn)證方案,當(dāng)訪問(wèn)令牌過(guò)期后,增加令牌刷新機(jī)制,既能夠改善用戶(hù)體驗(yàn),也能夠有效保護(hù)數(shù)據(jù)接口。該方案具有通用性,適用于前后端分離的軟件開(kāi)發(fā)。通過(guò)測(cè)試,表明了該方案具有有效性和可行性。

    關(guān)鍵詞:OAuth;身份驗(yàn)證和授權(quán);前后端分離;刷新

    中圖分類(lèi)號(hào):TP311.11? ? ?文獻(xiàn)標(biāo)識(shí)碼:A

    文章編號(hào):2096-1472(2021)-04-34-05

    Abstract: For software development model that separates front and back ends, it is very important to protect back-end data interface from being illegally invoked. The token, as a voucher for obtaining protected resources, needs to provide an expiration time, otherwise authentication function will lose its meaning. For active users, automatic login function needs to be provided within valid time to improve user experience. This paper proposes to implement an identity authentication scheme based on the ASP.NET Web API framework after studying an authentication mechanism of OAuth (Open Authorization, an open authorization standard). When the access token expires, token refresh mechanism is added, which can not only improve user experience, but also effectively protect data interfaces. The proposed scheme is versatile and suitable for software development with separation of front and back ends. Tests show its effectiveness and feasibility.

    Keywords: OAuth; authentication and authorization; separation of front and back ends; refresh

    1? ?引言(Introduction)

    隨著Web應(yīng)用的快速發(fā)展,前后端分離的開(kāi)發(fā)方式成為主流趨勢(shì)。圖1是一種主流的前后端分離的交互模型,使用前按需設(shè)計(jì)數(shù)據(jù)接口,后端(主要是指服務(wù)器端)可以為前端(主要是指PC端平臺(tái)、APP及各類(lèi)小程序)提供HTTP(Hyper Text Transfer Protocol, 超文本傳輸協(xié)議)服務(wù),而不需要關(guān)注業(yè)務(wù)的詳細(xì)展示[1]。此外,前端主要負(fù)責(zé)接收和組織展示后端傳過(guò)來(lái)的數(shù)據(jù),根據(jù)具體的業(yè)務(wù)進(jìn)行頁(yè)面邏輯的設(shè)計(jì)。這種前后端交互模型結(jié)構(gòu)簡(jiǎn)潔,方便前后端開(kāi)發(fā)者關(guān)注自己的業(yè)務(wù),降低了前后端的耦合性,可成功解耦,為后續(xù)開(kāi)發(fā)工作打下了堅(jiān)實(shí)的基礎(chǔ)。

    然而,使用前后端分離的軟件開(kāi)發(fā)模式,需要關(guān)注后端數(shù)據(jù)接口的安全性,保護(hù)接口不被非法調(diào)用。針對(duì)這種情況,本文實(shí)現(xiàn)了基于OAuth(Open Authorization,一種開(kāi)放的授權(quán)標(biāo)準(zhǔn))2.0的身份驗(yàn)證和授權(quán)方案,一方面能夠保護(hù)接口的安全性;另一方面,能夠在令牌過(guò)期之后實(shí)現(xiàn)刷新機(jī)制,改善用戶(hù)體驗(yàn),并通過(guò)Postman工具進(jìn)行完整測(cè)試,表明方案的可行性。

    2 身份驗(yàn)證與授權(quán)(Authentication and authorization)

    2.1? ?身份驗(yàn)證

    身份驗(yàn)證是驗(yàn)證一個(gè)系統(tǒng)實(shí)體或系統(tǒng)資源具有某種屬性值的過(guò)程。對(duì)于HTTP而言,客戶(hù)端和服務(wù)器端是兩個(gè)獨(dú)立的系統(tǒng)實(shí)體,因此,需要從兩個(gè)方面去考慮。一方面,若想實(shí)現(xiàn)服務(wù)器端的身份驗(yàn)證,就得需要向客戶(hù)端保證,請(qǐng)求消息只會(huì)發(fā)送給正確的源服務(wù)器,在這種情況下,消息的發(fā)送者需要在發(fā)送消息之前核實(shí)消息的接收者,通常是認(rèn)證傳輸連接的另一端。另一方面,若想實(shí)現(xiàn)客戶(hù)端的身份驗(yàn)證,就得需要客戶(hù)端向服務(wù)器端發(fā)送驗(yàn)證請(qǐng)求,即判斷請(qǐng)求消息是否應(yīng)該得到授權(quán)[2]。常用的身份驗(yàn)證包含基于密碼的HTTP基礎(chǔ)身份驗(yàn)證和基于令牌的身份驗(yàn)證。

    2.1.1? ?基于密碼的HTTP基礎(chǔ)身份驗(yàn)證

    基于密碼的HTTP基礎(chǔ)身份驗(yàn)證,就是將用戶(hù)名和密碼信息進(jìn)行加密處理,生成Ticket(票據(jù)),客戶(hù)端請(qǐng)求的時(shí)候需要校驗(yàn)Ticket[3],主要步驟如下:

    (1)使用冒號(hào)作為分隔符,連接用戶(hù)名和對(duì)應(yīng)的密碼,使用Base64對(duì)連接字符串進(jìn)行加密處理。

    (2)將加密之后的字符串放在Authorization標(biāo)頭的方案標(biāo)識(shí)符Basic之后。

    (3)若通過(guò)后臺(tái)校驗(yàn),客戶(hù)端將會(huì)接收Ticket,并保存為驗(yàn)證信息,之后的每一次請(qǐng)求都需要攜帶,以方便服務(wù)器進(jìn)行驗(yàn)證。驗(yàn)證成功,則獲取相關(guān)信息,否則返回未通過(guò)的提示信息。

    2.1.2? ?基于令牌的身份驗(yàn)證

    基于令牌的身份驗(yàn)證,就是使用安全令牌進(jìn)行驗(yàn)證。安全令牌是指用于在身份驗(yàn)證過(guò)程中驗(yàn)證用戶(hù)標(biāo)識(shí)的數(shù)據(jù)對(duì)象[4]。我們?cè)赪eb應(yīng)用程序中使用的身份驗(yàn)證Cookie,就是基于令牌的身份驗(yàn)證,其流程如下:

    (1)使用密碼進(jìn)行初始認(rèn)證操作,之后會(huì)生成一個(gè)Cookie,將其返回給客戶(hù)端。

    (2)客戶(hù)端之后發(fā)出的每個(gè)請(qǐng)求,都通過(guò)這個(gè)Cookie進(jìn)行身份驗(yàn)證,不再需要初始的身份信息。

    2.1.3? ?身份驗(yàn)證小結(jié)

    基于密碼的HTTP基礎(chǔ)身份驗(yàn)證方法存在如下一些問(wèn)題:

    (1)客戶(hù)端必須保存密碼,同時(shí),由于密碼采用明文保存,或使用一種可逆的保存方式,增加了密碼泄露的風(fēng)險(xiǎn)。

    (2)服務(wù)器對(duì)每個(gè)請(qǐng)求都進(jìn)行密碼驗(yàn)證,會(huì)增加很多開(kāi)銷(xiāo),影響效率。

    (3)為防御字典攻擊而使用相關(guān)技術(shù),會(huì)導(dǎo)致驗(yàn)證過(guò)程計(jì)算開(kāi)銷(xiāo)較大。

    (4)不適合分布式應(yīng)用。分布式系統(tǒng)中,身份驗(yàn)證通常委托給外部系統(tǒng)。

    基于如上考慮,本方案將使用基于令牌的認(rèn)證方案。

    2.2? ?授權(quán)

    2.2.1? ?授權(quán)簡(jiǎn)介

    授權(quán),可以理解為控制主體對(duì)受保護(hù)資源進(jìn)行相應(yīng)的操作[5]。通常來(lái)說(shuō),授權(quán)問(wèn)題的核心主要是主體、操作和資源三者的關(guān)系,即主體是否可以操作資源[6],如圖2所示。

    在Web API中,對(duì)于授權(quán)我們可以有如下理解:

    (1)資源,指HTTP資源,而HTTP資源是請(qǐng)求消息要訪問(wèn)的資源。

    (2)操作,指HTTP方法,包括GET請(qǐng)求、POST請(qǐng)求等。

    (3)主體,指執(zhí)行HTTP請(qǐng)求的HTTP客戶(hù)端。

    2.2.2? ?OAuth 2.0簡(jiǎn)介

    OAuth 2.0是OAuth 1.0協(xié)議的升級(jí)版本[6],它的主要目標(biāo)是讓客戶(hù)端的開(kāi)發(fā)工作變得簡(jiǎn)單與便捷,為Web應(yīng)用程序、手機(jī)APP、桌面軟件等提供特定的授權(quán)方式。OAuth 2.0允許第三方應(yīng)用程序獲得HTTP服務(wù)的訪問(wèn)權(quán)限,同時(shí),可以通過(guò)HTTP服務(wù)提供方授權(quán)資源擁有者,允許第三方應(yīng)用程序憑借自己的客戶(hù)端憑證獲取在資源服務(wù)器上的受保護(hù)資源的訪問(wèn)權(quán)限。

    在OAuth 2.0中,定義了授權(quán)碼模式、簡(jiǎn)化模式、密碼模式和客戶(hù)端模式四種授權(quán)方式[7],綜合考慮本方案的需求,決定采用密碼模式。密碼模式的流程如圖3所示。

    這種模式的流程如下:

    (1)用戶(hù)通過(guò)提供賬號(hào)和密碼來(lái)使用客戶(hù)端。

    (2)客戶(hù)端將賬號(hào)和密碼發(fā)送給認(rèn)證服務(wù)器,即請(qǐng)求token。

    (3)通過(guò)認(rèn)證服務(wù)器驗(yàn)證,將會(huì)向客戶(hù)端提供訪問(wèn)token。

    (4)客戶(hù)端使用token向資源服務(wù)器請(qǐng)求資源。

    3 身份驗(yàn)證和授權(quán)方案的設(shè)計(jì)與實(shí)現(xiàn)(Design and implementation of identity verification and authorization scheme)

    3.1? ?身份驗(yàn)證和授權(quán)方案的設(shè)計(jì)

    在ASP.NET Web API框架上,使用微軟開(kāi)發(fā)的基于OWIN規(guī)范的Katana項(xiàng)目中的中間件,能夠很方便地完成基于OAuth 2.0的身份驗(yàn)證和授權(quán)。雖然OAuth 2.0關(guān)注的主要內(nèi)容是授權(quán),但是在該中間件中OAuth 2.0可以提供基于令牌的身份驗(yàn)證功能[8],其處理訪問(wèn)令牌的流程如圖4所示。

    (1)獲取令牌。如果HTTP請(qǐng)求存在Bearer的Authorization標(biāo)頭,那么將該標(biāo)頭作為訪問(wèn)令牌,否則身份驗(yàn)證方法不返回任何身份信息。

    (2)獲取身份認(rèn)證票據(jù)。解析訪問(wèn)令牌,可以獲取身份驗(yàn)證票據(jù)信息以及屬性信息。

    (3)驗(yàn)證身份票據(jù),并檢查其有效性。

    3.2? ?身份驗(yàn)證和授權(quán)方案的實(shí)現(xiàn)

    (1)使用Postman發(fā)送仿真模擬請(qǐng)求,并嘗試使用GET方式訪問(wèn)已有的數(shù)據(jù)接口,其結(jié)果如圖5所示。此時(shí),我們是在沒(méi)有限制的情況下獲取相關(guān)數(shù)據(jù)信息。對(duì)于我們的方法,如果不加以限制,那么任何客戶(hù)端都可無(wú)條件訪問(wèn)我們的接口獲取數(shù)據(jù),這樣是不安全的,必須對(duì)接口進(jìn)行限制,只有通過(guò)驗(yàn)證的用戶(hù)才可以獲取數(shù)據(jù)信息。

    (2)在項(xiàng)目中,新建一個(gè)MyAuthorizationServerProvider

    類(lèi),用于實(shí)現(xiàn)身份驗(yàn)證,并且重寫(xiě)ValidateClientAuthentication

    方法和GrantResourceOwnerCredentials方法。

    關(guān)鍵代碼如下:

    public class MyAuthorizationServerProvider :

    OAuthAuthorizationServerProvider

    {

    public override Task ValidateClientAuthentication(

    OAuthValidateClientAuthenticationContext context)

    {

    context.Validated();

    return Task.FromResult(null);

    }

    public override async Task GrantResourceOwner

    Credentials(

    OAuthGrantResourceOwnerCredentialsContext context)

    {

    context.OwinContext.Response.Headers.

    Add("Access-Control-Allow-Origin", new[] { "*" });

    AccountService accService = new AccountService();

    string md5Pwd = LoginHelperMD5CryptoPasswd

    (context.Password);

    IList ul = accService.Login(context.UserName, md5Pwd);

    if (ul.Count() == 0)

    {

    context.SetError("授權(quán)無(wú)效", "用戶(hù)名或密碼錯(cuò)誤!");

    return;

    }

    var identity = new

    ClaimsIdentity(context.Options.AuthenticationType);

    context.Validated(identity);

    }

    }

    為上述數(shù)據(jù)接口添加Authorize標(biāo)簽,達(dá)到過(guò)濾的目的,進(jìn)而實(shí)現(xiàn)對(duì)接口的保護(hù)。此時(shí),我們?cè)俅问褂肞ostman進(jìn)行仿真請(qǐng)求,嘗試請(qǐng)求接口,返回信息如圖6所示,即顯示已拒絕為該請(qǐng)求授權(quán)。

    (3)當(dāng)前接口已經(jīng)被保護(hù)了,我們?cè)谠L問(wèn)接口的時(shí)候,就得通過(guò)Access_token。因此,我們必須拿到Access_token的值,其獲取方法如下:發(fā)送POST請(qǐng)求,訪問(wèn)token的URL;發(fā)送請(qǐng)求之前,在Body內(nèi)添加grant_type、username、password這三個(gè)參數(shù),由于我們采用密碼模式進(jìn)行授權(quán),因此,grant_type的參數(shù)是password,如圖7所示,我們發(fā)送一個(gè)POST請(qǐng)求之后,響應(yīng)的信息包含access_token、token_type等值,響應(yīng)詳情如圖8所示。

    (4)我們重新訪問(wèn)受限的接口,在發(fā)送GET請(qǐng)求的時(shí)候,如圖9所示。在請(qǐng)求的標(biāo)頭里將Authorization設(shè)置為KEY,此時(shí)需要使用上一步獲取到的Access_token,將其作為VALUE參數(shù)的一部分。最終,VALUE對(duì)應(yīng)的值應(yīng)該為Bearer+access_token,如圖9所示,我們能夠順利獲取到數(shù)據(jù)信息。這種情況下,15分鐘內(nèi)客戶(hù)端在訪問(wèn)服務(wù)器端的時(shí)候,無(wú)須進(jìn)行驗(yàn)證就可使用該token訪問(wèn)受保護(hù)的資源。

    (5)當(dāng)Access_token的值失效時(shí),我們就需要重新獲取新的令牌值。此時(shí),我們需要在項(xiàng)目目錄中新建一個(gè)MyRefreshTokenProvider類(lèi),用于令牌到期之前進(jìn)行刷新,以便獲取新的令牌,并重寫(xiě)Create方法和Receive方法,代碼如下:

    public class MyRefreshTokenProvider : Authentication

    TokenProvider

    {

    private static ConcurrentDictionary _refreshTokens= new ConcurrentDictionary();

    //用于生成refresh_token

    public override void Create(AuthenticationToken

    CreateContext context)

    {

    context.Ticket.Properties.IssuedUtc = DateTime.UtcNow;

    context.Ticket.Properties.ExpiresUtc = DateTime.UtcNow.AddDays(60);

    context.SetToken(Guid.NewGuid().ToString("n"));

    _refreshTokens[context.Token] = context.SerializeTicket();

    }

    //由 refresh_token 解析成 access_token

    public override void Receive(AuthenticationTokenReceiveContext context)

    {

    string value;

    if (_refreshTokens.TryRemove(context.Token, out value))

    {

    context.DeserializeTicket(value);

    }

    }

    }

    (6)修改好相關(guān)代碼之后,我們需要按照第(4)步的方式重新獲取Token,因?yàn)檫@次獲取數(shù)據(jù)的時(shí)候,會(huì)額外獲取到Refresh_token的值,如圖10所示,該值將用于重新獲取新的令牌,而不需要重新使用密碼的授權(quán)方式獲取。

    (7)當(dāng)Token過(guò)期后,我們需要使用上次得到的Refresh_token重新獲取令牌,即發(fā)送POST請(qǐng)求訪問(wèn)獲取令牌的URL。發(fā)送請(qǐng)求的時(shí)候,需要在Body內(nèi)添加grant_type、refresh_token這兩個(gè)參數(shù),由于本次需要使用刷新令牌的方式獲取新的令牌,因此Grant_type的值為Refresh_token,而Refresh_token的值就是我們?cè)诘谝淮潍@取令牌的時(shí)候里面的Refresh_token,如圖11所示。

    只要在客戶(hù)端進(jìn)行相關(guān)設(shè)置,即可實(shí)現(xiàn)在不影響用戶(hù)操作體驗(yàn)的情況下動(dòng)態(tài)延長(zhǎng)token有效期限,有效地解決了token失效問(wèn)題。

    4? ?結(jié)論(Conclusion)

    本文通過(guò)研究身份驗(yàn)證和授權(quán)的機(jī)制,改進(jìn)了基于令牌的認(rèn)證方案,增加刷新令牌,能夠在訪問(wèn)令牌過(guò)期之后,使用刷新令牌實(shí)現(xiàn)自動(dòng)登錄和授權(quán),不僅提升了用戶(hù)體驗(yàn),還能有效地保護(hù)后端數(shù)據(jù)接口的安全性;并使用Postman進(jìn)行接口測(cè)試,驗(yàn)證了方案的可行性,為前后端分離的身份驗(yàn)證和授權(quán)提供了有效解決方案。

    參考文獻(xiàn)(References)

    [1] 程冬梅,王瑞聰,劉燕,等.基于REST架構(gòu)風(fēng)格的物聯(lián)網(wǎng)服務(wù)平臺(tái)研發(fā)[J].計(jì)算機(jī)工程與應(yīng)用,2012,48(14):74-78.

    [2] 劉文元.基于ASP.NET Web API的摘要身份驗(yàn)證改進(jìn)算法[J].電腦迷,2017(4):56.

    [3] GLENN B.ASP.NET Web API設(shè)計(jì)[M].北京:人民郵電出版社,2015:331-333.

    [4] 蔣金楠.ASP.NET Web API2框架揭秘[M].北京:電子工業(yè)出版社,2014:591-594.

    [5] 王仲洲,楊曉洪,王劍平,等.基于REST風(fēng)格的WEB API架構(gòu)研究[J].微處理機(jī),2016,37(5):52-55.

    [6] 沈海波,陳強(qiáng),陳勇昌.基于OAuth 2.0擴(kuò)展的客戶(hù)端認(rèn)證方案[J].計(jì)算機(jī)工程與設(shè)計(jì),2017,38(2):350-354.

    [7] 王婷婷,趙松澤.基于OAuth 2.0協(xié)議的安全授權(quán)模型研究[J].軟件工程,2017,20(01):55-59.

    [8] DAVIS J, RAJASREE M S. A framework for the description, discovery and composition of RESTful semantic web services[C]. Computational Science, Engineering and Information Technology, 2012:88-93.

    作者簡(jiǎn)介:

    胡獻(xiàn)宇(1994-),男,碩士,講師.研究領(lǐng)域:軟件開(kāi)發(fā).

    美国免费a级毛片| 日日摸夜夜添夜夜爱| 老司机影院毛片| 精品一区二区三卡| 国产精品蜜桃在线观看| 精品卡一卡二卡四卡免费| xxx大片免费视频| 色吧在线观看| av免费观看日本| 黄频高清免费视频| av.在线天堂| 看十八女毛片水多多多| 亚洲欧美色中文字幕在线| 晚上一个人看的免费电影| 人妻少妇偷人精品九色| 久久精品国产综合久久久| 国产1区2区3区精品| 丰满乱子伦码专区| 久久久久国产一级毛片高清牌| 国产精品 国内视频| 18禁国产床啪视频网站| 久久精品熟女亚洲av麻豆精品| 女人高潮潮喷娇喘18禁视频| 久久久久久免费高清国产稀缺| 国产片内射在线| 熟女少妇亚洲综合色aaa.| 成人国语在线视频| 久久99蜜桃精品久久| 精品福利永久在线观看| 成年美女黄网站色视频大全免费| 美女高潮到喷水免费观看| 亚洲精品一二三| av视频免费观看在线观看| 久久久a久久爽久久v久久| 飞空精品影院首页| 97精品久久久久久久久久精品| 免费日韩欧美在线观看| 亚洲 欧美一区二区三区| 丰满乱子伦码专区| √禁漫天堂资源中文www| 中文精品一卡2卡3卡4更新| 哪个播放器可以免费观看大片| 大香蕉久久成人网| 久久99一区二区三区| 最近中文字幕2019免费版| 国产一区二区激情短视频 | 精品国产一区二区久久| 精品人妻熟女毛片av久久网站| 伊人久久国产一区二区| 好男人视频免费观看在线| 亚洲精品久久午夜乱码| 青春草亚洲视频在线观看| 爱豆传媒免费全集在线观看| 国产精品偷伦视频观看了| 欧美日韩一区二区视频在线观看视频在线| 成人免费观看视频高清| 中文字幕人妻丝袜一区二区 | 超碰97精品在线观看| 丝袜美足系列| 久久综合国产亚洲精品| 久久午夜综合久久蜜桃| 男女国产视频网站| 久久久久人妻精品一区果冻| 精品一区二区三区四区五区乱码 | 国产熟女午夜一区二区三区| a级毛片在线看网站| 边亲边吃奶的免费视频| 电影成人av| 日产精品乱码卡一卡2卡三| 欧美日韩成人在线一区二区| 男女边摸边吃奶| 国产男女超爽视频在线观看| kizo精华| 另类亚洲欧美激情| 国产色婷婷99| 日韩制服丝袜自拍偷拍| 欧美激情高清一区二区三区 | 97精品久久久久久久久久精品| 亚洲一区中文字幕在线| 老司机亚洲免费影院| 嫩草影院入口| 国产成人a∨麻豆精品| 国产日韩一区二区三区精品不卡| 91久久精品国产一区二区三区| 成人国语在线视频| 国产男女内射视频| 国产亚洲午夜精品一区二区久久| 欧美中文综合在线视频| 亚洲精品国产色婷婷电影| 2018国产大陆天天弄谢| 一本色道久久久久久精品综合| 成人国语在线视频| 精品久久蜜臀av无| 777米奇影视久久| 日韩av免费高清视频| 精品一区在线观看国产| 国产精品一区二区在线不卡| 夫妻午夜视频| 黑人猛操日本美女一级片| 91久久精品国产一区二区三区| 青青草视频在线视频观看| 中文字幕最新亚洲高清| 国产精品 欧美亚洲| 国产视频首页在线观看| 97在线视频观看| 男女高潮啪啪啪动态图| 亚洲av福利一区| 亚洲精品国产一区二区精华液| 国产亚洲最大av| 中国国产av一级| 中文字幕色久视频| 欧美少妇被猛烈插入视频| 夫妻午夜视频| 多毛熟女@视频| 2018国产大陆天天弄谢| 午夜久久久在线观看| av网站在线播放免费| 久久久久人妻精品一区果冻| av在线播放精品| 午夜免费鲁丝| 99久久综合免费| 亚洲精品国产av成人精品| 9热在线视频观看99| 亚洲国产欧美网| 色婷婷久久久亚洲欧美| 亚洲精品成人av观看孕妇| 啦啦啦啦在线视频资源| 丝袜在线中文字幕| 亚洲美女搞黄在线观看| 午夜福利视频在线观看免费| 国产色婷婷99| 久久精品熟女亚洲av麻豆精品| 人妻 亚洲 视频| 精品人妻熟女毛片av久久网站| 久久久欧美国产精品| 老汉色av国产亚洲站长工具| 90打野战视频偷拍视频| 永久网站在线| 母亲3免费完整高清在线观看 | 久久精品久久久久久噜噜老黄| 欧美人与性动交α欧美精品济南到 | 精品少妇久久久久久888优播| 国产片内射在线| 国产成人精品无人区| 婷婷成人精品国产| 熟妇人妻不卡中文字幕| 新久久久久国产一级毛片| 亚洲伊人色综图| av在线app专区| 日韩视频在线欧美| 午夜福利,免费看| 性高湖久久久久久久久免费观看| 成人亚洲欧美一区二区av| 中文字幕另类日韩欧美亚洲嫩草| 中文天堂在线官网| 美女主播在线视频| 搡老乐熟女国产| 国产日韩一区二区三区精品不卡| 各种免费的搞黄视频| 亚洲av男天堂| 男女国产视频网站| 国产精品久久久久久av不卡| 久久精品国产综合久久久| 下体分泌物呈黄色| 亚洲精品成人av观看孕妇| 日韩制服丝袜自拍偷拍| 精品亚洲成a人片在线观看| 乱人伦中国视频| 成年女人在线观看亚洲视频| 九草在线视频观看| 久久人妻熟女aⅴ| 日本色播在线视频| 乱人伦中国视频| 97人妻天天添夜夜摸| 国产 精品1| 国产欧美日韩一区二区三区在线| 天天影视国产精品| 亚洲国产日韩一区二区| 国产av码专区亚洲av| 成人毛片60女人毛片免费| 亚洲精品视频女| 久久精品久久久久久噜噜老黄| 国产激情久久老熟女| 热re99久久国产66热| 婷婷色综合www| 老司机亚洲免费影院| 亚洲三区欧美一区| 男人舔女人的私密视频| 日韩电影二区| 国产探花极品一区二区| av有码第一页| 满18在线观看网站| 亚洲熟女精品中文字幕| 少妇人妻久久综合中文| 黄色怎么调成土黄色| 夜夜骑夜夜射夜夜干| 激情视频va一区二区三区| 午夜影院在线不卡| 欧美黄色片欧美黄色片| 制服丝袜香蕉在线| 哪个播放器可以免费观看大片| 精品久久久久久电影网| 国产高清国产精品国产三级| 亚洲国产最新在线播放| 久久久精品区二区三区| 伊人久久国产一区二区| 亚洲成av片中文字幕在线观看 | 亚洲欧美成人综合另类久久久| www.精华液| av卡一久久| 麻豆乱淫一区二区| 久久久久久久亚洲中文字幕| 在线精品无人区一区二区三| 一级毛片黄色毛片免费观看视频| 99香蕉大伊视频| 国产精品免费大片| 国精品久久久久久国模美| 水蜜桃什么品种好| 欧美av亚洲av综合av国产av | 涩涩av久久男人的天堂| 免费看不卡的av| 精品国产一区二区三区久久久樱花| 男人操女人黄网站| 少妇人妻久久综合中文| 久久精品久久精品一区二区三区| 亚洲精品日本国产第一区| 亚洲国产精品国产精品| 伦精品一区二区三区| 免费女性裸体啪啪无遮挡网站| av免费观看日本| 久久人人爽av亚洲精品天堂| 9热在线视频观看99| 久久人人97超碰香蕉20202| 少妇被粗大的猛进出69影院| 欧美日韩综合久久久久久| 男人操女人黄网站| 亚洲av电影在线观看一区二区三区| 欧美人与性动交α欧美软件| 欧美日韩亚洲高清精品| 久久av网站| 亚洲欧美精品自产自拍| 亚洲美女视频黄频| av网站在线播放免费| 天天躁日日躁夜夜躁夜夜| 婷婷成人精品国产| 国产成人一区二区在线| 国产熟女欧美一区二区| 日韩伦理黄色片| 天堂8中文在线网| 亚洲欧美一区二区三区国产| 久久久久久久亚洲中文字幕| 色94色欧美一区二区| 五月伊人婷婷丁香| 国产亚洲午夜精品一区二区久久| 婷婷色综合www| 97在线人人人人妻| 亚洲成色77777| 精品久久久久久电影网| av卡一久久| 国产在线一区二区三区精| 亚洲成人av在线免费| 26uuu在线亚洲综合色| 看免费av毛片| 秋霞在线观看毛片| 成人午夜精彩视频在线观看| 伊人亚洲综合成人网| 大片电影免费在线观看免费| 亚洲四区av| 国产xxxxx性猛交| 大陆偷拍与自拍| 精品久久蜜臀av无| 色播在线永久视频| 国产精品久久久久久精品古装| 亚洲第一av免费看| 99精国产麻豆久久婷婷| 色婷婷av一区二区三区视频| 国产成人a∨麻豆精品| 香蕉精品网在线| 欧美老熟妇乱子伦牲交| 最新的欧美精品一区二区| 97在线视频观看| 人妻少妇偷人精品九色| 久久av网站| 亚洲美女黄色视频免费看| 精品少妇久久久久久888优播| 黄色 视频免费看| 91精品三级在线观看| 久久精品亚洲av国产电影网| 自拍欧美九色日韩亚洲蝌蚪91| 亚洲av免费高清在线观看| 久久久欧美国产精品| 看十八女毛片水多多多| 观看av在线不卡| 精品少妇内射三级| 黑人巨大精品欧美一区二区蜜桃| 在线天堂最新版资源| 一级毛片电影观看| 性色av一级| 不卡视频在线观看欧美| 日本午夜av视频| 亚洲,一卡二卡三卡| 国产爽快片一区二区三区| 老司机影院毛片| 亚洲精品乱久久久久久| 在线 av 中文字幕| 午夜免费观看性视频| 在线看a的网站| 日本猛色少妇xxxxx猛交久久| 日本欧美国产在线视频| 男人添女人高潮全过程视频| a级毛片在线看网站| 黄片播放在线免费| 丝袜在线中文字幕| 国产成人精品在线电影| 日韩不卡一区二区三区视频在线| 热re99久久国产66热| 国产色婷婷99| 麻豆av在线久日| 精品一区在线观看国产| 精品少妇一区二区三区视频日本电影 | 久久久国产精品麻豆| 精品久久久久久电影网| 人妻人人澡人人爽人人| 一级爰片在线观看| 欧美精品人与动牲交sv欧美| 久久午夜综合久久蜜桃| 三级国产精品片| 美女高潮到喷水免费观看| 日韩三级伦理在线观看| 国产精品久久久久久精品电影小说| 人妻一区二区av| 亚洲av.av天堂| 国产黄色视频一区二区在线观看| 捣出白浆h1v1| 菩萨蛮人人尽说江南好唐韦庄| 久久国内精品自在自线图片| 日韩欧美一区视频在线观看| 汤姆久久久久久久影院中文字幕| 日本av手机在线免费观看| 久久久久久久国产电影| 亚洲欧美精品自产自拍| 91久久精品国产一区二区三区| 日韩制服丝袜自拍偷拍| 天堂中文最新版在线下载| 男女高潮啪啪啪动态图| 国产精品国产三级国产专区5o| 在线精品无人区一区二区三| 久久精品亚洲av国产电影网| 久久韩国三级中文字幕| 久久久久久久亚洲中文字幕| 亚洲一区二区三区欧美精品| 精品少妇久久久久久888优播| 中文字幕亚洲精品专区| 国产有黄有色有爽视频| 国产激情久久老熟女| 欧美亚洲日本最大视频资源| 久久久久久久久久人人人人人人| 中文精品一卡2卡3卡4更新| 侵犯人妻中文字幕一二三四区| 欧美日本中文国产一区发布| 日韩制服骚丝袜av| 亚洲国产色片| 91精品三级在线观看| 性少妇av在线| 97人妻天天添夜夜摸| 亚洲,欧美,日韩| 亚洲伊人久久精品综合| av女优亚洲男人天堂| 国产精品二区激情视频| 十分钟在线观看高清视频www| 最近的中文字幕免费完整| 久久鲁丝午夜福利片| 日韩大片免费观看网站| 久久久久国产精品人妻一区二区| 老汉色av国产亚洲站长工具| 国产一区二区在线观看av| 水蜜桃什么品种好| 国产成人精品福利久久| 777米奇影视久久| 日韩一区二区三区影片| 美女脱内裤让男人舔精品视频| 日韩av免费高清视频| 麻豆精品久久久久久蜜桃| 两个人免费观看高清视频| 国产精品一区二区在线观看99| 亚洲av男天堂| 好男人视频免费观看在线| 男女午夜视频在线观看| 亚洲精品视频女| 热re99久久国产66热| 国产精品国产av在线观看| 国产麻豆69| 少妇人妻精品综合一区二区| 精品人妻在线不人妻| 午夜av观看不卡| 国产精品久久久久成人av| 亚洲国产精品999| 国产欧美日韩综合在线一区二区| 99久国产av精品国产电影| 亚洲在久久综合| 日本色播在线视频| 高清欧美精品videossex| 国产成人一区二区在线| 亚洲av成人精品一二三区| 韩国av在线不卡| 久久精品人人爽人人爽视色| 国产精品三级大全| 亚洲国产欧美日韩在线播放| 99国产综合亚洲精品| 国产人伦9x9x在线观看 | 一区福利在线观看| 亚洲精品久久久久久婷婷小说| 亚洲精品久久午夜乱码| 亚洲第一av免费看| 亚洲欧美一区二区三区黑人 | 美女午夜性视频免费| 国产一区二区三区av在线| 99久久综合免费| 欧美老熟妇乱子伦牲交| 性少妇av在线| 亚洲欧美一区二区三区国产| 黄色配什么色好看| 欧美日韩亚洲国产一区二区在线观看 | 十分钟在线观看高清视频www| 国产精品99久久99久久久不卡 | 日日啪夜夜爽| 中文天堂在线官网| 国产av国产精品国产| 一个人免费看片子| 国产 一区精品| 丝袜脚勾引网站| 亚洲经典国产精华液单| 国产成人精品婷婷| 精品99又大又爽又粗少妇毛片| 日韩人妻精品一区2区三区| 午夜日韩欧美国产| 亚洲,欧美精品.| 国产精品秋霞免费鲁丝片| 激情视频va一区二区三区| 大话2 男鬼变身卡| 最近中文字幕高清免费大全6| 日韩精品免费视频一区二区三区| 少妇被粗大猛烈的视频| 午夜激情av网站| 叶爱在线成人免费视频播放| 搡老乐熟女国产| 国产色婷婷99| 亚洲欧洲国产日韩| 在线免费观看不下载黄p国产| 人体艺术视频欧美日本| 国产综合精华液| 精品国产一区二区三区四区第35| 日韩中字成人| 日韩中文字幕欧美一区二区 | 春色校园在线视频观看| 91精品三级在线观看| 熟女少妇亚洲综合色aaa.| 妹子高潮喷水视频| 男的添女的下面高潮视频| 99九九在线精品视频| 国产午夜精品一二区理论片| 少妇的丰满在线观看| 老汉色∧v一级毛片| 老鸭窝网址在线观看| 成人国产麻豆网| 国产毛片在线视频| 精品一区二区免费观看| 少妇熟女欧美另类| 满18在线观看网站| 午夜福利视频精品| 伦精品一区二区三区| 欧美国产精品一级二级三级| 久久久国产欧美日韩av| 国产 一区精品| av女优亚洲男人天堂| videosex国产| 观看美女的网站| 少妇被粗大的猛进出69影院| 色吧在线观看| 香蕉精品网在线| 日韩av不卡免费在线播放| 亚洲国产最新在线播放| 亚洲精品美女久久久久99蜜臀 | 美女午夜性视频免费| 亚洲国产av新网站| 国产精品久久久久久久久免| 麻豆av在线久日| 老司机影院成人| 人体艺术视频欧美日本| 亚洲色图综合在线观看| 国产精品国产av在线观看| 99热网站在线观看| 美女视频免费永久观看网站| 亚洲av中文av极速乱| av不卡在线播放| 成人亚洲欧美一区二区av| 我的亚洲天堂| 另类亚洲欧美激情| 精品久久蜜臀av无| 国产日韩欧美亚洲二区| 搡女人真爽免费视频火全软件| 人妻系列 视频| 亚洲av欧美aⅴ国产| 欧美国产精品va在线观看不卡| 亚洲经典国产精华液单| 亚洲,一卡二卡三卡| 99re6热这里在线精品视频| 激情五月婷婷亚洲| 国产淫语在线视频| xxx大片免费视频| 波多野结衣av一区二区av| 亚洲国产av新网站| 欧美亚洲日本最大视频资源| freevideosex欧美| 欧美精品亚洲一区二区| 边亲边吃奶的免费视频| 人妻人人澡人人爽人人| 久久久久久久久久久免费av| 色视频在线一区二区三区| 免费看不卡的av| 国产男女内射视频| 男女无遮挡免费网站观看| 国产成人精品婷婷| 天天影视国产精品| 十分钟在线观看高清视频www| 十八禁高潮呻吟视频| 国产麻豆69| av在线app专区| 日韩一卡2卡3卡4卡2021年| 亚洲国产精品国产精品| 26uuu在线亚洲综合色| 亚洲国产成人一精品久久久| 超色免费av| 国产亚洲一区二区精品| 日韩av在线免费看完整版不卡| 不卡av一区二区三区| 国产有黄有色有爽视频| 又黄又粗又硬又大视频| 日本-黄色视频高清免费观看| 一本大道久久a久久精品| 叶爱在线成人免费视频播放| 精品久久久精品久久久| 欧美日韩一区二区视频在线观看视频在线| 午夜福利影视在线免费观看| 久久精品人人爽人人爽视色| 日日摸夜夜添夜夜爱| 亚洲精品美女久久av网站| 黄色毛片三级朝国网站| 国产一区二区激情短视频 | 男男h啪啪无遮挡| 免费大片黄手机在线观看| 亚洲 欧美一区二区三区| 在线天堂中文资源库| 一区二区三区四区激情视频| 成人免费观看视频高清| 中文字幕av电影在线播放| 亚洲国产精品999| 天堂8中文在线网| 亚洲国产日韩一区二区| 天美传媒精品一区二区| 大香蕉久久网| 啦啦啦视频在线资源免费观看| av有码第一页| 亚洲国产欧美网| 香蕉丝袜av| 亚洲av免费高清在线观看| 国产免费福利视频在线观看| 亚洲av免费高清在线观看| 亚洲av日韩在线播放| 99精国产麻豆久久婷婷| 亚洲综合精品二区| 亚洲欧美精品自产自拍| 老司机影院成人| 永久免费av网站大全| 最近2019中文字幕mv第一页| 亚洲精品自拍成人| 麻豆精品久久久久久蜜桃| 中文欧美无线码| 国产成人欧美| 日韩精品有码人妻一区| 涩涩av久久男人的天堂| 一级毛片 在线播放| 新久久久久国产一级毛片| 99热网站在线观看| 久久久a久久爽久久v久久| av网站在线播放免费| 国产又色又爽无遮挡免| 丰满乱子伦码专区| kizo精华| 我的亚洲天堂| 国产伦理片在线播放av一区| 久久青草综合色| 亚洲中文av在线| 一区二区三区乱码不卡18| 高清黄色对白视频在线免费看| 国产黄色视频一区二区在线观看| 亚洲精品久久久久久婷婷小说| 免费看av在线观看网站| 国产精品一国产av| 国产欧美日韩一区二区三区在线| 精品一区二区免费观看| 亚洲第一av免费看| www.熟女人妻精品国产| 国产成人一区二区在线| 久久97久久精品| 人体艺术视频欧美日本| 久久久久精品性色| 免费人妻精品一区二区三区视频| 亚洲精品中文字幕在线视频| 国产欧美日韩综合在线一区二区| 国产野战对白在线观看| 午夜久久久在线观看| 久久av网站| 午夜福利视频精品| 狠狠婷婷综合久久久久久88av|