久久精品国产精品国产精品污,男人扒开添女人下部免费视频,一级国产69式性姿势免费视频,夜鲁夜鲁很鲁在线视频 视频,欧美丰满少妇一区二区三区,国产偷国产偷亚洲高清人乐享,中文 在线 日韩 亚洲 欧美,熟妇人妻无乱码中文字幕真矢织江,一区二区三区人妻制服国产

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

转载的SSO文章,很基础

發(fā)布時(shí)間:2024/4/14 编程问答 42 豆豆
生活随笔 收集整理的這篇文章主要介紹了 转载的SSO文章,很基础 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
單點(diǎn)登錄(SSO)的技術(shù)被越來越廣泛地運(yùn)用到各個(gè)領(lǐng)域的軟件系統(tǒng)當(dāng)中。本文從業(yè)務(wù)的角度分析了單點(diǎn)登錄的需求和應(yīng)用領(lǐng)域;從技術(shù)本身的角度分析了單點(diǎn)登錄技術(shù)的內(nèi)部機(jī)制和實(shí)現(xiàn)手段,并且給出Web-SSO和桌面SSO的實(shí)現(xiàn)、源代碼和詳細(xì)講解;還從安全和性能的角度對現(xiàn)有的實(shí)現(xiàn)技術(shù)進(jìn)行進(jìn)一步分析,指出相應(yīng)的風(fēng)險(xiǎn)和需要改進(jìn)的方面。本文除了從多個(gè)方面和角度給出了對單點(diǎn)登錄(SSO)的全面分析,還并且討論了如何將現(xiàn)有的應(yīng)用和SSO服務(wù)結(jié)合起來,能夠幫助應(yīng)用架構(gòu)師和系統(tǒng)分析人員從本質(zhì)上認(rèn)識單點(diǎn)登錄,從而更好地設(shè)計(jì)出符合需要的安全架構(gòu)。
關(guān)鍵字:SSO, Java, J2EE, JAAS
1 什么是單點(diǎn)登陸
單點(diǎn)登錄(Single Sign On),簡稱為 SSO,是目前比較流行的企業(yè)業(yè)務(wù)整合的解決方案之一。SSO的定義是在多個(gè)應(yīng)用系統(tǒng)中,用戶只需要登錄一次就可以訪問所有相互信任的應(yīng)用系統(tǒng)。
較大的企業(yè)內(nèi)部,一般都有很多的業(yè)務(wù)支持系統(tǒng)為其提供相應(yīng)的管理和IT服務(wù)。例如財(cái)務(wù)系統(tǒng)為財(cái)務(wù)人員提供財(cái)務(wù)的管理、計(jì)算和報(bào)表服務(wù);人事系統(tǒng)為人事部門提供全公司人員的維護(hù)服務(wù);各種業(yè)務(wù)系統(tǒng)為公司內(nèi)部不同的業(yè)務(wù)提供不同的服務(wù)等等。這些系統(tǒng)的目的都是讓計(jì)算機(jī)來進(jìn)行復(fù)雜繁瑣的計(jì)算工作,來替代人力的手工勞動(dòng),提高工作效率和質(zhì)量。這些不同的系統(tǒng)往往是在不同的時(shí)期建設(shè)起來的,運(yùn)行在不同的平臺上;也許是由不同廠商開發(fā),使用了各種不同的技術(shù)和標(biāo)準(zhǔn)。如果舉例說國內(nèi)一著名的IT公司(名字隱去),內(nèi)部共有60多個(gè)業(yè)務(wù)系統(tǒng),這些系統(tǒng)包括兩個(gè)不同版本的SAP的ERP系統(tǒng),12個(gè)不同類型和版本的數(shù)據(jù)庫系統(tǒng),8個(gè)不同類型和版本的操作系統(tǒng),以及使用了3種不同的防火墻技術(shù),還有數(shù)十種互相不能兼容的協(xié)議和標(biāo)準(zhǔn),你相信嗎?不要懷疑,這種情況其實(shí)非常普遍。每一個(gè)應(yīng)用系統(tǒng)在運(yùn)行了數(shù)年以后,都會成為不可替換的企業(yè)IT架構(gòu)的一部分,如下圖所示。
隨著企業(yè)的發(fā)展,業(yè)務(wù)系統(tǒng)的數(shù)量在不斷的增加,老的系統(tǒng)卻不能輕易的替換,這會帶來很多的開銷。其一是管理上的開銷,需要維護(hù)的系統(tǒng)越來越多。很多系統(tǒng)的數(shù)據(jù)是相互冗余和重復(fù)的,數(shù)據(jù)的不一致性會給管理工作帶來很大的壓力。業(yè)務(wù)和業(yè)務(wù)之間的相關(guān)性也越來越大,例如公司的計(jì)費(fèi)系統(tǒng)和財(cái)務(wù)系統(tǒng),財(cái)務(wù)系統(tǒng)和人事系統(tǒng)之間都不可避免的有著密切的關(guān)系。
為了降低管理的消耗,最大限度的重用已有投資的系統(tǒng),很多企業(yè)都在進(jìn)行著企業(yè)應(yīng)用集成(EAI)。企業(yè)應(yīng)用集成可以在不同層面上進(jìn)行:例如在數(shù)據(jù)存儲層面上的“數(shù)據(jù)大集中”,在傳輸層面上的“通用數(shù)據(jù)交換平臺”,在應(yīng)用層面上的“業(yè)務(wù)流程整合”,和用戶界面上的“通用企業(yè)門戶”等等。事實(shí)上,還用一個(gè)層面上的集成變得越來越重要,那就是“身份認(rèn)證”的整合,也就是“單點(diǎn)登錄”。
通常來說,每個(gè)單獨(dú)的系統(tǒng)都會有自己的安全體系和身份認(rèn)證系統(tǒng)。整合以前,進(jìn)入每個(gè)系統(tǒng)都需要進(jìn)行登錄,這樣的局面不僅給管理上帶來了很大的困難,在安全方面也埋下了重大的隱患。下面是一些著名的調(diào)查公司顯示的統(tǒng)計(jì)數(shù)據(jù):
用戶每天平均 16 分鐘花在身份驗(yàn)證任務(wù)上 - 資料來源: IDS
頻繁的 IT 用戶平均有 21 個(gè)密碼 - 資料來源: NTA Monitor Password Survey
49% 的人寫下了其密碼,而 67% 的人很少改變它們
每 79 秒出現(xiàn)一起身份被竊事件 - 資料來源:National Small Business Travel Assoc
全球欺騙損失每年約 12B - 資料來源:Comm Fraud Control Assoc
到 2007 年,身份管理市場將成倍增長至 $4.5B - 資料來源:IDS

使用“單點(diǎn)登錄”整合后,只需要登錄一次就可以進(jìn)入多個(gè)系統(tǒng),而不需要重新登錄,這不僅僅帶來了更好的用戶體驗(yàn),更重要的是降低了安全的風(fēng)險(xiǎn)和管理的消耗。請看下面的統(tǒng)計(jì)數(shù)據(jù):
提高 IT 效率:對于每 1000 個(gè)受管用戶,每用戶可節(jié)省$70K
幫助臺呼叫減少至少1/3,對于 10K 員工的公司,每年可以節(jié)省每用戶 $75,或者合計(jì) $648K
生產(chǎn)力提高:每個(gè)新員工可節(jié)省 $1K,每個(gè)老員工可節(jié)省 $350 ?資料來源:Giga
ROI 回報(bào):7.5 到 13 個(gè)月 ?資料來源:Gartner

另外,使用“單點(diǎn)登錄”還是SOA時(shí)代的需求之一。在面向服務(wù)的架構(gòu)中,服務(wù)和服務(wù)之間,程序和程序之間的通訊大量存在,服務(wù)之間的安全認(rèn)證是SOA應(yīng)用的難點(diǎn)之一,應(yīng)此建立“單點(diǎn)登錄”的系統(tǒng)體系能夠大大簡化SOA的安全問題,提高服務(wù)之間的合作效率。
2 單點(diǎn)登陸的技術(shù)實(shí)現(xiàn)機(jī)制
隨著SSO技術(shù)的流行,SSO的產(chǎn)品也是滿天飛揚(yáng)。所有著名的軟件廠商都提供了相應(yīng)的解決方案。在這里我并不想介紹自己公司(Sun Microsystems)的產(chǎn)品,而是對SSO技術(shù)本身進(jìn)行解析,并且提供自己開發(fā)這一類產(chǎn)品的方法和簡單演示。有關(guān)我寫這篇文章的目的,請參考我的博客(http://yuwang881.blog.sohu.com/3184816.html)。
單點(diǎn)登錄的機(jī)制其實(shí)是比較簡單的,用一個(gè)現(xiàn)實(shí)中的例子做比較。頤和園是北京著名的旅游景點(diǎn),也是我常去的地方。在頤和園內(nèi)部有許多獨(dú)立的景點(diǎn),例如“蘇州街”、“佛香閣”和“德和園”,都可以在各個(gè)景點(diǎn)門口單獨(dú)買票。很多游客需要游玩所有德景點(diǎn),這種買票方式很不方便,需要在每個(gè)景點(diǎn)門口排隊(duì)買票,錢包拿進(jìn)拿出的,容易丟失,很不安全。于是絕大多數(shù)游客選擇在大門口買一張通票(也叫套票),就可以玩遍所有的景點(diǎn)而不需要重新再買票。他們只需要在每個(gè)景點(diǎn)門口出示一下剛才買的套票就能夠被允許進(jìn)入每個(gè)獨(dú)立的景點(diǎn)。
單點(diǎn)登錄的機(jī)制也一樣,如下圖所示,當(dāng)用戶第一次訪問應(yīng)用系統(tǒng)1的時(shí)候,因?yàn)檫€沒有登錄,會被引導(dǎo)到認(rèn)證系統(tǒng)中進(jìn)行登錄(1);根據(jù)用戶提供的登錄信息,認(rèn)證系統(tǒng)進(jìn)行身份效驗(yàn),如果通過效驗(yàn),應(yīng)該返回給用戶一個(gè)認(rèn)證的憑據(jù)--ticket(2);用戶再訪問別的應(yīng)用的時(shí)候(3,5)就會將這個(gè)ticket帶上,作為自己認(rèn)證的憑據(jù),應(yīng)用系統(tǒng)接受到請求之后會把ticket送到認(rèn)證系統(tǒng)進(jìn)行效驗(yàn),檢查ticket的合法性(4,6)。如果通過效驗(yàn),用戶就可以在不用再次登錄的情況下訪問應(yīng)用系統(tǒng)2和應(yīng)用系統(tǒng)3了。
從上面的視圖可以看出,要實(shí)現(xiàn)SSO,需要以下主要的功能:
所有應(yīng)用系統(tǒng)共享一個(gè)身份認(rèn)證系統(tǒng)。
統(tǒng)一的認(rèn)證系統(tǒng)是SSO的前提之一。認(rèn)證系統(tǒng)的主要功能是將用戶的登錄信息和用戶信息庫相比較,對用戶進(jìn)行登錄認(rèn)證;認(rèn)證成功后,認(rèn)證系統(tǒng)應(yīng)該生成統(tǒng)一的認(rèn)證標(biāo)志(ticket),返還給用戶。另外,認(rèn)證系統(tǒng)還應(yīng)該對ticket進(jìn)行效驗(yàn),判斷其有效性。
所有應(yīng)用系統(tǒng)能夠識別和提取ticket信息
要實(shí)現(xiàn)SSO的功能,讓用戶只登錄一次,就必須讓應(yīng)用系統(tǒng)能夠識別已經(jīng)登錄過的用戶。應(yīng)用系統(tǒng)應(yīng)該能對ticket進(jìn)行識別和提取,通過與認(rèn)證系統(tǒng)的通訊,能自動(dòng)判斷當(dāng)前用戶是否登錄過,從而完成單點(diǎn)登錄的功能。

上面的功能只是一個(gè)非常簡單的SSO架構(gòu),在現(xiàn)實(shí)情況下的SSO有著更加復(fù)雜的結(jié)構(gòu)。有兩點(diǎn)需要指出的是:
單一的用戶信息數(shù)據(jù)庫并不是必須的,有許多系統(tǒng)不能將所有的用戶信息都集中存儲,應(yīng)該允許用戶信息放置在不同的存儲中,如下圖所示。事實(shí)上,只要統(tǒng)一認(rèn)證系統(tǒng),統(tǒng)一ticket的產(chǎn)生和效驗(yàn),無論用戶信息存儲在什么地方,都能實(shí)現(xiàn)單點(diǎn)登錄。

統(tǒng)一的認(rèn)證系統(tǒng)并不是說只有單個(gè)的認(rèn)證服務(wù)器,如下圖所示,整個(gè)系統(tǒng)可以存在兩個(gè)以上的認(rèn)證服務(wù)器,這些服務(wù)器甚至可以是不同的產(chǎn)品。認(rèn)證服務(wù)器之間要通過標(biāo)準(zhǔn)的通訊協(xié)議,互相交換認(rèn)證信息,就能完成更高級別的單點(diǎn)登錄。如下圖,當(dāng)用戶在訪問應(yīng)用系統(tǒng)1時(shí),由第一個(gè)認(rèn)證服務(wù)器進(jìn)行認(rèn)證后,得到由此服務(wù)器產(chǎn)生的ticket。當(dāng)他訪問應(yīng)用系統(tǒng)4的時(shí)候,認(rèn)證服務(wù)器2能夠識別此ticket是由第一個(gè)服務(wù)器產(chǎn)生的,通過認(rèn)證服務(wù)器之間標(biāo)準(zhǔn)的通訊協(xié)議(例如SAML)來交換認(rèn)證信息,仍然能夠完成SSO的功能。

3 WEB-SSO的實(shí)現(xiàn)
隨著互聯(lián)網(wǎng)的高速發(fā)展,WEB應(yīng)用幾乎統(tǒng)治了絕大部分的軟件應(yīng)用系統(tǒng),因此WEB-SSO是SSO應(yīng)用當(dāng)中最為流行。WEB-SSO有其自身的特點(diǎn)和優(yōu)勢,實(shí)現(xiàn)起來比較簡單易用。很多商業(yè)軟件和開源軟件都有對WEB-SSO的實(shí)現(xiàn)。其中值得一提的是OpenSSO (https://opensso.dev.java.net),為用Java實(shí)現(xiàn)WEB-SSO提供架構(gòu)指南和服務(wù)指南,為用戶自己來實(shí)現(xiàn)WEB-SSO提供了理論的依據(jù)和實(shí)現(xiàn)的方法。
為什么說WEB-SSO比較容易實(shí)現(xiàn)呢?這是有WEB應(yīng)用自身的特點(diǎn)決定的。
眾所周知,Web協(xié)議(也就是HTTP)是一個(gè)無狀態(tài)的協(xié)議。一個(gè)Web應(yīng)用由很多個(gè)Web頁面組成,每個(gè)頁面都有唯一的URL來定義。用戶在瀏覽器的地址欄輸入頁面的URL,瀏覽器就會向Web Server去發(fā)送請求。如下圖,瀏覽器向Web服務(wù)器發(fā)送了兩個(gè)請求,申請了兩個(gè)頁面。這兩個(gè)頁面的請求是分別使用了兩個(gè)單獨(dú)的HTTP連接。所謂無狀態(tài)的協(xié)議也就是表現(xiàn)在這里,瀏覽器和Web服務(wù)器會在第一個(gè)請求完成以后關(guān)閉連接通道,在第二個(gè)請求的時(shí)候重新建立連接。Web服務(wù)器并不區(qū)分哪個(gè)請求來自哪個(gè)客戶端,對所有的請求都一視同仁,都是單獨(dú)的連接。這樣的方式大大區(qū)別于傳統(tǒng)的(Client/Server)C/S結(jié)構(gòu),在那樣的應(yīng)用中,客戶端和服務(wù)器端會建立一個(gè)長時(shí)間的專用的連接通道。正是因?yàn)橛辛藷o狀態(tài)的特性,每個(gè)連接資源能夠很快被其他客戶端所重用,一臺Web服務(wù)器才能夠同時(shí)服務(wù)于成千上萬的客戶端。
但是我們通常的應(yīng)用是有狀態(tài)的。先不用提不同應(yīng)用之間的SSO,在同一個(gè)應(yīng)用中也需要保存用戶的登錄身份信息。例如用戶在訪問頁面1的時(shí)候進(jìn)行了登錄,但是剛才也提到,客戶端的每個(gè)請求都是單獨(dú)的連接,當(dāng)客戶再次訪問頁面2的時(shí)候,如何才能告訴Web服務(wù)器,客戶剛才已經(jīng)登錄過了呢?瀏覽器和服務(wù)器之間有約定:通過使用cookie技術(shù)來維護(hù)應(yīng)用的狀態(tài)。Cookie是可以被Web服務(wù)器設(shè)置的字符串,并且可以保存在瀏覽器中。如下圖所示,當(dāng)瀏覽器訪問了頁面1時(shí),web服務(wù)器設(shè)置了一個(gè)cookie,并將這個(gè)cookie和頁面1一起返回給瀏覽器,瀏覽器接到cookie之后,就會保存起來,在它訪問頁面2的時(shí)候會把這個(gè)cookie也帶上,Web服務(wù)器接到請求時(shí)也能讀出cookie的值,根據(jù)cookie值的內(nèi)容就可以判斷和恢復(fù)一些用戶的信息狀態(tài)。
Web-SSO完全可以利用Cookie結(jié)束來完成用戶登錄信息的保存,將瀏覽器中的Cookie和上文中的Ticket結(jié)合起來,完成SSO的功能。

為了完成一個(gè)簡單的SSO的功能,需要兩個(gè)部分的合作:
統(tǒng)一的身份認(rèn)證服務(wù)。
修改Web應(yīng)用,使得每個(gè)應(yīng)用都通過這個(gè)統(tǒng)一的認(rèn)證服務(wù)來進(jìn)行身份效驗(yàn)。
3.1 Web SSO 的樣例
根據(jù)上面的原理,我用J2EE的技術(shù)(JSP和Servlet)完成了一個(gè)具有Web-SSO的簡單樣例。樣例包含一個(gè)身份認(rèn)證的服務(wù)器和兩個(gè)簡單的Web應(yīng)用,使得這兩個(gè) Web應(yīng)用通過統(tǒng)一的身份認(rèn)證服務(wù)來完成Web-SSO的功能。此樣例所有的源代碼和二進(jìn)制代碼都可以從網(wǎng)站地址http://gceclub.sun.com.cn/wangyu/ 下載。

樣例下載、安裝部署和運(yùn)行指南:
Web-SSO的樣例是由三個(gè)標(biāo)準(zhǔn)Web應(yīng)用組成,壓縮成三個(gè)zip文件,從http://gceclub.sun.com.cn/wangyu/web-sso/中下載。其中SSOAuth(http://gceclub.sun.com.cn/wangyu/web-sso/SSOAuth.zip)是身份認(rèn)證服務(wù);SSOWebDemo1(http://gceclub.sun.com.cn/wangyu/web-sso/SSOWebDemo1.zip)和SSOWebDemo2(http://gceclub.sun.com.cn/wangyu/web-sso/SSOWebDemo2.zip)是兩個(gè)用來演示單點(diǎn)登錄的Web應(yīng)用。這三個(gè)Web應(yīng)用之所以沒有打成war包,是因?yàn)樗鼈儾荒苤苯硬渴?#xff0c;根據(jù)讀者的部署環(huán)境需要作出小小的修改。樣例部署和運(yùn)行的環(huán)境有一定的要求,需要符合Servlet2.3以上標(biāo)準(zhǔn)的J2EE容器才能運(yùn)行(例如Tomcat5,Sun Application Server 8, Jboss 4等)。另外,身份認(rèn)證服務(wù)需要JDK1.5的運(yùn)行環(huán)境。之所以要用JDK1.5是因?yàn)楣P者使用了一個(gè)線程安全的高性能的Java集合類“ConcurrentMap”,只有在JDK1.5中才有。
這三個(gè)Web應(yīng)用完全可以單獨(dú)部署,它們可以分別部署在不同的機(jī)器,不同的操作系統(tǒng)和不同的J2EE的產(chǎn)品上,它們完全是標(biāo)準(zhǔn)的和平臺無關(guān)的應(yīng)用。但是有一個(gè)限制,那兩臺部署應(yīng)用(demo1、demo2)的機(jī)器的域名需要相同,這在后面的章節(jié)中會解釋到cookie和domain的關(guān)系以及如何制作跨域的WEB-SSO
解壓縮SSOAuth.zip文件,在/WEB-INF/下的web.xml中請修改“domainname”的屬性以反映實(shí)際的應(yīng)用部署情況,domainname需要設(shè)置為兩個(gè)單點(diǎn)登錄的應(yīng)用(demo1和demo2)所屬的域名。這個(gè)domainname和當(dāng)前SSOAuth服務(wù)部署的機(jī)器的域名沒有關(guān)系。我缺省設(shè)置的是“.sun.com”。如果你部署demo1和demo2的機(jī)器沒有域名,請輸入IP地址或主機(jī)名(如localhost),但是如果使用IP地址或主機(jī)名也就意味著demo1和demo2需要部署到一臺機(jī)器上了。設(shè)置完后,根據(jù)你所選擇的J2EE容器,可能需要將SSOAuth這個(gè)目錄壓縮打包成war文件。用“jar -cvf SSOAuth.war SSOAuth/”就可以完成這個(gè)功能。
解壓縮SSOWebDemo1和SSOWebDemo2文件,分別在它們/WEB-INF/下找到web.xml文件,請修改其中的幾個(gè)初始化參數(shù)

SSOServiceURL
http://wangyu.prc.sun.com:8080/SSOAuth/SSOAuth


SSOLoginPage
http://wangyu.prc.sun.com:8080/SSOAuth/login.jsp

將其中的SSOServiceURL和SSOLoginPage修改成部署SSOAuth應(yīng)用的機(jī)器名、端口號以及根路徑(缺省是SSOAuth)以反映實(shí)際的部署情況。設(shè)置完后,根據(jù)你所選擇的J2EE容器,可能需要將SSOWebDemo1和SSOWebDemo2這兩個(gè)目錄壓縮打包成兩個(gè)war文件。用“jar -cvf SSOWebDemo1.war SSOWebDemo1/”就可以完成這個(gè)功能。
請輸入第一個(gè)web應(yīng)用的測試URL(test.jsp),例如http://wangyu.prc.sun.com:8080/ SSOWebDemo1/test.jsp,如果是第一次訪問,便會自動(dòng)跳轉(zhuǎn)到登錄界面,如下圖


使用系統(tǒng)自帶的三個(gè)帳號之一登錄(例如,用戶名:wangyu,密碼:wangyu),便能成功的看到test.jsp的內(nèi)容:顯示當(dāng)前用戶名和歡迎信息。

請接著在同一個(gè)瀏覽器中輸入第二個(gè)web應(yīng)用的測試URL(test.jsp),例如http://wangyu.prc.sun.com:8080/ SSOWebDemo2/test.jsp。你會發(fā)現(xiàn),不需要再次登錄就能看到test.jsp的內(nèi)容,同樣是顯示當(dāng)前用戶名和歡迎信息,而且歡迎信息中明確的顯示當(dāng)前的應(yīng)用名稱(demo2)。

3.2 WEB-SSO代碼講解
3.2.1身份認(rèn)證服務(wù)代碼解析
Web-SSO的源代碼可以從網(wǎng)站地址http://gceclub.sun.com.cn/wangyu/web-sso/websso_src.zip下載。身份認(rèn)證服務(wù)是一個(gè)標(biāo)準(zhǔn)的web應(yīng)用,包括一個(gè)名為SSOAuth的Servlet,一個(gè)login.jsp文件和一個(gè)failed.html。身份認(rèn)證的所有服務(wù)幾乎都由SSOAuth的Servlet來實(shí)現(xiàn)了;login.jsp用來顯示登錄的頁面(如果發(fā)現(xiàn)用戶還沒有登錄過);failed.html是用來顯示登錄失敗的信息(如果用戶的用戶名和密碼與信息數(shù)據(jù)庫中的不一樣)。
SSOAuth的代碼如下面的列表顯示,結(jié)構(gòu)非常簡單,先看看這個(gè)Servlet的主體部分:
package DesktopSSO;

import java.io.*;
import java.net.*;
import java.text.*;
import java.util.*;
import java.util.concurrent.*;

import javax.servlet.*;
import javax.servlet.http.*;


public class SSOAuth extends HttpServlet {

static private ConcurrentMap accounts;
static private ConcurrentMap SSOIDs;
String cookiename="WangYuDesktopSSOID";
String domainname;

public void init(ServletConfig config) throws ServletException {
super.init(config);
domainname= config.getInitParameter("domainname");
cookiename = config.getInitParameter("cookiename");
SSOIDs = new ConcurrentHashMap();
accounts=new ConcurrentHashMap();
accounts.put("wangyu", "wangyu");
accounts.put("paul", "paul");
accounts.put("carol", "carol");
}

protected void processRequest(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
PrintWriter out = response.getWriter();
String action = request.getParameter("action");
String result="failed";
if (action==null) {
handlerFromLogin(request,response);
} else if (action.equals("authcookie")){
String myCookie = request.getParameter("cookiename");
if (myCookie != null) result = authCookie(myCookie);
out.print(result);
out.close();
} else if (action.equals("authuser")) {
result=authNameAndPasswd(request,response);
out.print(result);
out.close();
} else if (action.equals("logout")) {
String myCookie = request.getParameter("cookiename");
logout(myCookie);
out.close();
}
}

.....

}


從代碼很容易看出,SSOAuth就是一個(gè)簡單的Servlet。其中有兩個(gè)靜態(tài)成員變量:accounts和SSOIDs,這兩個(gè)成員變量都使用了JDK1.5中線程安全的MAP類: ConcurrentMap,所以這個(gè)樣例一定要JDK1.5才能運(yùn)行。Accounts用來存放用戶的用戶名和密碼,在init()的方法中可以看到我給系統(tǒng)添加了三個(gè)合法的用戶。在實(shí)際應(yīng)用中,accounts應(yīng)該是去數(shù)據(jù)庫中或LDAP中獲得,為了簡單起見,在本樣例中我使用了ConcurrentMap在內(nèi)存中用程序創(chuàng)建了三個(gè)用戶。而SSOIDs保存了在用戶成功的登錄后所產(chǎn)生的cookie和用戶名的對應(yīng)關(guān)系。它的功能顯而易見:當(dāng)用戶成功登錄以后,再次訪問別的系統(tǒng),為了鑒別這個(gè)用戶請求所帶的cookie的有效性,需要到SSOIDs中檢查這樣的映射關(guān)系是否存在。

在主要的請求處理方法processRequest()中,可以很清楚的看到SSOAuth的所有功能
如果用戶還沒有登錄過,是第一次登錄本系統(tǒng),會被跳轉(zhuǎn)到login.jsp頁面(在后面會解釋如何跳轉(zhuǎn))。用戶在提供了用戶名和密碼以后,就會用handlerFromLogin()這個(gè)方法來驗(yàn)證。
如果用戶已經(jīng)登錄過本系統(tǒng),再訪問別的應(yīng)用的時(shí)候,是不需要再次登錄的。因?yàn)闉g覽器會將第一次登錄時(shí)產(chǎn)生的cookie和請求一起發(fā)送。效驗(yàn)cookie的有效性是SSOAuth的主要功能之一。
SSOAuth還能直接效驗(yàn)非login.jsp頁面過來的用戶名和密碼的效驗(yàn)請求。這個(gè)功能是用于非web應(yīng)用的SSO,這在后面的桌面SSO中會用到。
SSOAuth還提供logout服務(wù)。

下面看看幾個(gè)主要的功能函數(shù):
private void handlerFromLogin(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
String username = request.getParameter("username");
String password = request.getParameter("password");
String pass = (String)accounts.get(username);
if ((pass==null)||(!pass.equals(password)))
getServletContext().getRequestDispatcher("/failed.html").forward(request, response);
else {
String gotoURL = request.getParameter("goto");
String newID = createUID();
SSOIDs.put(newID, username);
Cookie wangyu = new Cookie(cookiename, newID);
wangyu.setDomain(domainname);
wangyu.setMaxAge(60000);
wangyu.setValue(newID);
wangyu.setPath("/");
response.addCookie(wangyu);
System.out.println("login success, goto back url:" + gotoURL);
if (gotoURL != null) {
PrintWriter out = response.getWriter();
response.sendRedirect(gotoURL);
out.close();
}
}
}

handlerFromLogin()這個(gè)方法是用來處理來自login.jsp的登錄請求。它的邏輯很簡單:將用戶輸入的用戶名和密碼與預(yù)先設(shè)定好的用戶集合(存放在accounts中)相比較,如果用戶名或密碼不匹配的話,則返回登錄失敗的頁面(failed.html),如果登錄成功的話,需要為用戶當(dāng)前的session創(chuàng)建一個(gè)新的ID,并將這個(gè)ID和用戶名的映射關(guān)系存放到SSOIDs中,最后還要將這個(gè)ID設(shè)置為瀏覽器能夠保存的cookie值。
登錄成功后,瀏覽器會到哪個(gè)頁面呢?那我們回顧一下我們是如何使用身份認(rèn)證服務(wù)的。一般來說我們不會直接訪問身份服務(wù)的任何URL,包括login.jsp。身份服務(wù)是用來保護(hù)其他應(yīng)用服務(wù)的,用戶一般在訪問一個(gè)受SSOAuth保護(hù)的Web應(yīng)用的某個(gè)URL時(shí),當(dāng)前這個(gè)應(yīng)用會發(fā)現(xiàn)當(dāng)前的用戶還沒有登錄,便強(qiáng)制將也頁面轉(zhuǎn)向SSOAuth的login.jsp,讓用戶登錄。如果登錄成功后,應(yīng)該自動(dòng)的將用戶的瀏覽器指向用戶最初想訪問的那個(gè)URL。在handlerFromLogin()這個(gè)方法中,我們通過接收“goto”這個(gè)參數(shù)來保存用戶最初訪問的URL,成功后便重新定向到這個(gè)頁面中。
另外一個(gè)要說明的是,在設(shè)置cookie的時(shí)候,我使用了一個(gè)setMaxAge(6000)的方法。這個(gè)方法是用來設(shè)置cookie的有效期,單位是秒。如果不使用這個(gè)方法或者參數(shù)為負(fù)數(shù)的話,當(dāng)瀏覽器關(guān)閉的時(shí)候,這個(gè)cookie就失效了。在這里我給了很大的值(1000分鐘),導(dǎo)致的行為是:當(dāng)你關(guān)閉瀏覽器(或者關(guān)機(jī)),下次再打開瀏覽器訪問剛才的應(yīng)用,只要在1000分鐘之內(nèi),就不需要再登錄了。我這樣做是下面要介紹的桌面SSO中所需要的功能。
其他的方法更加簡單,這里就不多解釋了。

3.2.2具有SSO功能的web應(yīng)用源代碼解析
要實(shí)現(xiàn)WEB-SSO的功能,只有身份認(rèn)證服務(wù)是不夠的。這點(diǎn)很顯然,要想使多個(gè)應(yīng)用具有單點(diǎn)登錄的功能,還需要每個(gè)應(yīng)用本身的配合:將自己的身份認(rèn)證的服務(wù)交給一個(gè)統(tǒng)一的身份認(rèn)證服務(wù)-SSOAuth。SSOAuth服務(wù)中提供的各個(gè)方法就是供每個(gè)加入SSO的Web應(yīng)用來調(diào)用的。
一般來說,Web應(yīng)用需要SSO的功能,應(yīng)該通過以下的交互過程來調(diào)用身份認(rèn)證服務(wù)的提供的認(rèn)證服務(wù):
Web應(yīng)用中每一個(gè)需要安全保護(hù)的URL在訪問以前,都需要進(jìn)行安全檢查,如果發(fā)現(xiàn)沒有登錄(沒有發(fā)現(xiàn)認(rèn)證之后所帶的cookie),就重新定向到SSOAuth中的login.jsp進(jìn)行登錄。
登錄成功后,系統(tǒng)會自動(dòng)給你的瀏覽器設(shè)置cookie,證明你已經(jīng)登錄過了。
當(dāng)你再訪問這個(gè)應(yīng)用的需要保護(hù)的URL的時(shí)候,系統(tǒng)還是要進(jìn)行安全檢查的,但是這次系統(tǒng)能夠發(fā)現(xiàn)相應(yīng)的cookie。
有了這個(gè)cookie,還不能證明你就一定有權(quán)限訪問。因?yàn)橛锌赡苣阋呀?jīng)logout,或者cookie已經(jīng)過期了,或者身份認(rèn)證服務(wù)重起過,這些情況下,你的cookie都可能無效。應(yīng)用系統(tǒng)拿到這個(gè)cookie,還需要調(diào)用身份認(rèn)證的服務(wù),來判斷cookie時(shí)候真的有效,以及當(dāng)前的cookie對應(yīng)的用戶是誰。
如果cookie效驗(yàn)成功,就允許用戶訪問當(dāng)前請求的資源。
以上這些功能,可以用很多方法來實(shí)現(xiàn):
在每個(gè)被訪問的資源中(JSP或Servlet)中都加入身份認(rèn)證的服務(wù),來獲得cookie,并且判斷當(dāng)前用戶是否登錄過。不過這個(gè)笨方法沒有人會用:-)。
可以通過一個(gè)controller,將所有的功能都寫到一個(gè)servlet中,然后在URL映射的時(shí)候,映射到所有需要保護(hù)的URL集合中(例如*.jsp,/security/*等)。這個(gè)方法可以使用,不過,它的缺點(diǎn)是不能重用。在每個(gè)應(yīng)用中都要部署一個(gè)相同的servlet。
Filter是比較好的方法。符合Servlet2.3以上的J2EE容器就具有部署filter的功能。(Filter的使用可以參考JavaWolrd的文章http://www.javaworld.com/javaworld/jw-06-2001/jw-0622-filters.html)Filter是一個(gè)具有很好的模塊化,可重用的編程API,用在SSO正合適不過。本樣例就是使用一個(gè)filter來完成以上的功能。

package SSO;

import java.io.*;
import java.net.*;
import java.util.*;
import java.text.*;
import javax.servlet.*;
import javax.servlet.http.*;
import javax.servlet.*;
import org.apache.commons.httpclient.*;
import org.apache.commons.httpclient.methods.GetMethod;

public class SSOFilter implements Filter {
private FilterConfig filterConfig = null;
private String cookieName="WangYuDesktopSSOID";
private String SSOServiceURL= "http://wangyu.prc.sun.com:8080/SSOAuth/SSOAuth";
private String SSOLoginPage= "http://wangyu.prc.sun.com:8080/SSOAuth/login.jsp";

public void init(FilterConfig filterConfig) {

this.filterConfig = filterConfig;
if (filterConfig != null) {
if (debug) {
log("SSOFilter:Initializing filter");
}
}
cookieName = filterConfig.getInitParameter("cookieName");
SSOServiceURL = filterConfig.getInitParameter("SSOServiceURL");
SSOLoginPage = filterConfig.getInitParameter("SSOLoginPage");
}
.....
.....

}

以上的初始化的源代碼有兩點(diǎn)需要說明:一是有兩個(gè)需要配置的參數(shù)SSOServiceURL和SSOLoginPage。因?yàn)楫?dāng)前的Web應(yīng)用很可能和身份認(rèn)證服務(wù)(SSOAuth)不在同一臺機(jī)器上,所以需要讓這個(gè)filter知道身份認(rèn)證服務(wù)部署的URL,這樣才能去調(diào)用它的服務(wù)。另外一點(diǎn)就是由于身份認(rèn)證的服務(wù)調(diào)用是要通過http協(xié)議來調(diào)用的(在本樣例中是這樣設(shè)計(jì)的,讀者完全可以設(shè)計(jì)自己的身份服務(wù),使用別的調(diào)用協(xié)議,如RMI或SOAP等等),所有筆者引用了apache的commons工具包(詳細(xì)信息情訪問apache 的網(wǎng)站http://jakarta.apache.org/commons/index.html),其中的“httpclient”可以大大簡化http調(diào)用的編程。
下面看看filter的主體方法doFilter():
public void doFilter(ServletRequest req, ServletResponse res, FilterChain chain) throws IOException, ServletException {
if (debug) log("SSOFilter:doFilter()");
HttpServletRequest request = (HttpServletRequest) req;
HttpServletResponse response = (HttpServletResponse) res;
String result="failed";
String url = request.getRequestURL().toString();
String qstring = request.getQueryString();
if (qstring == null) qstring ="";

//檢查http請求的head是否有需要的cookie
String cookieValue ="";
javax.servlet.http.Cookie[] diskCookies = request.getCookies();
if (diskCookies != null) {
for (int i = 0; i < diskCookies.length; i++) {
if(diskCookies[i].getName().equals(cookieName)){
cookieValue = diskCookies[i].getValue();

//如果找到了相應(yīng)的cookie則效驗(yàn)其有效性
result = SSOService(cookieValue);
if (debug) log("found cookies!");
}
}
}
if (result.equals("failed")) { //效驗(yàn)失敗或沒有找到cookie,則需要登錄
response.sendRedirect(SSOLoginPage+"?goto="+url);
} else if (qstring.indexOf("logout") > 1) {//logout服務(wù)
if (debug) log("logout action!");
logoutService(cookieValue);
response.sendRedirect(SSOLoginPage+"?goto="+url);
} else {//效驗(yàn)成功
request.setAttribute("SSOUser",result);
Throwable problem = null;
try {
chain.doFilter(req, res);
} catch(Throwable t) {
problem = t;
t.printStackTrace();
}
if (problem != null) {
if (problem instanceof ServletException) throw (ServletException)problem;
if (problem instanceof IOException) throw (IOException)problem;
sendProcessingError(problem, res);
}
}
}

doFilter()方法的邏輯也是非常簡單的,在接收到請求的時(shí)候,先去查找是否存在期望的cookie值,如果找到了,就會調(diào)用SSOService(cookieValue)去效驗(yàn)這個(gè)cookie的有效性。如果cookie效驗(yàn)不成功或者cookie根本不存在,就會直接轉(zhuǎn)到登錄界面讓用戶登錄;如果cookie效驗(yàn)成功,就不會做任何阻攔,讓此請求進(jìn)行下去。在配置文件中,有下面的一個(gè)節(jié)點(diǎn)表示了此filter的URL映射關(guān)系:只攔截所有的jsp請求。

SSOFilter
*.jsp


下面還有幾個(gè)主要的函數(shù)需要說明:
private String SSOService(String cookievalue) throws IOException {
String authAction = "?action=authcookie&cookiename=";
HttpClient httpclient = new HttpClient();
GetMethod httpget = new GetMethod(SSOServiceURL+authAction+cookievalue);
try {
httpclient.executeMethod(httpget);
String result = httpget.getResponseBodyAsString();
return result;
} finally {
httpget.releaseConnection();
}
}

private void logoutService(String cookievalue) throws IOException {
String authAction = "?action=logout&cookiename=";
HttpClient httpclient = new HttpClient();
GetMethod httpget = new GetMethod(SSOServiceURL+authAction+cookievalue);
try {
httpclient.executeMethod(httpget);
httpget.getResponseBodyAsString();
} finally {
httpget.releaseConnection();
}
}

這兩個(gè)函數(shù)主要是利用apache中的httpclient訪問SSOAuth提供的認(rèn)證服務(wù)來完成效驗(yàn)cookie和logout的功能。
其他的函數(shù)都很簡單,有很多都是我的IDE(NetBeans)替我自動(dòng)生成的。
4 當(dāng)前方案的安全局限性
當(dāng)前這個(gè)WEB-SSO的方案是一個(gè)比較簡單的雛形,主要是用來演示SSO的概念和說明SSO技術(shù)的實(shí)現(xiàn)方式。有很多方面還需要完善,其中安全性是非常重要的一個(gè)方面。
我們說過,采用SSO技術(shù)的主要目的之一就是加強(qiáng)安全性,降低安全風(fēng)險(xiǎn)。因?yàn)椴捎昧薙SO,在網(wǎng)絡(luò)上傳遞密碼的次數(shù)減少,風(fēng)險(xiǎn)降低是顯然的,但是當(dāng)前的方案卻有其他的安全風(fēng)險(xiǎn)。由于cookie是一個(gè)用戶登錄的唯一憑據(jù),對cookie的保護(hù)措施是系統(tǒng)安全的重要環(huán)節(jié):
cookie的長度和復(fù)雜度
在本方案中,cookie是有一個(gè)固定的字符串(我的姓名)加上當(dāng)前的時(shí)間戳。這樣的cookie很容易被偽造和猜測。懷有惡意的用戶如果猜測到合法的cookie就可以被當(dāng)作已經(jīng)登錄的用戶,任意訪問權(quán)限范圍內(nèi)的資源
cookie的效驗(yàn)和保護(hù)
在本方案中,雖然密碼只要傳輸一次就夠了,可cookie在網(wǎng)絡(luò)中是經(jīng)常傳來傳去。一些網(wǎng)絡(luò)探測工具(如sniff, snoop,tcpdump等)可以很容易捕獲到cookie的數(shù)值。在本方案中,并沒有考慮cookie在傳輸時(shí)候的保護(hù)。另外對cookie的效驗(yàn)也過于簡單,并不去檢查發(fā)送cookie的來源究竟是不是cookie最初的擁有者,也就是說無法區(qū)分正常的用戶和仿造cookie的用戶。
當(dāng)其中一個(gè)應(yīng)用的安全性不好,其他所有的應(yīng)用都會受到安全威脅
因?yàn)橛蠸SO,所以當(dāng)某個(gè)處于 SSO的應(yīng)用被黒客攻破,那么很容易攻破其他處于同一個(gè)SSO保護(hù)的應(yīng)用。
這些安全漏洞在商業(yè)的SSO解決方案中都會有所考慮,提供相關(guān)的安全措施和保護(hù)手段,例如Sun公司的Access Manager,cookie的復(fù)雜讀和對cookie的保護(hù)都做得非常好。另外在OpneSSO (https://opensso.dev.java.net)的架構(gòu)指南中也給出了部分安全措施的解決方案。
5 當(dāng)前方案的功能和性能局限性
除了安全性,當(dāng)前方案在功能和性能上都需要很多的改進(jìn):
當(dāng)前所提供的登錄認(rèn)證模式只有一種:用戶名和密碼,而且為了簡單,將用戶名和密碼放在內(nèi)存當(dāng)中。事實(shí)上,用戶身份信息的來源應(yīng)該是多種多樣的,可以是來自數(shù)據(jù)庫中,LDAP中,甚至于來自操作系統(tǒng)自身的用戶列表。還有很多其他的認(rèn)證模式都是商務(wù)應(yīng)用不可缺少的,因此SSO的解決方案應(yīng)該包括各種認(rèn)證的模式,包括數(shù)字證書,Radius, SafeWord ,MemberShip,SecurID等多種方式。最為靈活的方式應(yīng)該允許可插入的JAAS框架來擴(kuò)展身份認(rèn)證的接口
我們編寫的Filter只能用于J2EE的應(yīng)用,而對于大量非Java的Web應(yīng)用,卻無法提供SSO服務(wù)。
在將Filter應(yīng)用到Web應(yīng)用的時(shí)候,需要對容器上的每一個(gè)應(yīng)用都要做相應(yīng)的修改,重新部署。而更加流行的做法是Agent機(jī)制:為每一個(gè)應(yīng)用服務(wù)器安裝一個(gè)agent,就可以將SSO功能應(yīng)用到這個(gè)應(yīng)用服務(wù)器中的所有應(yīng)用。
當(dāng)前的方案不能支持分別位于不同domain的Web應(yīng)用進(jìn)行SSO。這是因?yàn)闉g覽器在訪問Web服務(wù)器的時(shí)候,僅僅會帶上和當(dāng)前web服務(wù)器具有相同domain名稱的那些cookie。要提供跨域的SSO的解決方案有很多其他的方法,在這里就不多說了。Sun的Access Manager就具有跨域的SSO的功能。
另外,Filter的性能問題也是需要重視的方面。因?yàn)镕ilter會截獲每一個(gè)符合URL映射規(guī)則的請求,獲得cookie,驗(yàn)證其有效性。這一系列任務(wù)是比較消耗資源的,特別是驗(yàn)證cookie有效性是一個(gè)遠(yuǎn)程的http的調(diào)用,來訪問SSOAuth的認(rèn)證服務(wù),有一定的延時(shí)。因此在性能上需要做進(jìn)一步的提高。例如在本樣例中,如果將URL映射從“.jsp”改成“/*”,也就是說filter對所有的請求都起作用,整個(gè)應(yīng)用會變得非常慢。這是因?yàn)?#xff0c;頁面當(dāng)中包含了各種靜態(tài)元素如gif圖片,css樣式文件,和其他html靜態(tài)頁面,這些頁面的訪問都要通過filter去驗(yàn)證。而事實(shí)上,這些靜態(tài)元素沒有什么安全上的需求,應(yīng)該在filter中進(jìn)行判斷,不去效驗(yàn)這些請求,性能會好很多。另外,如果在filter中加上一定的cache,而不需要每一個(gè)cookie效驗(yàn)請求都去遠(yuǎn)端的身份認(rèn)證服務(wù)中執(zhí)行,性能也能大幅度提高。
另外系統(tǒng)還需要很多其他的服務(wù),如在內(nèi)存中定時(shí)刪除無用的cookie映射等等,都是一個(gè)嚴(yán)肅的解決方案需要考慮的問題。
6 桌面SSO的實(shí)現(xiàn)
從WEB-SSO的概念延伸開,我們可以把SSO的技術(shù)拓展到整個(gè)桌面的應(yīng)用,不僅僅局限在瀏覽器。SSO的概念和原則都沒有改變,只需要再做一點(diǎn)點(diǎn)的工作,就可以完成桌面 SSO 的應(yīng)用。
桌面SSO和WEB-SSO一樣,關(guān)鍵的技術(shù)也在于如何在用戶登錄過后保存登錄的憑據(jù)。在WEB-SSO中,登錄的憑據(jù)是靠瀏覽器的cookie機(jī)制來完成的;在桌面應(yīng)用中,可以將登錄的憑證保存到任何地方,只要所有SSO的桌面應(yīng)用都共享這個(gè)憑證。
從網(wǎng)站可以下載一個(gè)簡單的桌面SSO的樣例(http://gceclub.sun.com.cn/wangyu/desktop-sso/desktopsso.zip)和全部源碼(http://gceclub.sun.com.cn/wangyu/desktop-sso/desktopsso_src.zip),雖然簡單,但是它具有桌面SSO大多數(shù)的功能,稍微加以擴(kuò)充就可以成為自己的解決方案。

6.1桌面樣例的部署
運(yùn)行此桌面SSO需要三個(gè)前提條件:
a) WEB-SSO的身份認(rèn)證應(yīng)用應(yīng)該正在運(yùn)行,因?yàn)槲覀冊谧烂鍿SO當(dāng)中需要用到統(tǒng)一的認(rèn)證服務(wù)
b) 當(dāng)前桌面需要運(yùn)行Mozilla或Netscape瀏覽器,因?yàn)槲覀儗icket保存到mozilla的cookie文件中
c) 必須在JDK1.4以上運(yùn)行。(WEB-SSO需要JDK1.5以上)
解開desktopsso.zip文件,里面有兩個(gè)目錄bin和lib。
bin目錄下有一些腳本文件和配置文件,其中config.properties包含了三個(gè)需要配置的參數(shù):
a) SSOServiceURL要指向WebSSO部署的身份認(rèn)證的URL
b) SSOLoginPage要指向WebSSO部署的身份認(rèn)證的登錄頁面URL
c) cookiefilepath要指向當(dāng)前用戶的mozilla所存放cookie的文件
在bin目錄下還有一個(gè)login.conf是用來配置JAAS登錄模塊,本樣例提供了兩個(gè),讀者可以任意選擇其中一個(gè)(也可以都選),再重新運(yùn)行程序,查看登錄認(rèn)證的變化
在bin下的運(yùn)行腳本可能需要作相應(yīng)的修改
a) 如果是在unix下,各個(gè)jar文件需要用“:”來隔開,而不是“;”
b) java 運(yùn)行程序需要放置在當(dāng)前運(yùn)行的路徑下,否則需要加上java的路徑全名。

6.2桌面樣例的運(yùn)行
樣例程序包含三個(gè)簡單的Java控制臺程序,這三個(gè)程序單獨(dú)運(yùn)行都需要登錄。如果運(yùn)行第一個(gè)命叫“GameSystem”的程序,提示需要輸入用戶名和密碼:
效驗(yàn)成功以后,便會顯示當(dāng)前登錄的用戶的基本信息等等。

這時(shí)候再運(yùn)行第二個(gè)桌面Java應(yīng)用(mailSystem)的時(shí)候,就不需要再登錄了,直接就顯示出來剛才登錄的用戶。
第三個(gè)應(yīng)用是logout,運(yùn)行它之后,用戶便退出系統(tǒng)。再訪問的時(shí)候,又需要重新登錄了。請讀者再制裁執(zhí)行完logout之后,重新驗(yàn)證一下前兩個(gè)應(yīng)用的SSO:先運(yùn)行第二個(gè)應(yīng)用,再運(yùn)行第一個(gè),會看到相同的效果。
我們的樣例并沒有在這里停步,事實(shí)上,本樣例不僅能夠和在幾個(gè)Java應(yīng)用之間SSO,還能和瀏覽器進(jìn)行SSO,也就是將瀏覽器也當(dāng)成是桌面的一部分。這對一些行業(yè)有著不小的吸引力。
這時(shí)候再打開Mozilla瀏覽器,訪問以前提到的那兩個(gè)WEB應(yīng)用,會發(fā)現(xiàn)只要桌面應(yīng)用如果登錄過,Web應(yīng)用就不用再登錄了,而且能顯示剛才登錄的用戶的信息。讀者可以在幾個(gè)桌面和Web應(yīng)用之間進(jìn)行登錄和logout的試驗(yàn),看看它們之間的SSO。
6.3桌面樣例的源碼分析
桌面SSO的樣例使用了JAAS(要了解JAAS的詳細(xì)的信息請參考http://java.sun.com/products/jaas)。JAAS是對PAM(Pluggable Authentication Module)的Java實(shí)現(xiàn),來完成 Java應(yīng)用可插拔的安全認(rèn)證模塊。使用JAAS作為Java應(yīng)用的安全認(rèn)證模塊有很多好處,最主要的是不需要修改源代碼就可以更換認(rèn)證方式。例如原有的Java應(yīng)用如果使用JAAS的認(rèn)證,如果需要應(yīng)用SSO,只需要修改JAAS的配置文件就行了?,F(xiàn)在在流行的J2EE和其他 Java的產(chǎn)品中,用戶的身份認(rèn)證都是通過JAAS來完成的。在樣例中,我們就展示了這個(gè)功能。請看配置文件login.conf
DesktopSSO {
desktopsso.share.PasswordLoginModule required;
desktopsso.share.DesktopSSOLoginModule required;
};

當(dāng)我們注解掉第二個(gè)模塊的時(shí)候,只有第一個(gè)模塊起作用。在這個(gè)模塊的作用下,只有test用戶(密碼是12345)才能登錄。當(dāng)我們注解掉第一個(gè)模塊的時(shí)候,只有第二個(gè)模塊起作用,桌面SSO才會起作用。

所有的Java桌面樣例程序都是標(biāo)準(zhǔn)JAAS應(yīng)用,熟悉JAAS的程序員會很快了解。JAAS中主要的是登錄模塊(LoginModule)。下面是SSO登錄模塊的源碼:
public class DesktopSSOLoginModule implements LoginModule {
..........
private String SSOServiceURL = "";
private String SSOLoginPage = "";
private static String cookiefilepath = "";
.........


在config.properties的文件中,我們配置了它們的值:
SSOServiceURL=http://wangyu.prc.sun.com:8080/SSOAuth/SSOAuth
SSOLoginPage=http://wangyu.prc.sun.com:8080/SSOAuth/login.jsp
cookiefilepath=C:\\Documents and Settings\\yw137672\\Application Data\\Mozilla\\Profiles\\default\\hog6z1ji.slt\\cookies.txt

SSOServiceURL和SSOLoginPage成員變量指向了在Web-SSO中用過的身份認(rèn)證模塊:SSOAuth,這就說明在桌面系統(tǒng)中我們試圖和Web應(yīng)用共用一個(gè)認(rèn)證服務(wù)。而cookiefilepath成員變量則泄露了一個(gè)“天機(jī)”:我們使用了Mozilla瀏覽器的cookie文件來保存登錄的憑證。換句話說,和Mozilla共用了一個(gè)保存登錄憑證的機(jī)制。之所以用Mozilla是應(yīng)為它的Cookie文件格式簡單,很容易編程訪問和修改任意的Cookie值。(我試圖解析Internet Explorer的cookie文件但沒有成功。)
下面是登錄模塊DesktopSSOLoginModule的主體:login()方法。邏輯也是非常簡單:先用Cookie來登陸,如果成功,則直接就進(jìn)入系統(tǒng),否則需要用戶輸入用戶名和密碼來登錄系統(tǒng)。
public boolean login() throws LoginException{
try {
if (Cookielogin()) return true;
} catch (IOException ex) {
ex.printStackTrace();
}
if (passwordlogin()) return true;
throw new FailedLoginException();
}


下面是Cookielogin()方法的實(shí)體,它的邏輯是:先從Cookie文件中獲得相應(yīng)的Cookie值,通過身份效驗(yàn)服務(wù)效驗(yàn)Cookie的有效性。如果cookie有效就算登錄成功;如果不成功或Cookie不存在,用cookie登錄就算失敗。
public boolean Cookielogin() throws LoginException,IOException {
String cookieValue="";
int cookieIndex =foundCookie();
if (cookieIndex<0)
return false;
else
cookieValue = getCookieValue(cookieIndex);
username = cookieAuth(cookieValue);
if (! username.equals("failed")) {
loginSuccess = true;
return true;
}
return false;
}


用用戶名和密碼登錄的方法要復(fù)雜一些,通過Callback的機(jī)制和屏幕輸入輸出進(jìn)行信息交互,完成用戶登錄信息的獲取;獲取信息以后通過userAuth方法來調(diào)用遠(yuǎn)端SSOAuth的服務(wù)來判定當(dāng)前登錄的有效性。
public boolean passwordlogin() throws LoginException {
//
// Since we need input from a user, we need a callback handler
if (callbackHandler == null) {
throw new LoginException("No CallbackHandler defined");
}
Callback[] callbacks = new Callback[2];
callbacks[0] = new NameCallback("Username");
callbacks[1] = new PasswordCallback("Password", false);
//
// Call the callback handler to get the username and password
try {
callbackHandler.handle(callbacks);
username = ((NameCallback)callbacks[0]).getName();
char[] temp = ((PasswordCallback)callbacks[1]).getPassword();
password = new char[temp.length];
System.arraycopy(temp, 0, password, 0, temp.length);
((PasswordCallback)callbacks[1]).clearPassword();
} catch (IOException ioe) {
throw new LoginException(ioe.toString());
} catch (UnsupportedCallbackException uce) {
throw new LoginException(uce.toString());
}

System.out.println();
String authresult ="";
try {
authresult = userAuth(username, password);
} catch (IOException ex) {
ex.printStackTrace();
}
if (! authresult.equals("failed")) {
loginSuccess= true;
clearPassword();
try {
updateCookie(authresult);
} catch (IOException ex) {
ex.printStackTrace();
}
return true;
}


loginSuccess = false;
username = null;
clearPassword();
System.out.println( "Login: PasswordLoginModule FAIL" );
throw new FailedLoginException();
}


CookieAuth和userAuth方法都是利用apahce的httpclient工具包和遠(yuǎn)程的SSOAuth進(jìn)行http連接,獲取服務(wù)。
private String cookieAuth(String cookievalue) throws IOException{
String result = "failed";

HttpClient httpclient = new HttpClient();
GetMethod httpget = new GetMethod(SSOServiceURL+Action1+cookievalue);

try {
httpclient.executeMethod(httpget);
result = httpget.getResponseBodyAsString();
} finally {
httpget.releaseConnection();
}
return result;
}

private String userAuth(String username, char[] password) throws IOException{
String result = "failed";
String passwd= new String(password);
HttpClient httpclient = new HttpClient();
GetMethod httpget = new GetMethod(SSOServiceURL+Action2+username+"&password="+passwd);
passwd = null;

try {
httpclient.executeMethod(httpget);
result = httpget.getResponseBodyAsString();
} finally {
httpget.releaseConnection();
}
return result;

}


還有一個(gè)地方需要補(bǔ)充說明的是,在本樣例中,用戶名和密碼的輸入都會在屏幕上顯示明文。如果希望用掩碼形式來顯示密碼,以提高安全性,請參考:http://java.sun.com/developer/technicalArticles/Security/pwordmask/
7 真正安全的全方位SSO解決方案:Kerberos
我們的樣例程序(桌面SSO和WEB-SSO)都有一個(gè)共性:要想將一個(gè)應(yīng)用集成到我們的SSO解決方案中,或多或少的需要修改應(yīng)用程序。Web應(yīng)用需要配置一個(gè)我們預(yù)制的filter;桌面應(yīng)用需要加上我們桌面SSO的JAAS模塊(至少要修改JAAS的配置文件)。可是有很多程序是沒有源代碼和無法修改的,例如常用的遠(yuǎn)程通訊程序telnet和ftp等等一些操作系統(tǒng)自己帶的常用的應(yīng)用程序。這些程序是很難修改加入到我們的SSO的解決方案中。
事實(shí)上有一種全方位的SSO解決方案能夠解決這些問題,這就是Kerberos協(xié)議(RFC 1510)。Kerberos是網(wǎng)絡(luò)安全應(yīng)用標(biāo)準(zhǔn)(http://web.mit.edu/kerberos/),由MIT學(xué)校發(fā)明,被主流的操作系統(tǒng)所采用。在采用kerberos的平臺中,登錄和認(rèn)證是由操作系統(tǒng)本身來維護(hù),認(rèn)證的憑證也由操作系統(tǒng)來保存,這樣整個(gè)桌面都可以處于同一個(gè)SSO的系統(tǒng)保護(hù)中。操作系統(tǒng)中的各個(gè)應(yīng)用(如ftp,telnet)只需要通過配置就能加入到SSO中。另外使用Kerberos最大的好處在于它的安全性。通過密鑰算法的保證和密鑰中心的建立,可以做到用戶的密碼根本不需要在網(wǎng)絡(luò)中傳輸,而傳輸?shù)男畔⒁矔值陌踩?
目前支持Kerberos的操作系統(tǒng)包括Solaris, windows,Linux等等主流的平臺。只不過要搭建一個(gè)Kerberos的環(huán)境比較復(fù)雜,KDC(密鑰分發(fā)中心)的建立也需要相當(dāng)?shù)牟襟E。Kerberos擁有非常成熟的API,包括Java的API。使用Java Generic Security Services(GSS) API并且使用JAAS中對Kerberos的支持(詳細(xì)信息請參見Sun的Java&Kerberos教程http://java.sun.com/ j2se/1.5.0/docs/guide/security/jgss/tutorials/index.html),要將我們這個(gè)樣例改造成對Kerberos的支持也是不難的。 值得一提的是在JDK6.0 (http://www.java.net/download/jdk6)當(dāng)中直接就包含了對GSS的支持,不需要單獨(dú)下載GSS的包。

8 總結(jié)
本文的主要目的是闡述SSO的基本原理,并提供了一種實(shí)現(xiàn)的方式。通過對源代碼的分析來掌握開發(fā)SSO服務(wù)的技術(shù)要點(diǎn)和充分理解SSO的應(yīng)用范圍。但是,本文僅僅說明了身份認(rèn)證的服務(wù),而另外一個(gè)和身份認(rèn)證密不可分的服務(wù)----權(quán)限效驗(yàn),卻沒有提到。要開發(fā)出真正的SSO的產(chǎn)品,在功能上、性能上和安全上都必須有更加完備的考慮。
作者簡介
王昱是Sun中國工程研究院的Java工程師,現(xiàn)在的主要負(fù)責(zé)全球合作伙伴的技術(shù)支持。作為一名Java資深工程師和架構(gòu)師,王昱在Java 的很多領(lǐng)域都有多年的造詣,特別是在Java虛擬機(jī)、J2EE技術(shù)(包括EJB, JSP/Servlet, JMS和Web services等技術(shù))、集群技術(shù)和Java應(yīng)用性能調(diào)優(yōu)上有著較為豐富的經(jīng)驗(yàn)。曾經(jīng)多次在重要的Java會議發(fā)表演講,并在國際著名的Java技術(shù)站 點(diǎn)發(fā)表文章。

資源鏈接
OpenSSO 的網(wǎng)站: https://opensso.dev.java.net
在java應(yīng)用中使用掩碼的密碼提示:http://java.sun.com/developer/technicalArticles/Security/pwordmask/
Kerberos的資源網(wǎng)站:http://web.mit.edu/kerberos/
Sun的Java&Kerberos教程:http://java.sun.com/j2se/1.5.0/docs/guide/security/jgss/tutorials/index.html
Apache社區(qū)提供的HttpClient工具包網(wǎng)址:http://jakarta.apache.org/commons/index.html)
Filter的使用教程文章:http://www.javaworld.com/javaworld/jw-06-2001/jw-0622-filters.html
我的博客http://yuwang881.blog.sohu.com/3184816.html

總結(jié)

以上是生活随笔為你收集整理的转载的SSO文章,很基础的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

国产免费久久久久久无码 | 成年美女黄网站色大免费全看 | 中文字幕乱码人妻二区三区 | 亚洲自偷自拍另类第1页 | 日日碰狠狠丁香久燥 | 国产情侣作爱视频免费观看 | 人人妻人人澡人人爽欧美一区 | 天天摸天天碰天天添 | 色狠狠av一区二区三区 | 大色综合色综合网站 | 女人和拘做爰正片视频 | 国产麻豆精品一区二区三区v视界 | 成人免费视频视频在线观看 免费 | 六月丁香婷婷色狠狠久久 | 蜜桃视频插满18在线观看 | 精品无码一区二区三区爱欲 | 精品久久久中文字幕人妻 | aⅴ亚洲 日韩 色 图网站 播放 | 丰满诱人的人妻3 | 精品久久综合1区2区3区激情 | 成人av无码一区二区三区 | 伊人久久大香线蕉午夜 | 亚洲欧美综合区丁香五月小说 | 欧美精品无码一区二区三区 | 色婷婷香蕉在线一区二区 | 国产办公室秘书无码精品99 | 国产精品国产三级国产专播 | 日日天干夜夜狠狠爱 | 久久久久久国产精品无码下载 | 久在线观看福利视频 | 亚洲无人区午夜福利码高清完整版 | 国产两女互慰高潮视频在线观看 | 国产无遮挡又黄又爽免费视频 | 色婷婷欧美在线播放内射 | 日本乱偷人妻中文字幕 | 男人的天堂2018无码 | 97人妻精品一区二区三区 | 色老头在线一区二区三区 | 免费无码午夜福利片69 | 欧美国产日产一区二区 | 99久久婷婷国产综合精品青草免费 | 内射白嫩少妇超碰 | 国产网红无码精品视频 | 国产无遮挡又黄又爽免费视频 | 99re在线播放 | 99久久精品午夜一区二区 | 久久zyz资源站无码中文动漫 | 成 人 网 站国产免费观看 | 久久亚洲中文字幕精品一区 | 熟女俱乐部五十路六十路av | 亚洲人成人无码网www国产 | 国产99久久精品一区二区 | 久久国产精品精品国产色婷婷 | 呦交小u女精品视频 | 国产亚洲欧美在线专区 | 乱码av麻豆丝袜熟女系列 | 日韩av无码一区二区三区不卡 | 大色综合色综合网站 | 久久成人a毛片免费观看网站 | 日韩欧美成人免费观看 | 中文字幕乱码中文乱码51精品 | 大色综合色综合网站 | 2020久久超碰国产精品最新 | 亚洲一区av无码专区在线观看 | 无码av中文字幕免费放 | 日韩精品无码一区二区中文字幕 | 久久精品国产亚洲精品 | 人妻少妇精品无码专区二区 | 黑人玩弄人妻中文在线 | 久久亚洲国产成人精品性色 | 无码国产色欲xxxxx视频 | 久久精品人人做人人综合试看 | 免费网站看v片在线18禁无码 | 天天躁夜夜躁狠狠是什么心态 | 国产精品久久久久久亚洲毛片 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 亚洲欧美国产精品久久 | 九月婷婷人人澡人人添人人爽 | 国产美女极度色诱视频www | 蜜桃无码一区二区三区 | 天天综合网天天综合色 | 国产真实乱对白精彩久久 | a在线亚洲男人的天堂 | 国产人妻人伦精品 | 国产精品毛多多水多 | 国产农村妇女高潮大叫 | 日欧一片内射va在线影院 | 国产乱子伦视频在线播放 | 图片小说视频一区二区 | 无码国内精品人妻少妇 | 女人被男人爽到呻吟的视频 | 国产亚洲视频中文字幕97精品 | 亚洲一区二区三区四区 | 精品久久久久久亚洲精品 | 国产亚洲美女精品久久久2020 | 久久成人a毛片免费观看网站 | 成人三级无码视频在线观看 | 人妻少妇精品无码专区二区 | 午夜成人1000部免费视频 | 老熟妇仑乱视频一区二区 | 亚洲国产成人a精品不卡在线 | 日日碰狠狠丁香久燥 | 四虎永久在线精品免费网址 | 亚洲中文字幕乱码av波多ji | 一本久道高清无码视频 | 中文亚洲成a人片在线观看 | 日韩欧美群交p片內射中文 | 未满小14洗澡无码视频网站 | 国产97色在线 | 免 | 无码任你躁久久久久久久 | 天堂а√在线地址中文在线 | www一区二区www免费 | 国产精品永久免费视频 | 狂野欧美激情性xxxx | 综合网日日天干夜夜久久 | 亚洲色在线无码国产精品不卡 | 一本一道久久综合久久 | 国产又爽又黄又刺激的视频 | 亚洲gv猛男gv无码男同 | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 国产精品无码一区二区三区不卡 | 一二三四在线观看免费视频 | 日本免费一区二区三区最新 | 欧美日韩视频无码一区二区三 | 又黄又爽又色的视频 | 亚洲 另类 在线 欧美 制服 | 国产精品亚洲一区二区三区喷水 | 一个人免费观看的www视频 | 午夜福利电影 | 午夜精品久久久久久久久 | 精品久久久久久人妻无码中文字幕 | 欧美日本免费一区二区三区 | 久久婷婷五月综合色国产香蕉 | 扒开双腿疯狂进出爽爽爽视频 | 国产特级毛片aaaaaa高潮流水 | 小sao货水好多真紧h无码视频 | 亚洲日韩乱码中文无码蜜桃臀网站 | 女人被爽到呻吟gif动态图视看 | 中文字幕无码视频专区 | 国产精品嫩草久久久久 | 丰满人妻翻云覆雨呻吟视频 | 国产亚洲欧美在线专区 | 高清不卡一区二区三区 | 丰满人妻被黑人猛烈进入 | 亚洲乱亚洲乱妇50p | 日本va欧美va欧美va精品 | 永久免费观看美女裸体的网站 | 丰满人妻一区二区三区免费视频 | 日本护士毛茸茸高潮 | 对白脏话肉麻粗话av | 国产无av码在线观看 | 久久视频在线观看精品 | 亚洲一区二区三区四区 | 中文无码精品a∨在线观看不卡 | 999久久久国产精品消防器材 | 四虎影视成人永久免费观看视频 | 欧洲vodafone精品性 | 青青青爽视频在线观看 | 午夜福利一区二区三区在线观看 | 在线播放免费人成毛片乱码 | 精品久久8x国产免费观看 | 女人被男人躁得好爽免费视频 | 免费国产黄网站在线观看 | 国内精品人妻无码久久久影院 | 日韩视频 中文字幕 视频一区 | 一区二区三区乱码在线 | 欧洲 | 国产成人无码一二三区视频 | 麻豆精品国产精华精华液好用吗 | 免费无码午夜福利片69 | 中文毛片无遮挡高清免费 | 国产精品久久福利网站 | 一本久久伊人热热精品中文字幕 | av无码久久久久不卡免费网站 | 夜先锋av资源网站 | 亚洲小说图区综合在线 | 成人片黄网站色大片免费观看 | 无码精品国产va在线观看dvd | 午夜男女很黄的视频 | 国产精品无码成人午夜电影 | 亚洲の无码国产の无码步美 | 色偷偷人人澡人人爽人人模 | 强辱丰满人妻hd中文字幕 | 人妻人人添人妻人人爱 | 亚洲熟妇色xxxxx欧美老妇 | 麻豆精品国产精华精华液好用吗 | 免费无码的av片在线观看 | 国产精品人人爽人人做我的可爱 | 性生交大片免费看女人按摩摩 | 一本久道高清无码视频 | 国产精品亚洲五月天高清 | 国产特级毛片aaaaaa高潮流水 | 日日碰狠狠躁久久躁蜜桃 | 欧美变态另类xxxx | 免费人成在线观看网站 | 一本色道久久综合亚洲精品不卡 | 麻豆人妻少妇精品无码专区 | 久久久精品欧美一区二区免费 | 午夜性刺激在线视频免费 | 成人性做爰aaa片免费看 | 亚洲成a人一区二区三区 | 六十路熟妇乱子伦 | 99久久久国产精品无码免费 | 青青久在线视频免费观看 | 国产精品美女久久久久av爽李琼 | 亚洲综合伊人久久大杳蕉 | 黑森林福利视频导航 | 午夜成人1000部免费视频 | 亚洲中文字幕在线观看 | 99久久精品无码一区二区毛片 | 正在播放东北夫妻内射 | 99国产精品白浆在线观看免费 | 日日噜噜噜噜夜夜爽亚洲精品 | 无套内射视频囯产 | 成人影院yy111111在线观看 | 亚洲欧美国产精品久久 | 水蜜桃亚洲一二三四在线 | 女人被爽到呻吟gif动态图视看 | 国产色视频一区二区三区 | 国产真人无遮挡作爱免费视频 | 国产激情一区二区三区 | 国产亚洲欧美日韩亚洲中文色 | 婷婷丁香六月激情综合啪 | 最近的中文字幕在线看视频 | 乱人伦中文视频在线观看 | 无码人妻精品一区二区三区下载 | 欧洲美熟女乱又伦 | 国产婷婷色一区二区三区在线 | 国产精品无码一区二区桃花视频 | 任你躁在线精品免费 | 欧美性生交xxxxx久久久 | 亚洲精品一区二区三区婷婷月 | 精品熟女少妇av免费观看 | 丰满少妇高潮惨叫视频 | 亚洲欧美综合区丁香五月小说 | 激情人妻另类人妻伦 | 亚洲gv猛男gv无码男同 | 欧美阿v高清资源不卡在线播放 | 99在线 | 亚洲 | 日本护士毛茸茸高潮 | 亚洲国产精品久久久久久 | 欧美亚洲国产一区二区三区 | 日本大香伊一区二区三区 | 日本va欧美va欧美va精品 | 俄罗斯老熟妇色xxxx | 老司机亚洲精品影院无码 | 中文字幕精品av一区二区五区 | 中文字幕乱码人妻二区三区 | 色欲久久久天天天综合网精品 | 国产精品无码永久免费888 | 爱做久久久久久 | 国产色在线 | 国产 | 国产精品成人av在线观看 | 亚洲国产日韩a在线播放 | 熟妇人妻无乱码中文字幕 | 中文字幕av伊人av无码av | 亚洲国产欧美日韩精品一区二区三区 | 久久99精品久久久久久 | 性做久久久久久久免费看 | 少女韩国电视剧在线观看完整 | 国语自产偷拍精品视频偷 | 日韩精品无码一本二本三本色 | 亚洲a无码综合a国产av中文 | 97久久精品无码一区二区 | 免费观看又污又黄的网站 | 亚洲精品中文字幕久久久久 | 黑人巨大精品欧美一区二区 | 精品乱码久久久久久久 | 日韩av无码一区二区三区 | 国产午夜福利亚洲第一 | 国内揄拍国内精品人妻 | 成年美女黄网站色大免费视频 | 免费看男女做好爽好硬视频 | 激情内射亚州一区二区三区爱妻 | 捆绑白丝粉色jk震动捧喷白浆 | 97夜夜澡人人双人人人喊 | 亚洲精品久久久久中文第一幕 | 国精品人妻无码一区二区三区蜜柚 | 国产农村乱对白刺激视频 | 国产区女主播在线观看 | 奇米影视888欧美在线观看 | 欧美性猛交内射兽交老熟妇 | 亚洲国产精品久久人人爱 | 男女猛烈xx00免费视频试看 | 男女超爽视频免费播放 | 少妇性l交大片 | 99久久亚洲精品无码毛片 | 色妞www精品免费视频 | 亚洲精品国产精品乱码不卡 | 国产精品美女久久久网av | 人人爽人人澡人人人妻 | 55夜色66夜色国产精品视频 | 东京热男人av天堂 | 亚洲人成影院在线无码按摩店 | 无人区乱码一区二区三区 | 亚洲一区二区三区播放 | 性开放的女人aaa片 | 人妻中文无码久热丝袜 | 久久亚洲中文字幕无码 | 99久久久无码国产aaa精品 | 日产国产精品亚洲系列 | 久久久成人毛片无码 | 久久综合香蕉国产蜜臀av | 亚洲成av人片在线观看无码不卡 | 久久精品国产99精品亚洲 | 精品无码一区二区三区爱欲 | 久久久久久久人妻无码中文字幕爆 | 色综合天天综合狠狠爱 | 人人超人人超碰超国产 | √天堂资源地址中文在线 | 欧美精品一区二区精品久久 | 国产真实夫妇视频 | 久久久久久久人妻无码中文字幕爆 | 亚洲国产综合无码一区 | 亚洲成av人影院在线观看 | 丁香啪啪综合成人亚洲 | 51国偷自产一区二区三区 | 人妻有码中文字幕在线 | 国产亚洲日韩欧美另类第八页 | 大地资源中文第3页 | 日本一区二区三区免费高清 | 色情久久久av熟女人妻网站 | 97人妻精品一区二区三区 | 亚洲精品中文字幕乱码 | 成人精品天堂一区二区三区 | 国产成人人人97超碰超爽8 | 最新国产麻豆aⅴ精品无码 | 午夜性刺激在线视频免费 | 亚洲精品综合一区二区三区在线 | 嫩b人妻精品一区二区三区 | 中文无码成人免费视频在线观看 | 天天爽夜夜爽夜夜爽 | 丝袜 中出 制服 人妻 美腿 | 在线观看免费人成视频 | 无码国产色欲xxxxx视频 | 99精品久久毛片a片 | 国产一区二区三区日韩精品 | 色窝窝无码一区二区三区色欲 | 四虎4hu永久免费 | 国产舌乚八伦偷品w中 | 国产精品久久久久久亚洲影视内衣 | 亚洲 日韩 欧美 成人 在线观看 | 扒开双腿疯狂进出爽爽爽视频 | 免费观看又污又黄的网站 | 精品熟女少妇av免费观看 | 午夜精品久久久久久久久 | 76少妇精品导航 | 99精品国产综合久久久久五月天 | 兔费看少妇性l交大片免费 | 国内揄拍国内精品人妻 | 成人三级无码视频在线观看 | 日本饥渴人妻欲求不满 | 久久久久免费看成人影片 | 久久人人爽人人爽人人片ⅴ | 国产97在线 | 亚洲 | 国产偷抇久久精品a片69 | 国产97在线 | 亚洲 | 免费国产黄网站在线观看 | 精品久久综合1区2区3区激情 | 无码纯肉视频在线观看 | 男女下面进入的视频免费午夜 | 国产办公室秘书无码精品99 | 国产精品久久久久久亚洲毛片 | 亚洲国产精品一区二区美利坚 | 初尝人妻少妇中文字幕 | 狂野欧美性猛xxxx乱大交 | 亚洲精品中文字幕久久久久 | 波多野结衣av在线观看 | 日韩视频 中文字幕 视频一区 | 国产成人综合色在线观看网站 | 最近免费中文字幕中文高清百度 | 东京热无码av男人的天堂 | 麻豆果冻传媒2021精品传媒一区下载 | 日本大乳高潮视频在线观看 | 成人免费视频一区二区 | 国产亚洲精品久久久久久国模美 | 大肉大捧一进一出好爽视频 | 性欧美videos高清精品 | 中文字幕中文有码在线 | 在线播放免费人成毛片乱码 | 久久精品国产一区二区三区肥胖 | 人妻少妇精品无码专区动漫 | 成熟妇人a片免费看网站 | 中文精品久久久久人妻不卡 | 女人被男人爽到呻吟的视频 | 中国女人内谢69xxxx | 免费乱码人妻系列无码专区 | 亚洲中文字幕无码中字 | 免费网站看v片在线18禁无码 | 欧美zoozzooz性欧美 | 亚洲国产精品无码一区二区三区 | 东京无码熟妇人妻av在线网址 | 久久久久久九九精品久 | 狂野欧美激情性xxxx | 国产精品无码久久av | 欧美人妻一区二区三区 | 国产精品久久久久久亚洲影视内衣 | 无码av中文字幕免费放 | 任你躁在线精品免费 | 免费国产成人高清在线观看网站 | 亚洲国产成人av在线观看 | 丝袜 中出 制服 人妻 美腿 | 成人性做爰aaa片免费看 | 人妻人人添人妻人人爱 | 激情亚洲一区国产精品 | 国产成人精品三级麻豆 | 亚洲理论电影在线观看 | 精品国产一区二区三区av 性色 | 曰韩少妇内射免费播放 | 国产sm调教视频在线观看 | 狠狠色丁香久久婷婷综合五月 | 成人一区二区免费视频 | 中文字幕av伊人av无码av | 少妇人妻大乳在线视频 | 水蜜桃色314在线观看 | 亚洲欧美色中文字幕在线 | 色偷偷人人澡人人爽人人模 | 亚洲另类伦春色综合小说 | 午夜福利电影 | 亚洲人成网站色7799 | 99国产精品白浆在线观看免费 | 国产免费无码一区二区视频 | 亚洲成色www久久网站 | 无码播放一区二区三区 | 国产一区二区三区日韩精品 | a在线亚洲男人的天堂 | 精品一区二区三区无码免费视频 | 亚洲成av人综合在线观看 | 无码国内精品人妻少妇 | 欧美刺激性大交 | 色综合久久中文娱乐网 | 亚洲欧美精品aaaaaa片 | 国产农村妇女高潮大叫 | 欧美日韩综合一区二区三区 | 国产一区二区不卡老阿姨 | 午夜嘿嘿嘿影院 | 亚洲综合无码久久精品综合 | 亚洲成av人影院在线观看 | 熟女俱乐部五十路六十路av | 无码一区二区三区在线观看 | 国精品人妻无码一区二区三区蜜柚 | 欧美日韩久久久精品a片 | 荫蒂被男人添的好舒服爽免费视频 | 欧美阿v高清资源不卡在线播放 | 97久久超碰中文字幕 | 未满小14洗澡无码视频网站 | 国产亚av手机在线观看 | 国产亚洲欧美日韩亚洲中文色 | 色综合久久久久综合一本到桃花网 | 亚洲综合无码久久精品综合 | 国模大胆一区二区三区 | 色综合久久久无码网中文 | 亚洲中文字幕av在天堂 | 久久www免费人成人片 | 少妇无套内谢久久久久 | 嫩b人妻精品一区二区三区 | 欧美国产日韩久久mv | 国产午夜精品一区二区三区嫩草 | 国产麻豆精品精东影业av网站 | 正在播放东北夫妻内射 | 日日天干夜夜狠狠爱 | 国产精品无套呻吟在线 | 国产精品欧美成人 | 中文无码精品a∨在线观看不卡 | 免费人成在线视频无码 | 乌克兰少妇性做爰 | 久久综合九色综合欧美狠狠 | 亚洲爆乳大丰满无码专区 | 性啪啪chinese东北女人 | 香港三级日本三级妇三级 | 无码乱肉视频免费大全合集 | 国产午夜福利100集发布 | 娇妻被黑人粗大高潮白浆 | 亚洲成av人片在线观看无码不卡 | 国产激情精品一区二区三区 | 亚洲欧洲日本综合aⅴ在线 | www国产亚洲精品久久久日本 | 久久亚洲国产成人精品性色 | 久久99精品久久久久婷婷 | 中文字幕无码人妻少妇免费 | 日本欧美一区二区三区乱码 | 久在线观看福利视频 | 最近的中文字幕在线看视频 | 中文字幕乱码人妻二区三区 | 中国女人内谢69xxxx | 亚洲中文字幕在线无码一区二区 | 国产9 9在线 | 中文 | 亚洲欧美精品aaaaaa片 | 精品国产aⅴ无码一区二区 | yw尤物av无码国产在线观看 | 精品 日韩 国产 欧美 视频 | 欧美阿v高清资源不卡在线播放 | 波多野结衣一区二区三区av免费 | 无码毛片视频一区二区本码 | 亚洲经典千人经典日产 | 欧美日韩视频无码一区二区三 | 正在播放老肥熟妇露脸 | 国产av无码专区亚洲a∨毛片 | 少妇愉情理伦片bd | 亚洲成av人在线观看网址 | 色婷婷综合激情综在线播放 | 久久人人爽人人人人片 | 日韩精品无码一本二本三本色 | 欧美午夜特黄aaaaaa片 | aⅴ亚洲 日韩 色 图网站 播放 | 亚洲爆乳大丰满无码专区 | 国产成人无码一二三区视频 | 亚洲中文字幕无码一久久区 | 丰满妇女强制高潮18xxxx | 久久久久成人片免费观看蜜芽 | 免费无码一区二区三区蜜桃大 | 国产舌乚八伦偷品w中 | 国产无遮挡又黄又爽免费视频 | 男女猛烈xx00免费视频试看 | 人妻夜夜爽天天爽三区 | 性欧美牲交xxxxx视频 | 狠狠色噜噜狠狠狠狠7777米奇 | 国产精品久久久午夜夜伦鲁鲁 | 成人性做爰aaa片免费看不忠 | 麻花豆传媒剧国产免费mv在线 | 国产黄在线观看免费观看不卡 | 成人无码影片精品久久久 | 亚洲熟妇色xxxxx亚洲 | 精品亚洲成av人在线观看 | 国产凸凹视频一区二区 | 综合激情五月综合激情五月激情1 | 亚洲精品一区国产 | 欧美乱妇无乱码大黄a片 | 国产人妻人伦精品1国产丝袜 | 国产农村妇女高潮大叫 | 亚洲国产精品久久人人爱 | 日本熟妇浓毛 | 亚洲精品久久久久avwww潮水 | 天堂久久天堂av色综合 | 激情爆乳一区二区三区 | 色婷婷综合中文久久一本 | 亚洲国精产品一二二线 | 久久国产36精品色熟妇 | 奇米影视7777久久精品人人爽 | 午夜精品久久久久久久久 | 午夜性刺激在线视频免费 | 精品欧美一区二区三区久久久 | 无码人妻精品一区二区三区下载 | 老熟妇乱子伦牲交视频 | 亚洲日韩精品欧美一区二区 | 欧洲精品码一区二区三区免费看 | 国产麻豆精品精东影业av网站 | 一本久久a久久精品vr综合 | 麻豆国产人妻欲求不满谁演的 | 亚洲欧美中文字幕5发布 | 欧美freesex黑人又粗又大 | 久久99精品国产麻豆 | 亚洲 a v无 码免 费 成 人 a v | 丰满少妇弄高潮了www | 波多野42部无码喷潮在线 | 学生妹亚洲一区二区 | 亚洲成av人综合在线观看 | 亚洲国产精品美女久久久久 | 无套内谢的新婚少妇国语播放 | 国产精品高潮呻吟av久久4虎 | 国产精品沙发午睡系列 | 亚洲精品成a人在线观看 | 亚洲高清偷拍一区二区三区 | 亚洲精品久久久久中文第一幕 | 国产成人无码av在线影院 | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 2020最新国产自产精品 | 国产成人综合在线女婷五月99播放 | 精品国产福利一区二区 | 樱花草在线社区www | 成人免费视频视频在线观看 免费 | av人摸人人人澡人人超碰下载 | 无码av免费一区二区三区试看 | 国产无遮挡又黄又爽免费视频 | 高潮毛片无遮挡高清免费视频 | 日本一卡2卡3卡四卡精品网站 | 国产在线一区二区三区四区五区 | 亚洲成熟女人毛毛耸耸多 | 中文字幕av日韩精品一区二区 | 久久99精品久久久久久动态图 | 国产熟女一区二区三区四区五区 | 少妇厨房愉情理9仑片视频 | 在线看片无码永久免费视频 | av香港经典三级级 在线 | 女人被男人躁得好爽免费视频 | 国产suv精品一区二区五 | 国产精品久免费的黄网站 | 国产精品久久久久久亚洲毛片 | 午夜福利试看120秒体验区 | 97久久精品无码一区二区 | 国产内射老熟女aaaa | 国产99久久精品一区二区 | 麻豆国产97在线 | 欧洲 | 国产在热线精品视频 | 最近免费中文字幕中文高清百度 | 99久久精品日本一区二区免费 | 欧美喷潮久久久xxxxx | 国产又粗又硬又大爽黄老大爷视 | 人妻尝试又大又粗久久 | 亚洲爆乳大丰满无码专区 | 精品国产乱码久久久久乱码 | 国产精品亚洲а∨无码播放麻豆 | 98国产精品综合一区二区三区 | 精品国产aⅴ无码一区二区 | 国产综合色产在线精品 | 欧美老熟妇乱xxxxx | 人妻少妇精品无码专区动漫 | 亚洲日韩av一区二区三区中文 | 97夜夜澡人人双人人人喊 | 日日摸天天摸爽爽狠狠97 | 麻豆果冻传媒2021精品传媒一区下载 | 精品人妻人人做人人爽夜夜爽 | 天下第一社区视频www日本 | 久久视频在线观看精品 | 亚洲va中文字幕无码久久不卡 | 无码一区二区三区在线 | 动漫av一区二区在线观看 | 丰满少妇人妻久久久久久 | 麻豆精产国品 | 亚洲熟妇色xxxxx欧美老妇y | 久久国内精品自在自线 | 国产亚洲精品久久久久久久久动漫 | 一本久道高清无码视频 | 久久精品国产一区二区三区肥胖 | 香港三级日本三级妇三级 | 夜精品a片一区二区三区无码白浆 | 久久精品视频在线看15 | 久热国产vs视频在线观看 | 波多野结衣av一区二区全免费观看 | 少妇无码一区二区二三区 | 国产成人精品优优av | 国产成人精品一区二区在线小狼 | 久久精品女人天堂av免费观看 | 国产高潮视频在线观看 | 99久久人妻精品免费一区 | 亚洲天堂2017无码 | 国产亚洲精品久久久久久国模美 | 一本色道久久综合亚洲精品不卡 | 精品日本一区二区三区在线观看 | 亚洲 欧美 激情 小说 另类 | 免费网站看v片在线18禁无码 | 日韩精品无码一区二区中文字幕 | 妺妺窝人体色www在线小说 | 大乳丰满人妻中文字幕日本 | 亚洲日韩av片在线观看 | 亲嘴扒胸摸屁股激烈网站 | 超碰97人人做人人爱少妇 | 久久精品中文闷骚内射 | 亚洲日韩av一区二区三区中文 | 奇米影视7777久久精品人人爽 | 国产成人无码午夜视频在线观看 | 久久精品国产一区二区三区肥胖 | 夫妻免费无码v看片 | 狠狠综合久久久久综合网 | 1000部夫妻午夜免费 | 蜜臀aⅴ国产精品久久久国产老师 | 亚洲精品成a人在线观看 | 亚洲一区av无码专区在线观看 | 在线观看国产一区二区三区 | 国产人妻大战黑人第1集 | 亚洲精品国产精品乱码视色 | 最近免费中文字幕中文高清百度 | 麻花豆传媒剧国产免费mv在线 | 青青久在线视频免费观看 | 国产无遮挡吃胸膜奶免费看 | 18无码粉嫩小泬无套在线观看 | 欧美野外疯狂做受xxxx高潮 | 日韩精品成人一区二区三区 | 久久久久亚洲精品中文字幕 | 亚洲精品午夜国产va久久成人 | √天堂资源地址中文在线 | 丰满护士巨好爽好大乳 | 又紧又大又爽精品一区二区 | 国产偷自视频区视频 | 国产精品久久久久9999小说 | 99久久99久久免费精品蜜桃 | 亚洲欧美日韩国产精品一区二区 | 亚洲国产成人av在线观看 | 久久久久免费精品国产 | 狠狠色丁香久久婷婷综合五月 | 久久久久久久女国产乱让韩 | 欧美肥老太牲交大战 | 日韩成人一区二区三区在线观看 | 双乳奶水饱满少妇呻吟 | 美女黄网站人色视频免费国产 | 国产精品怡红院永久免费 | 国产av无码专区亚洲awww | 18禁黄网站男男禁片免费观看 | 一二三四社区在线中文视频 | 国产莉萝无码av在线播放 | 久久国产精品精品国产色婷婷 | 亚洲欧洲日本无在线码 | 亚洲成av人综合在线观看 | 熟妇人妻无乱码中文字幕 | 久久午夜夜伦鲁鲁片无码免费 | 亚洲国产精品毛片av不卡在线 | 国产激情无码一区二区app | 亚洲日本在线电影 | 精品亚洲韩国一区二区三区 | 黑人大群体交免费视频 | 粗大的内捧猛烈进出视频 | 国产欧美熟妇另类久久久 | 正在播放东北夫妻内射 | 亚洲熟悉妇女xxx妇女av | 久久久久99精品成人片 | 无码一区二区三区在线观看 | 国产精品亚洲一区二区三区喷水 | 精品无码成人片一区二区98 | 狠狠色色综合网站 | 国产偷自视频区视频 | 无遮挡国产高潮视频免费观看 | 图片小说视频一区二区 | 激情内射日本一区二区三区 | 人人妻人人澡人人爽欧美一区九九 | av无码久久久久不卡免费网站 | 国产熟妇另类久久久久 | 国产精品久久久久无码av色戒 | 午夜性刺激在线视频免费 | 狠狠色丁香久久婷婷综合五月 | 国产激情一区二区三区 | 亚洲精品综合五月久久小说 | 欧美精品在线观看 | 色综合久久中文娱乐网 | 日韩视频 中文字幕 视频一区 | 国产精品丝袜黑色高跟鞋 | 狠狠躁日日躁夜夜躁2020 | 蜜臀av无码人妻精品 | 久久综合狠狠综合久久综合88 | 偷窥日本少妇撒尿chinese | 狠狠色噜噜狠狠狠7777奇米 | 中文字幕av无码一区二区三区电影 | 国产午夜视频在线观看 | 亚洲国产精品成人久久蜜臀 | 台湾无码一区二区 | 日韩精品无码一本二本三本色 | 国产精品亚洲专区无码不卡 | 99国产精品白浆在线观看免费 | 亚洲成色在线综合网站 | 精品aⅴ一区二区三区 | 一区二区传媒有限公司 | 日本熟妇人妻xxxxx人hd | 亚洲人成影院在线无码按摩店 | 亚洲一区二区三区播放 | 日日噜噜噜噜夜夜爽亚洲精品 | 无码人妻精品一区二区三区下载 | 精品人人妻人人澡人人爽人人 | 成人一在线视频日韩国产 | 亚洲精品久久久久久一区二区 | 国产后入清纯学生妹 | 亚洲精品久久久久久一区二区 | 亚洲中文字幕av在天堂 | 亚洲熟妇色xxxxx欧美老妇 | 久久国产精品萌白酱免费 | 亚洲一区二区三区播放 | 精品久久久无码中文字幕 | 内射巨臀欧美在线视频 | 曰韩少妇内射免费播放 | 日日天干夜夜狠狠爱 | 亚洲欧美日韩国产精品一区二区 | 天堂亚洲免费视频 | 久久人人97超碰a片精品 | 国产激情综合五月久久 | 在线看片无码永久免费视频 | 内射老妇bbwx0c0ck | 欧美激情内射喷水高潮 | 久久久中文字幕日本无吗 | 丰满肥臀大屁股熟妇激情视频 | 高清不卡一区二区三区 | 国产精品美女久久久久av爽李琼 | 国产猛烈高潮尖叫视频免费 | 欧美人与禽猛交狂配 | 久久精品国产一区二区三区肥胖 | 18禁黄网站男男禁片免费观看 | 18禁黄网站男男禁片免费观看 | 日本护士xxxxhd少妇 | 天干天干啦夜天干天2017 | 正在播放老肥熟妇露脸 | 丰满人妻被黑人猛烈进入 | 亚洲一区二区三区含羞草 | 久久精品国产一区二区三区 | 欧美乱妇无乱码大黄a片 | 一区二区传媒有限公司 | 牲欲强的熟妇农村老妇女 | 日本va欧美va欧美va精品 | 亚拍精品一区二区三区探花 | 国产午夜精品一区二区三区嫩草 | 无码播放一区二区三区 | 欧美人与禽猛交狂配 | 国产熟女一区二区三区四区五区 | 国产综合在线观看 | 综合激情五月综合激情五月激情1 | 欧美成人免费全部网站 | 夜夜高潮次次欢爽av女 | av无码电影一区二区三区 | 无码人妻精品一区二区三区不卡 | 在线视频网站www色 | 成人亚洲精品久久久久 | 性色av无码免费一区二区三区 | 国产网红无码精品视频 | 免费视频欧美无人区码 | 亚洲第一无码av无码专区 | 少妇性l交大片欧洲热妇乱xxx | 国产艳妇av在线观看果冻传媒 | 成人无码视频免费播放 | 日日碰狠狠躁久久躁蜜桃 | 少妇激情av一区二区 | 俺去俺来也在线www色官网 | 我要看www免费看插插视频 | 日日噜噜噜噜夜夜爽亚洲精品 | 丝袜人妻一区二区三区 | 欧美精品一区二区精品久久 | 欧美精品无码一区二区三区 | 18禁止看的免费污网站 | 波多野结衣高清一区二区三区 | 亚洲の无码国产の无码步美 | 欧美成人家庭影院 | 精品久久久久久人妻无码中文字幕 | 免费乱码人妻系列无码专区 | 丁香啪啪综合成人亚洲 | 欧美色就是色 | 亚洲精品一区二区三区四区五区 | 免费播放一区二区三区 | 欧美日韩亚洲国产精品 | 性欧美videos高清精品 | 国产熟妇另类久久久久 | 欧美人妻一区二区三区 | 男女下面进入的视频免费午夜 | 黑人粗大猛烈进出高潮视频 | 国产激情艳情在线看视频 | 日韩人妻无码一区二区三区久久99 | 精品欧美一区二区三区久久久 | 永久免费观看国产裸体美女 | 奇米影视7777久久精品人人爽 | 国产成人无码av片在线观看不卡 | 亚洲中文字幕在线无码一区二区 | 久久无码人妻影院 | 久久 国产 尿 小便 嘘嘘 | 人人爽人人爽人人片av亚洲 | 少妇愉情理伦片bd | 99久久亚洲精品无码毛片 | 国产内射老熟女aaaa | 亚洲日韩av一区二区三区四区 | 激情五月综合色婷婷一区二区 | 无遮挡啪啪摇乳动态图 | 亚洲精品一区三区三区在线观看 | 学生妹亚洲一区二区 | 日韩人妻无码一区二区三区久久99 | 在线观看免费人成视频 | 精品久久综合1区2区3区激情 | 欧美黑人巨大xxxxx | 久久精品人人做人人综合 | 国内揄拍国内精品人妻 | 日韩精品无码免费一区二区三区 | 波多野结衣高清一区二区三区 | 日韩 欧美 动漫 国产 制服 | 亚洲成av人片在线观看无码不卡 | 亚洲熟妇色xxxxx亚洲 | 精品国产青草久久久久福利 | 老熟妇仑乱视频一区二区 | 国产9 9在线 | 中文 | 久久视频在线观看精品 | 波多野结衣高清一区二区三区 | 免费人成网站视频在线观看 | 国产亚洲tv在线观看 | 欧美午夜特黄aaaaaa片 | 巨爆乳无码视频在线观看 | 亚洲日韩一区二区 | 亚洲国产欧美国产综合一区 | 高潮毛片无遮挡高清免费视频 | 激情内射亚州一区二区三区爱妻 | 久久99久久99精品中文字幕 | 九九综合va免费看 | 精品人人妻人人澡人人爽人人 | 国产精品第一区揄拍无码 | 国产精品人妻一区二区三区四 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 丝袜人妻一区二区三区 | 精品国产麻豆免费人成网站 | 欧美黑人性暴力猛交喷水 | 麻豆蜜桃av蜜臀av色欲av | 宝宝好涨水快流出来免费视频 | 日日橹狠狠爱欧美视频 | 亚洲成av人影院在线观看 | 国产色视频一区二区三区 | 日本乱人伦片中文三区 | 亚洲国产av美女网站 | 熟妇激情内射com | 夜夜躁日日躁狠狠久久av | 色欲久久久天天天综合网精品 | аⅴ资源天堂资源库在线 | 丰满少妇高潮惨叫视频 | 欧美阿v高清资源不卡在线播放 | 水蜜桃色314在线观看 | 日本一卡2卡3卡四卡精品网站 | 一个人看的www免费视频在线观看 | 内射巨臀欧美在线视频 | 18精品久久久无码午夜福利 | 午夜精品久久久内射近拍高清 | 夜精品a片一区二区三区无码白浆 | 国产亚洲日韩欧美另类第八页 | 亚洲精品一区国产 | 欧美成人家庭影院 | 荫蒂被男人添的好舒服爽免费视频 | 国产精品毛片一区二区 | 久久综合色之久久综合 | 成人免费视频在线观看 | 国产激情无码一区二区app | 国产熟妇另类久久久久 | 色一情一乱一伦一区二区三欧美 | 日产精品高潮呻吟av久久 | 国产人妻精品午夜福利免费 | 日韩欧美成人免费观看 | 东京无码熟妇人妻av在线网址 | 99精品久久毛片a片 | 夜精品a片一区二区三区无码白浆 | 亚洲精品国偷拍自产在线麻豆 | 国产av久久久久精东av | 国产高清不卡无码视频 | 国产艳妇av在线观看果冻传媒 | 欧美精品免费观看二区 | 55夜色66夜色国产精品视频 | 无码帝国www无码专区色综合 | 99久久久国产精品无码免费 | 久久伊人色av天堂九九小黄鸭 | 国产真人无遮挡作爱免费视频 | 性欧美熟妇videofreesex | 亚洲精品国偷拍自产在线观看蜜桃 | 免费观看的无遮挡av | 夜夜夜高潮夜夜爽夜夜爰爰 | 纯爱无遮挡h肉动漫在线播放 | 久久久久se色偷偷亚洲精品av | 亚洲国产欧美日韩精品一区二区三区 | 无码人妻出轨黑人中文字幕 | 欧美性色19p | 中文字幕人妻无码一夲道 | 99久久精品无码一区二区毛片 | 中文字幕精品av一区二区五区 | 欧美亚洲日韩国产人成在线播放 | 蜜臀av无码人妻精品 | 色狠狠av一区二区三区 | 欧美人妻一区二区三区 | 亚洲人成网站在线播放942 | 成人一区二区免费视频 | 亚洲自偷精品视频自拍 | 色偷偷av老熟女 久久精品人妻少妇一区二区三区 | 男女下面进入的视频免费午夜 | 澳门永久av免费网站 | 蜜臀av无码人妻精品 | 久久精品女人的天堂av | 丰满护士巨好爽好大乳 | 久久精品国产精品国产精品污 | 国产成人无码区免费内射一片色欲 | 久久精品中文字幕大胸 | 中文精品无码中文字幕无码专区 | 精品日本一区二区三区在线观看 | 国产成人精品久久亚洲高清不卡 | 国产一区二区三区日韩精品 | 国内精品久久毛片一区二区 | 亚洲午夜无码久久 | 亚洲国精产品一二二线 | 51国偷自产一区二区三区 | 国产无av码在线观看 | 装睡被陌生人摸出水好爽 | 玩弄人妻少妇500系列视频 | 国精产品一品二品国精品69xx | 无码国内精品人妻少妇 | 国精产品一品二品国精品69xx | 国产va免费精品观看 | 人妻互换免费中文字幕 | 亚洲一区二区观看播放 | 老子影院午夜精品无码 | 国产精品久久精品三级 | 国产激情综合五月久久 | 97夜夜澡人人双人人人喊 | 成人片黄网站色大片免费观看 | 好男人www社区 | 亚洲精品一区国产 | 国产欧美精品一区二区三区 | 成人欧美一区二区三区黑人免费 | 午夜成人1000部免费视频 | 一个人看的视频www在线 | 人人妻人人澡人人爽欧美一区九九 | 国产综合在线观看 | 久久久精品成人免费观看 | 88国产精品欧美一区二区三区 | 综合网日日天干夜夜久久 | 熟妇人妻激情偷爽文 | 成人影院yy111111在线观看 | 亚洲中文字幕在线无码一区二区 | 激情爆乳一区二区三区 | 国产成人精品视频ⅴa片软件竹菊 | 99视频精品全部免费免费观看 | 午夜无码人妻av大片色欲 | 久久这里只有精品视频9 | 夫妻免费无码v看片 | 丰满护士巨好爽好大乳 | 亚洲国产精品无码久久久久高潮 | 成人无码视频免费播放 | 青春草在线视频免费观看 | 国産精品久久久久久久 | 国产亚洲美女精品久久久2020 | 奇米综合四色77777久久 东京无码熟妇人妻av在线网址 | 亚洲熟妇色xxxxx欧美老妇y | 综合人妻久久一区二区精品 | 久久久久亚洲精品中文字幕 | 国产人妻人伦精品1国产丝袜 | 欧美 日韩 亚洲 在线 | 亚洲一区二区三区香蕉 | 精品日本一区二区三区在线观看 | 国产午夜手机精彩视频 | 东京一本一道一二三区 | 99精品无人区乱码1区2区3区 | 在线播放无码字幕亚洲 | 麻豆人妻少妇精品无码专区 | 一本色道久久综合亚洲精品不卡 | 免费无码一区二区三区蜜桃大 | 色诱久久久久综合网ywww | 亚洲色在线无码国产精品不卡 | 亚洲人成人无码网www国产 | 蜜臀aⅴ国产精品久久久国产老师 | 日韩成人一区二区三区在线观看 | 亚洲国精产品一二二线 | 午夜福利电影 | 高潮毛片无遮挡高清免费 | 巨爆乳无码视频在线观看 | 欧美老妇交乱视频在线观看 | 国产熟妇另类久久久久 | 国产精品成人av在线观看 | 天天躁日日躁狠狠躁免费麻豆 | 无码人妻精品一区二区三区不卡 | 国产偷自视频区视频 | 久久精品人人做人人综合 | 无码人妻精品一区二区三区下载 | 亚洲日韩乱码中文无码蜜桃臀网站 | 一区二区三区高清视频一 | 高潮毛片无遮挡高清免费视频 | 亚洲精品无码人妻无码 | 一本色道婷婷久久欧美 | 在线a亚洲视频播放在线观看 | 亚洲欧美国产精品久久 | 亚洲乱码国产乱码精品精 | 未满成年国产在线观看 | 国产深夜福利视频在线 | 精品无人区无码乱码毛片国产 | 2020久久超碰国产精品最新 | 成人精品视频一区二区 | 欧美人与禽猛交狂配 | 国产手机在线αⅴ片无码观看 | 又色又爽又黄的美女裸体网站 | 日韩人妻少妇一区二区三区 | 亚洲欧美精品aaaaaa片 | 久久综合香蕉国产蜜臀av | 亚洲一区二区三区香蕉 | 俺去俺来也www色官网 | 黑人粗大猛烈进出高潮视频 | 欧美一区二区三区视频在线观看 | 国产99久久精品一区二区 | 精品久久久久香蕉网 | 久久久久99精品国产片 | 亚洲色成人中文字幕网站 | 久久99热只有频精品8 | 国産精品久久久久久久 | 日本精品人妻无码免费大全 | 国产无遮挡又黄又爽又色 | 久久这里只有精品视频9 | 久久97精品久久久久久久不卡 | 免费人成网站视频在线观看 | av香港经典三级级 在线 | 亚洲成av人综合在线观看 | 国产午夜手机精彩视频 | 中文字幕av伊人av无码av | 欧美丰满熟妇xxxx性ppx人交 | 久久亚洲精品中文字幕无男同 | 久久久婷婷五月亚洲97号色 | 少妇无码av无码专区在线观看 | 国产卡一卡二卡三 | 国产99久久精品一区二区 | 国产av人人夜夜澡人人爽麻豆 | 国产综合久久久久鬼色 | av无码久久久久不卡免费网站 | 丝袜美腿亚洲一区二区 | yw尤物av无码国产在线观看 | 亚洲欧美国产精品久久 | 成年美女黄网站色大免费全看 | 久9re热视频这里只有精品 | 成人无码视频在线观看网站 | 无码人妻av免费一区二区三区 | 欧美熟妇另类久久久久久多毛 | 麻豆果冻传媒2021精品传媒一区下载 | 精品久久久久久人妻无码中文字幕 | 无码av中文字幕免费放 | 国产乱码精品一品二品 | 窝窝午夜理论片影院 | 国产手机在线αⅴ片无码观看 | 色婷婷av一区二区三区之红樱桃 | 中文字幕日韩精品一区二区三区 | 亚洲午夜久久久影院 | 中文字幕人妻无码一夲道 | 2019nv天堂香蕉在线观看 | 少妇无码av无码专区在线观看 | 国产一区二区不卡老阿姨 | 日本又色又爽又黄的a片18禁 | 日产国产精品亚洲系列 | 国产精华av午夜在线观看 | 无码任你躁久久久久久久 | 自拍偷自拍亚洲精品10p | 国产激情综合五月久久 | 国产熟女一区二区三区四区五区 | 亚洲热妇无码av在线播放 | 色欲久久久天天天综合网精品 | 国产人妖乱国产精品人妖 | 亚洲熟妇自偷自拍另类 | 国产成人无码av片在线观看不卡 | 一本久道久久综合狠狠爱 | 国产97人人超碰caoprom | 国产精品亚洲一区二区三区喷水 | 久久精品国产一区二区三区肥胖 | 人妻中文无码久热丝袜 | 国产人妻人伦精品1国产丝袜 | 国内综合精品午夜久久资源 | 国产精品第一国产精品 | 免费观看的无遮挡av | 免费观看黄网站 | 久久久久成人精品免费播放动漫 | 丝袜足控一区二区三区 | 国产精品18久久久久久麻辣 | 国产精品美女久久久 | 丝袜美腿亚洲一区二区 | 亚洲综合另类小说色区 | 强奷人妻日本中文字幕 | 少妇人妻偷人精品无码视频 | 久久99精品国产麻豆蜜芽 | 日韩精品无码免费一区二区三区 | 狠狠色丁香久久婷婷综合五月 | 成人欧美一区二区三区 | 久久综合狠狠综合久久综合88 | 欧美老妇交乱视频在线观看 | 亚洲日本va午夜在线电影 | 国产av久久久久精东av | 久久久国产一区二区三区 | 男女爱爱好爽视频免费看 | 人妻无码αv中文字幕久久琪琪布 | 小sao货水好多真紧h无码视频 | 国产精品高潮呻吟av久久 | 999久久久国产精品消防器材 | 午夜熟女插插xx免费视频 | 亚洲阿v天堂在线 | 亚洲国产精华液网站w | 成熟人妻av无码专区 | 久久国产精品二国产精品 | 人人妻人人澡人人爽欧美一区 | 亚洲色成人中文字幕网站 | 对白脏话肉麻粗话av | 色欲人妻aaaaaaa无码 | 婷婷六月久久综合丁香 | 鲁鲁鲁爽爽爽在线视频观看 | 国内精品人妻无码久久久影院蜜桃 | 女人和拘做爰正片视频 | 国产猛烈高潮尖叫视频免费 | 中文字幕无码人妻少妇免费 | 欧美freesex黑人又粗又大 | 欧美成人高清在线播放 | 国产超碰人人爽人人做人人添 | 亚洲国产精品久久人人爱 | 日韩 欧美 动漫 国产 制服 | 人人妻人人澡人人爽欧美精品 | 中文亚洲成a人片在线观看 | 国产成人无码区免费内射一片色欲 | 精品少妇爆乳无码av无码专区 | 国内精品人妻无码久久久影院 | 亚洲最大成人网站 | 亚洲成a人一区二区三区 | 伊人久久大香线蕉亚洲 | 鲁鲁鲁爽爽爽在线视频观看 | 无码播放一区二区三区 | 国产精品亚洲一区二区三区喷水 | 精品国产aⅴ无码一区二区 | 蜜桃无码一区二区三区 | 亚洲日韩av一区二区三区中文 | √天堂中文官网8在线 | 国产乱人伦av在线无码 | 欧美阿v高清资源不卡在线播放 | 噜噜噜亚洲色成人网站 | 玩弄人妻少妇500系列视频 | 国产成人综合美国十次 | 免费看男女做好爽好硬视频 | 国产一区二区三区四区五区加勒比 | 免费乱码人妻系列无码专区 | 婷婷丁香五月天综合东京热 | 久久人妻内射无码一区三区 | 荡女精品导航 | 国产成人无码专区 | 亚洲一区二区三区在线观看网站 | 人人爽人人爽人人片av亚洲 | 黑人巨大精品欧美黑寡妇 | 国产明星裸体无码xxxx视频 | 欧美 丝袜 自拍 制服 另类 | 日日摸天天摸爽爽狠狠97 | 国产成人无码午夜视频在线观看 | 国产猛烈高潮尖叫视频免费 | 国产成人一区二区三区在线观看 | 人妻天天爽夜夜爽一区二区 | 日日麻批免费40分钟无码 | 精品日本一区二区三区在线观看 | 国产三级精品三级男人的天堂 | 大乳丰满人妻中文字幕日本 | 亚洲国产成人a精品不卡在线 | 国内揄拍国内精品少妇国语 | 欧美熟妇另类久久久久久不卡 | 97人妻精品一区二区三区 | 国产成人综合美国十次 | 国产无遮挡又黄又爽免费视频 | 熟女少妇人妻中文字幕 | 人妻少妇精品无码专区动漫 | 亚洲欧美日韩成人高清在线一区 | 丰满少妇人妻久久久久久 | 国产在热线精品视频 | 给我免费的视频在线观看 | 成人精品视频一区二区 | 水蜜桃av无码 | 动漫av网站免费观看 | 水蜜桃av无码 | 中文字幕人成乱码熟女app | 中文精品久久久久人妻不卡 | 亚洲日本在线电影 | 中文字幕 亚洲精品 第1页 | 亚洲精品中文字幕久久久久 | 国产69精品久久久久app下载 | 欧美日本免费一区二区三区 | 国产精品第一区揄拍无码 | 天天摸天天透天天添 | 亚洲精品久久久久avwww潮水 | 国产xxx69麻豆国语对白 | 色诱久久久久综合网ywww | 无码人妻少妇伦在线电影 | 无码av免费一区二区三区试看 | 一本久久伊人热热精品中文字幕 | 久久精品无码一区二区三区 | 内射爽无广熟女亚洲 | 精品无人国产偷自产在线 | 老熟妇仑乱视频一区二区 | 日本在线高清不卡免费播放 | 亚洲熟妇色xxxxx欧美老妇 | 丝袜足控一区二区三区 | 夜夜高潮次次欢爽av女 | 九九热爱视频精品 | 曰韩少妇内射免费播放 | 国产精品久久久久久亚洲毛片 | 亚洲精品午夜国产va久久成人 | 成人av无码一区二区三区 | 天天摸天天碰天天添 | 欧美老人巨大xxxx做受 | 人人妻人人澡人人爽欧美一区 | 国产成人无码av在线影院 | 水蜜桃色314在线观看 | 精品国产av色一区二区深夜久久 | 亚洲国产日韩a在线播放 | 精品国偷自产在线视频 | 国内少妇偷人精品视频 | 女人被男人爽到呻吟的视频 | 亚洲熟女一区二区三区 | 又湿又紧又大又爽a视频国产 | 久久精品一区二区三区四区 | 夜精品a片一区二区三区无码白浆 | 最新国产乱人伦偷精品免费网站 | 无码帝国www无码专区色综合 | 中文字幕色婷婷在线视频 | 亚洲爆乳精品无码一区二区三区 | 无码午夜成人1000部免费视频 | 国产麻豆精品一区二区三区v视界 | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 成人性做爰aaa片免费看不忠 | 青青青手机频在线观看 | 国产va免费精品观看 | 澳门永久av免费网站 | 亚洲国产精品一区二区第一页 | 久久精品国产亚洲精品 | 国产人妻大战黑人第1集 | 高潮毛片无遮挡高清免费视频 | 樱花草在线社区www | 婷婷综合久久中文字幕蜜桃三电影 | 中国大陆精品视频xxxx | 色综合视频一区二区三区 | 荡女精品导航 | 国产熟妇另类久久久久 | 色婷婷欧美在线播放内射 | 国产欧美精品一区二区三区 | 久久97精品久久久久久久不卡 | 精品国产aⅴ无码一区二区 | 久久午夜无码鲁丝片午夜精品 | 奇米影视888欧美在线观看 | 噜噜噜亚洲色成人网站 | 在线 国产 欧美 亚洲 天堂 | 精品国产麻豆免费人成网站 | 高潮喷水的毛片 | 亚洲呦女专区 | 亚洲人成无码网www | 日本大乳高潮视频在线观看 | 天天燥日日燥 | 色噜噜亚洲男人的天堂 | 亚洲熟女一区二区三区 | 人妻人人添人妻人人爱 | 国精产品一品二品国精品69xx | 7777奇米四色成人眼影 | 亚洲第一无码av无码专区 | 中文字幕乱码亚洲无线三区 | 亚洲乱亚洲乱妇50p | 色窝窝无码一区二区三区色欲 | 国产明星裸体无码xxxx视频 | 青青青手机频在线观看 | 少妇性荡欲午夜性开放视频剧场 | 欧美成人午夜精品久久久 | 中文字幕乱码人妻二区三区 | а√资源新版在线天堂 | 伊人色综合久久天天小片 | 久久精品国产精品国产精品污 | 色婷婷久久一区二区三区麻豆 | 无码人中文字幕 | 天天做天天爱天天爽综合网 | 麻豆国产人妻欲求不满谁演的 | 性色av无码免费一区二区三区 | 97久久精品无码一区二区 | 亚洲精品国偷拍自产在线观看蜜桃 | 人人妻在人人 | 久青草影院在线观看国产 | 福利一区二区三区视频在线观看 | 一本色道久久综合狠狠躁 | 亚洲欧美日韩成人高清在线一区 | 无码成人精品区在线观看 | 水蜜桃av无码 | 一区二区三区高清视频一 | 精品无码av一区二区三区 | 亚洲爆乳大丰满无码专区 | 人妻少妇精品无码专区二区 | 亚洲熟妇色xxxxx亚洲 | 中文无码成人免费视频在线观看 | 一本久道久久综合婷婷五月 | 亚洲成熟女人毛毛耸耸多 | 精品 日韩 国产 欧美 视频 | 国产热a欧美热a在线视频 | 中文字幕av日韩精品一区二区 | 无码人妻av免费一区二区三区 | 久在线观看福利视频 | 99国产欧美久久久精品 | 亚洲国产高清在线观看视频 | 国产精品.xx视频.xxtv | 亚洲中文字幕久久无码 | 18精品久久久无码午夜福利 | 色婷婷av一区二区三区之红樱桃 | 久久久久se色偷偷亚洲精品av | 性欧美牲交xxxxx视频 | 国产av无码专区亚洲awww | 久久www免费人成人片 | 在线 国产 欧美 亚洲 天堂 | 久久精品中文字幕大胸 | 在线欧美精品一区二区三区 | 天天摸天天透天天添 | 中文字幕 亚洲精品 第1页 | 亚洲欧美综合区丁香五月小说 | 熟女体下毛毛黑森林 | 国产av一区二区三区最新精品 | 亚洲精品国产精品乱码不卡 | 76少妇精品导航 | 欧美 日韩 人妻 高清 中文 | 亚洲熟悉妇女xxx妇女av | 中文字幕乱码人妻无码久久 | 人妻少妇精品无码专区二区 | 天天爽夜夜爽夜夜爽 | 真人与拘做受免费视频 | 久久久久久九九精品久 | 国产无av码在线观看 | 国产尤物精品视频 | 久久www免费人成人片 | 波多野结衣乳巨码无在线观看 | 国产精品久免费的黄网站 | 久久伊人色av天堂九九小黄鸭 | 97无码免费人妻超级碰碰夜夜 | 久久99精品久久久久久动态图 | 中文字幕无码免费久久9一区9 | 亚洲成a人片在线观看日本 | 日本精品高清一区二区 | 亚洲中文字幕无码中字 | 日韩少妇内射免费播放 | 内射爽无广熟女亚洲 | 欧美乱妇无乱码大黄a片 | 国内揄拍国内精品人妻 | 无码人妻精品一区二区三区不卡 | 国产精品久久久久7777 | 欧美变态另类xxxx | 成人影院yy111111在线观看 | 青春草在线视频免费观看 | 国产av一区二区精品久久凹凸 | 国产av无码专区亚洲awww | 中文精品久久久久人妻不卡 | 无码国产激情在线观看 | 亚洲理论电影在线观看 | 欧美精品国产综合久久 | 成人精品视频一区二区三区尤物 | 免费观看又污又黄的网站 | 久激情内射婷内射蜜桃人妖 | 女人被男人躁得好爽免费视频 | 少妇性l交大片 | 欧美三级不卡在线观看 | 久久综合久久自在自线精品自 | 久9re热视频这里只有精品 | 国产日产欧产精品精品app | 黄网在线观看免费网站 | 四虎影视成人永久免费观看视频 | 男女作爱免费网站 | 日日天干夜夜狠狠爱 | 日本大乳高潮视频在线观看 | 高清无码午夜福利视频 | 欧美成人高清在线播放 | 乱人伦人妻中文字幕无码久久网 | 亚洲色在线无码国产精品不卡 | 久久99久久99精品中文字幕 | 午夜免费福利小电影 | 人妻少妇精品无码专区二区 | 久久精品人人做人人综合试看 | 国产精品久久久久9999小说 | 中文字幕久久久久人妻 | 人妻少妇被猛烈进入中文字幕 | 亚洲自偷自偷在线制服 | 国产明星裸体无码xxxx视频 | 西西人体www44rt大胆高清 | 樱花草在线社区www | 国产精品亚洲综合色区韩国 | 成人欧美一区二区三区黑人免费 | 国产熟妇另类久久久久 | 一本久道久久综合狠狠爱 | 国产内射爽爽大片视频社区在线 | 国产又爽又黄又刺激的视频 | 国产亚洲人成在线播放 | 永久免费观看国产裸体美女 | 成人一在线视频日韩国产 | 日韩人妻无码一区二区三区久久99 | 最新国产麻豆aⅴ精品无码 | 色五月丁香五月综合五月 | 精品国产国产综合精品 | 久久久久成人精品免费播放动漫 | 国产人妖乱国产精品人妖 | 麻豆国产人妻欲求不满谁演的 | 扒开双腿吃奶呻吟做受视频 | 成熟人妻av无码专区 | 人妻aⅴ无码一区二区三区 | 麻豆精产国品 | 丰腴饱满的极品熟妇 | 日本一区二区三区免费播放 | 国产精品久久久久无码av色戒 | 欧美日韩色另类综合 | 5858s亚洲色大成网站www | 乱码午夜-极国产极内射 | 3d动漫精品啪啪一区二区中 | 久久天天躁狠狠躁夜夜免费观看 | 人人妻人人澡人人爽精品欧美 | 超碰97人人做人人爱少妇 | 久久精品国产99久久6动漫 | 亚洲中文字幕成人无码 | 国产乡下妇女做爰 | 久久精品国产一区二区三区肥胖 | 亚洲日韩乱码中文无码蜜桃臀网站 | 水蜜桃色314在线观看 | 99久久久国产精品无码免费 | 学生妹亚洲一区二区 | 午夜精品久久久内射近拍高清 | 色婷婷综合中文久久一本 | 伊人久久大香线蕉亚洲 | 精品久久久久久人妻无码中文字幕 | 久久久久久久女国产乱让韩 | 丰满肥臀大屁股熟妇激情视频 | 99er热精品视频 | 亚洲综合无码一区二区三区 | 大乳丰满人妻中文字幕日本 | 大胆欧美熟妇xx | 中国女人内谢69xxxxxa片 | 99久久亚洲精品无码毛片 | 精品厕所偷拍各类美女tp嘘嘘 | 久久人人爽人人人人片 | 成人片黄网站色大片免费观看 | 人妻无码αv中文字幕久久琪琪布 | 人妻尝试又大又粗久久 | 亚洲欧美色中文字幕在线 | 国产精品99久久精品爆乳 | 国产明星裸体无码xxxx视频 | 5858s亚洲色大成网站www | 国产精品理论片在线观看 | 丁香啪啪综合成人亚洲 | 精品日本一区二区三区在线观看 | 一个人看的www免费视频在线观看 | 中文字幕亚洲情99在线 | 男女猛烈xx00免费视频试看 | 精品偷自拍另类在线观看 | 性欧美牲交xxxxx视频 | 99久久人妻精品免费二区 | 中文亚洲成a人片在线观看 | 少妇性俱乐部纵欲狂欢电影 | 亚洲色欲久久久综合网东京热 | 无码av最新清无码专区吞精 | 亚洲日韩精品欧美一区二区 | 亚洲国产精品毛片av不卡在线 | 亚洲精品美女久久久久久久 | 欧美freesex黑人又粗又大 | 亚洲精品国偷拍自产在线观看蜜桃 | 精品人妻av区 | 夜精品a片一区二区三区无码白浆 | 图片区 小说区 区 亚洲五月 | 亚洲综合无码久久精品综合 | 久久99热只有频精品8 | 强辱丰满人妻hd中文字幕 | 丰满少妇熟乱xxxxx视频 | 国产成人精品一区二区在线小狼 | 人人妻在人人 | 蜜桃av抽搐高潮一区二区 | 中文字幕日韩精品一区二区三区 | 天天摸天天碰天天添 | 好爽又高潮了毛片免费下载 | 亚洲欧洲无卡二区视頻 | 日本成熟视频免费视频 | 国产精品久久久久9999小说 | 丰满少妇高潮惨叫视频 | 国产精品永久免费视频 | 永久免费精品精品永久-夜色 | 男人的天堂2018无码 | 麻豆国产人妻欲求不满 | 少妇人妻av毛片在线看 | 九九在线中文字幕无码 | 丁香花在线影院观看在线播放 | 成人av无码一区二区三区 | 国产精品美女久久久 | 窝窝午夜理论片影院 | 精品一区二区三区无码免费视频 | 中文字幕久久久久人妻 | 国产国产精品人在线视 | 人妻天天爽夜夜爽一区二区 | av无码不卡在线观看免费 | 无码吃奶揉捏奶头高潮视频 | 国产精品美女久久久久av爽李琼 | 色婷婷欧美在线播放内射 | 久久久久久久人妻无码中文字幕爆 | 成人毛片一区二区 | 色窝窝无码一区二区三区色欲 | 精品久久久久久人妻无码中文字幕 | 亚洲人成影院在线无码按摩店 | 内射白嫩少妇超碰 | 亚洲国产一区二区三区在线观看 | 久久精品人人做人人综合试看 | 国产av人人夜夜澡人人爽麻豆 | 婷婷五月综合缴情在线视频 | 日本大乳高潮视频在线观看 | 女高中生第一次破苞av | 精品国产乱码久久久久乱码 | 免费国产成人高清在线观看网站 | 伊人久久婷婷五月综合97色 | 无码吃奶揉捏奶头高潮视频 | 日本成熟视频免费视频 | 丰满人妻被黑人猛烈进入 | 77777熟女视频在线观看 а天堂中文在线官网 | 国产午夜亚洲精品不卡下载 | 巨爆乳无码视频在线观看 | 亚洲小说春色综合另类 | www国产精品内射老师 | 亚洲s色大片在线观看 | 沈阳熟女露脸对白视频 | 少妇人妻av毛片在线看 | 久久国内精品自在自线 | 特级做a爰片毛片免费69 | 精品无人国产偷自产在线 | 国产精品亚洲а∨无码播放麻豆 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 在线a亚洲视频播放在线观看 | 欧美性猛交xxxx富婆 | 青草青草久热国产精品 | 麻豆国产97在线 | 欧洲 | 亚洲国产精品一区二区第一页 | 黑人巨大精品欧美黑寡妇 | 久久久久久国产精品无码下载 | 国产香蕉尹人视频在线 | 人人妻人人澡人人爽欧美一区 | 欧美 丝袜 自拍 制服 另类 | 亚洲a无码综合a国产av中文 | 欧美肥老太牲交大战 | 一本色道久久综合狠狠躁 | 国产精品人人妻人人爽 | 亚洲一区二区三区国产精华液 | 无码av中文字幕免费放 | 大色综合色综合网站 | 午夜免费福利小电影 | 欧美放荡的少妇 | 天海翼激烈高潮到腰振不止 | 免费国产成人高清在线观看网站 | 婷婷六月久久综合丁香 | 无码人妻出轨黑人中文字幕 | 国产精品久免费的黄网站 | 网友自拍区视频精品 | 又大又硬又黄的免费视频 | 亚洲国产精品美女久久久久 | 在线а√天堂中文官网 | 人人澡人人透人人爽 | 撕开奶罩揉吮奶头视频 | 国产真实乱对白精彩久久 | √天堂中文官网8在线 | 日本一卡二卡不卡视频查询 | 中文字幕乱码中文乱码51精品 | 色 综合 欧美 亚洲 国产 | 国产办公室秘书无码精品99 | 成人精品视频一区二区 | 伊人久久大香线焦av综合影院 | 亚洲中文字幕在线无码一区二区 | 中文精品久久久久人妻不卡 | 亚欧洲精品在线视频免费观看 | 牲交欧美兽交欧美 | 精品久久久无码中文字幕 | 狠狠色色综合网站 | 日本va欧美va欧美va精品 | 亚洲成a人片在线观看日本 | 国产成人精品无码播放 | 亚洲经典千人经典日产 | 熟女体下毛毛黑森林 | 久久99精品国产麻豆蜜芽 | 97夜夜澡人人爽人人喊中国片 | 人妻互换免费中文字幕 | 性欧美牲交xxxxx视频 | 亚洲狠狠色丁香婷婷综合 | 无码免费一区二区三区 | 亚洲第一无码av无码专区 | 久青草影院在线观看国产 | 亚洲精品鲁一鲁一区二区三区 | 思思久久99热只有频精品66 | 国产精品久久久久影院嫩草 | 中文字幕亚洲情99在线 | 色综合久久网 | 欧美日韩一区二区免费视频 | 麻豆成人精品国产免费 | 精品国产精品久久一区免费式 | 国产精品久久久久久亚洲影视内衣 | 国产激情一区二区三区 | 免费中文字幕日韩欧美 | 国产卡一卡二卡三 | 扒开双腿吃奶呻吟做受视频 | 色综合久久88色综合天天 | 人妻有码中文字幕在线 | 中文字幕无码人妻少妇免费 | 欧美日韩色另类综合 | 奇米影视7777久久精品人人爽 | 中文字幕+乱码+中文字幕一区 | 我要看www免费看插插视频 | 人妻少妇精品无码专区二区 | 国产亚洲欧美日韩亚洲中文色 | 国产在线精品一区二区高清不卡 | 亚洲中文字幕乱码av波多ji | 免费观看又污又黄的网站 | 一本大道久久东京热无码av | 四虎4hu永久免费 | 亚洲男女内射在线播放 | 久久久中文久久久无码 | 欧美日本精品一区二区三区 | 亚洲中文字幕成人无码 | 亚洲国产精品久久人人爱 | 欧美日韩一区二区综合 | 午夜无码人妻av大片色欲 | 亚洲最大成人网站 | 伊人色综合久久天天小片 | 亚洲 高清 成人 动漫 | 国产午夜无码视频在线观看 | 亚洲欧美中文字幕5发布 | 色一情一乱一伦一视频免费看 | 欧美成人免费全部网站 | 国产成人无码av在线影院 | 无码福利日韩神码福利片 | 亚洲成色www久久网站 | 午夜肉伦伦影院 | 丝袜 中出 制服 人妻 美腿 | 131美女爱做视频 | 婷婷五月综合缴情在线视频 | 漂亮人妻洗澡被公强 日日躁 | 人人妻人人澡人人爽欧美一区 | 国产精品美女久久久久av爽李琼 |