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

    基于Java的SOA分層研究與設計*

    2010-08-11 05:27:18徐遇霄
    艦船電子工程 2010年6期
    關鍵詞:應用層調(diào)用部署

    徐遇霄

    (武漢市長虹橋37-1號 武漢 430064)

    1 引言

    霍金曾說:復雜性是21世紀的科學。當代對復雜系統(tǒng)的研究也表明,復雜性是由簡單性進化而來的。那么,我們?nèi)绾螌碗s的難事變?yōu)楹唵蔚囊资?對一般的復雜問題,將其分割為簡單的橫向子問題,就可以達到效果。對于更加復雜的問題,則需要在橫向子問題分割的基礎上,實行縱向分層??v向分層也是一種抽象的分解復雜問題的方法?,F(xiàn)在,一個軟件系統(tǒng),往往是一巨型復雜系統(tǒng)。對于這種復雜系統(tǒng)的分析與實現(xiàn),分層理論認為,降低其復雜性與提高效率的最好辦法是將系統(tǒng)分層實現(xiàn)。從軟件研究和開發(fā)的發(fā)展歷史、現(xiàn)行軟件的體系結構來看,分層方法一直都是軟件研發(fā)普遍適用的基本的思想方法。因此,在軟件體系結構中,把層次性系統(tǒng)作為架構風格,應用的相當廣泛。

    2 SOA的分層研究

    SOA的主要特點之一是平臺中立,平臺中立的Java Web服務技術是構建SOA系統(tǒng)一種很自然的選擇。在Java世界中,J2EE多層架構是一個典型的分層體系,同樣,基于Java的SOA系統(tǒng)也可采用分層模型。SOA有3個角色,其中服務請求者是服務的最終消費者,它對服務進行應用,則位于SOA的頂層-應用層。服務注冊中心負責服務的注冊,以便請求者能發(fā)現(xiàn)服務,在一定程度上履行了服務接口的功能。服務提供者構建實現(xiàn)服務的業(yè)務邏輯,部署服務并提供調(diào)用服務的環(huán)境。業(yè)務邏輯都由業(yè)務組件構成,業(yè)務邏輯層應該是獨立的一層。業(yè)務組件需要部署為服務,并要提供服務的描述以及調(diào)用服務的環(huán)境,請求者才能消費服務,因此,在應用層與業(yè)務層之間,可定義服務接口層,以實現(xiàn)業(yè)務層到應用層的平滑過渡。業(yè)務層一般要訪問數(shù)據(jù)庫,但不是直接訪問,可通過一個中間層來進行。中間層的作用是屏蔽訪問不同數(shù)據(jù)庫的差異,使數(shù)據(jù)庫對業(yè)務層是透明的。因此,數(shù)據(jù)庫位于系統(tǒng)的最底層,而業(yè)務層與數(shù)據(jù)庫之間的中間層可定義為數(shù)據(jù)接口層。至此,基于SOA的應用系統(tǒng)從上到下可劃分為如下5層:應用層、服務接口層、業(yè)務層、數(shù)據(jù)接口層和數(shù)據(jù)庫層,如圖1所示。

    圖1 基于Java的SOA分層架構

    服務接口層為應用層調(diào)用服務提供標準化的接口,從而使得該服務可提供給任何異構平臺和任何本地或者遠程用戶使用。

    業(yè)務層主要提供系統(tǒng)的業(yè)務邏輯和控制,由一些基本的組件構成。

    數(shù)據(jù)接口層為業(yè)務層提供統(tǒng)一的訪問數(shù)據(jù)庫的方式,以屏蔽業(yè)務層訪問不同數(shù)據(jù)庫的差異。

    數(shù)據(jù)庫層完成數(shù)據(jù)的持久化功能。它提供了數(shù)據(jù)信息和數(shù)據(jù)邏輯,所有與數(shù)據(jù)有關的安全性、完整性、數(shù)據(jù)的一致性、并發(fā)操作等都在數(shù)據(jù)庫層。

    數(shù)據(jù)接口層和數(shù)據(jù)庫層統(tǒng)稱為數(shù)據(jù)層。

    3 數(shù)據(jù)層的設計

    1)數(shù)據(jù)實體類的設計

    在數(shù)據(jù)接口層的上一層業(yè)務層中,對數(shù)據(jù)的操作體現(xiàn)在業(yè)務管理類和業(yè)務處理類與業(yè)務數(shù)據(jù)類的交互。業(yè)務數(shù)據(jù)類是數(shù)據(jù)實體類的一部分。為了使業(yè)務層以一致的方式處理數(shù)據(jù),首先,數(shù)據(jù)實體類應該采用一致的數(shù)據(jù)表示方式。在業(yè)務層中,所有的數(shù)據(jù)都由數(shù)據(jù)實體類來統(tǒng)一表示,這些類是基本的JavaBean,被稱為POJO或ValueObject,只有屬性和Get/Set方法,其作用就是供業(yè)務類使用,是業(yè)務類操作的對象。為了增強程序的可讀性并方便記憶,可將類的名稱定義為與表名相同,將類中的屬性名與表的字段名定義相同。這些數(shù)據(jù)類與數(shù)據(jù)庫進行映射,一般將數(shù)據(jù)實體類的屬性映射為數(shù)據(jù)庫中對應表的字段,非原子屬性則映射為表,這種映射關系通常由一個XML映射配置文件來完成。由于基于XML文本的配置文件可以靈活的改變,因此提高了系統(tǒng)的可移植性及易維護性,同時也在數(shù)據(jù)層體現(xiàn)了系統(tǒng)的松耦合性。

    2)持久化技術的選擇

    目前,在基于Java的程序設計中,常用的主要有以下幾種持久化技術:

    (1)BMP(Bean-Managed Persistence),即Bean本身管理持久化。這種方式由在Java組件中嵌入JDBC代碼來實現(xiàn),顯然,這是一種緊耦合的方式。

    (2)CMP(Container-Managed Persistence),即容器管理持久化,表示由EJB容器來管理實體EJB的持久化。EJB容器封裝了對象/關系的映射及數(shù)據(jù)訪問細節(jié)。這是一種框架化的持久性機制,在這類機制中,由框架調(diào)用業(yè)務處理的類。這種機制的一個特點就是它提供一個管理環(huán)境,在這個環(huán)境中進行對象持久化。一旦離開這個環(huán)境,代碼就不能運行了。并且,理解并使用EJB的規(guī)范也不是很輕松的事情。

    (3)JDO(Java Data Objects),Sun公司制定的描述對象持久化語義的標準API。嚴格的說,JDO并不是對象/關系映射接口,因為它支持把對象持久化到任意一種存儲系統(tǒng)中,包括關系數(shù)據(jù)庫、面向?qū)ο蟮臄?shù)據(jù)庫、基于XML的數(shù)據(jù)庫,以及其他專有存儲系統(tǒng)。由于關系數(shù)據(jù)庫是目前最流行的存儲系統(tǒng),許多JDO的實現(xiàn)都包含了對象/關系映射服務。JDO的出現(xiàn)似乎有了一些改觀,但是,JDO沒有一個好的開源免費實現(xiàn)。好的產(chǎn)品一般都是商業(yè)產(chǎn)品,并且在國內(nèi)沒有銷售和技術支持。JDO也不是一個輕量級封裝,它建立的持久層框架很不完善,造成了JDO感覺比較笨重,使得很多操作方式很是煩瑣,JDO的應用在人們心理上一直布滿陰影。

    (4)Hibernate,輕量級的開源ORM模型。它的一大優(yōu)勢就在于可以把被持久化的對象實現(xiàn)成脫離這個持久化環(huán)境依然可以運行的類。Hibenate利用XML文件將應用程序的數(shù)據(jù)實體類與數(shù)據(jù)庫中的表進行映射,并通過框架的內(nèi)部機制對復雜的數(shù)據(jù)操作提供支持,包括記錄的添加、修改和刪除等操作。因此,在基于Java的程序設計中,Hibernate成為持久層流行的框架技術,而它對于構建基于SOA的應用系統(tǒng),也無疑是一個很優(yōu)的選擇。下面簡要介紹Hibernate的原理。

    Hibernate是一種比較徹底的Java對象關系映射工具,支持使用各種Java思想,如Inheritance(繼承),Association(關聯(lián)),Composition(組合),Collections(集合)等來實現(xiàn)對象關系映射。它可以直接映射大部分的POJO型的JavaBean,而不需要對它們作任何修改,即使需要修改,最多只在Bean里面加上一些私有訪問方法。它還可以將一個用戶定義的多個類的實例映射到一張表的同一行,甚至可以利用代理模式來簡化載入類的過程。這些功能都大大減少了利用HQL從數(shù)據(jù)庫提取數(shù)據(jù)的代碼編寫量,從而節(jié)約開發(fā)時間和開發(fā)成本。Hibernate利用Reflection機制,在系統(tǒng)啟動時生成SQL語句,進行對象的持久管理。Hibernate對每一種數(shù)據(jù)庫都有對應的Dialect進行操作優(yōu)化,從而提高它在各種情況下的效率。

    圖2所示 Hibernate的持久化服務在一個數(shù)據(jù)庫應用中的作用:應用程序通過

    圖2 Hibernate持久化原理

    Hibernate 連接到數(shù)據(jù)庫,對數(shù)據(jù)進行操作。Hibernate自身通過Properties或類的映射文件(Mapping XML)將數(shù)據(jù)實體類映射到數(shù)據(jù)庫的行。因此Application可以通過持久化的數(shù)據(jù)類直接訪問數(shù)據(jù)庫,而不必使用JDBC和SQL進行數(shù)據(jù)的操作。

    Hibernate具有很大的靈活性,界于它的最大模式和最小模式之間的某些功能構件是可選的。在最小模式下,可選擇使用JDBC,可以利用JTA管理自己的事務,也可以使用JNDI。這時Hibernate通過 SessionFactory提供 Session,在 Session中對持久化對象進行操作。在最大模式下,Hibernate在自己的底層管理 JNDI、JDBC和 JTA,在上層向外提供 SessionFactory、Session和 Transaction的接口,供 Client控制Persistent Object之用。

    3)數(shù)據(jù)庫訪問的設計

    (1)數(shù)據(jù)實體類與表的映射

    Hibernate定義了類到數(shù)據(jù)庫的基于XML的映射文件。映射文件中的“class”元素定義了需持久化的類與數(shù)據(jù)庫中表的映射關系,“name”屬性指定了類名,而“table”屬性指定了數(shù)據(jù)庫中的表?!癷d”元素定義了鍵屬性?!皃roperty”元素定義了類的屬性與表中字段的映射。具體的映射文件可見后文的實現(xiàn)部分。

    (2)配置 Hibernate

    配置Hibernate通過設置其配置文件來完成。該文件描述了數(shù)據(jù)庫的驅(qū)動程序以及數(shù)據(jù)庫的URL等連接數(shù)據(jù)庫的信息。Hibernate在應用程序啟動時自動進行初始化工作。配置描述文件可以是hibernate.cfg.xml或 Hibernate.properties文件。

    Hibernate對JDBC進行了封裝,自動進行JDBC連接,并使用SessionFactory來打開數(shù)據(jù)庫的連接。使用Hibernate時,我們可以提供外部連接池,亦可配置Hibernate使用它自己直接支持的池(C3PO,Proxcool)。Hibernate可以根據(jù)用戶的數(shù)據(jù)庫設置一個正確的hibernate.dialect語言。它支持 Oracle、Ms SQL、My SQL 、DB2等多種語言 。Hibernate提供的HQL也支持外部連接查詢,這些連接類型是從SQL中借鑒來的:inner join(內(nèi)連接)、left outer join(左外連接)、right outer join(右外連接)、full join(全連接,并不常用)。但外連接也可通過設置Outer-join屬性為False來禁止,因為使用它會占用過多的資源。

    Hibernate可靈活地設置數(shù)據(jù)庫的驅(qū)動程序及數(shù)據(jù)庫的URL。這樣,在進行系統(tǒng)設計時,我們可以不去關心底層采用的是何種數(shù)據(jù)庫。加之我們引入ORM技術,使得業(yè)務邏輯和數(shù)據(jù)邏輯分離。在此二者基礎上,我們就構建了出一個抽象層—數(shù)據(jù)接口層。數(shù)據(jù)接口層的引入一方面增強了系統(tǒng)的靈活性和可移植性,另一方面也體現(xiàn)了SOA的松散耦合性。

    (3)使用Hibernate進行數(shù)據(jù)庫訪問

    Hibernate運用框架模型如圖3所示。

    圖3 Hibernate應用框架模型

    其中:*.hbm.xml是數(shù)據(jù)實體類與表的映射文件,*_Access.class是數(shù)據(jù)訪問類文件,*.class是POJO型的數(shù)據(jù)實體類文件。

    4 業(yè)務層的設計

    1)業(yè)務邏輯的實現(xiàn)策略

    我們可以將業(yè)務層類分為三大類:業(yè)務管理類、業(yè)務處理類和業(yè)務輔助類,如圖4所示。在數(shù)據(jù)接口層提供的數(shù)據(jù)實體對象和對象的持久性存儲機制的基礎之上,就可以將這些對象根據(jù)業(yè)務需求由業(yè)務層的類組合起來,構建系統(tǒng)的業(yè)務邏輯處理程序。

    圖4 業(yè)務層類框架圖

    2)服務粒度的選擇

    我們可以用服務樹來刻畫服務的粒度。所謂服務樹,是把要部署為服務的功能模塊用樹型結構來進行表示,如圖5網(wǎng)上定購服務樹所示。

    圖5 服務樹圖

    服務樹清晰地反映出了服務的粒度,是構建SOA系統(tǒng)時決定服務粒度的有力工具。我們可以利用服務樹找到SOA系統(tǒng)最佳的服務粒度方式。

    服務接口層通過部署,將業(yè)務層的業(yè)務管理類暴露為服務,因此,業(yè)務管理類所實現(xiàn)的業(yè)務邏輯的粒度就決定了系統(tǒng)服務的粒度。SOA傾向于粗粒度的服務,在進行系統(tǒng)之間的通信時,這有很大的優(yōu)勢,因為粗粒度的服務減少了系統(tǒng)之間的交互,提高了系統(tǒng)的運行效率,特別是異構異地的系統(tǒng)之間的通信。但在進行企業(yè)內(nèi)部應用系統(tǒng)之間集成,或系統(tǒng)內(nèi)部的構建時,粗粒度的服務降低了系統(tǒng)的靈活性,增大了系統(tǒng)的耦合性。所以,我們在構建SOA系統(tǒng)時,要選擇一個合適的服務粒度。

    5 服務接口層的設計

    1)Web服務引擎AXIS

    Apache可擴展交互系統(tǒng)(Apache eXtensible Interaction System,AXIS)是在基于可配置的消息鏈和Handler對象重新設計SOAP的過程中發(fā)展而來的。它是基于 Java的、最新的SOAP規(guī)范(SOAP 1.2)和SOAP with Attachments規(guī)范的開源實現(xiàn)。圖6表示了AXIS引擎的基礎結構。

    圖6 AXIS基礎結構

    AXIS可作為Web服務引擎工作于服務接口層,也可作為服務請求方環(huán)境運行于應用層,因此,它是構建基于Java的Web服務的良好選擇。

    2)使用AXIS部署服務

    使用AXIS將業(yè)務層的組件部署為Web服務有以下3種方式:

    (1)最簡單的方式:jws方式

    AXIS提供了一種將帶有.jws擴展的Java類部署為Web服務的簡單方式。它的實質(zhì)是AXIS將Servlet引擎中的Java Servlet自動部署為Web服務。常用的Servlet引擎是Apache的 Tomcat容器。這種方式以Java類的源文件為基礎,部署方法很簡單,只須將以.java為擴展名的源文件,重命名為以.jws為擴展名的文件,復制到Axis Web應用程序的主目錄中。當該Web服務被訪問時,Axis會根據(jù).jws文件自動生成相應的 WSDL及SOAP端點,即自動將.jw s文件部署為Web服務,而無需WSDD部署描述符。這種方式也無需編譯該文件,Axis運行庫會自動進行類及其所有方法的編譯。

    獲取該服務的WSDL與其它方式相同,只需在訪問該服務的URL后加“?WSDL”參數(shù)即可,如“http://localhost:8080/axis/HelloWorld.jws?WSDL”。

    以.jws文件形式創(chuàng)建Web服務的方法,從簡易性及可操作性的角度來看,非常類似于JSP。這種方式一般用于建立單一的或簡易的Web服務。

    (2)使用WSDD將JSE組件部署為Web服務

    以.jws文件部署基于Java的Web服務雖然既簡單有快捷,但缺乏服務部署的靈活性,例如,我們需要將JSE組件中的某些方法而非全部發(fā)布為Web服務。Axis提供了 Web服務部署描述符(Web Service Deployment Description,WSDD)的方法,可以對Java Web服務進行一些高級的定制部署。該方法需要創(chuàng)建一個部署服務(deployment)的XM L描述文件(*.wsdd)和一個卸載服務(undeployment)的XML描述文件。這些文件將告訴AXIS如何處理對Java Web服務的特定調(diào)用。

    (3)使用WSDD將EJB部署為Web服務

    在開源的EJB服務器(或容器)中,我們選擇JBoss公司的JBoss服務器。JBoss集成Axis時,需將Axis文件夾復制到JBoss的部署目錄中。另外,我們還要確保Axis能夠為EJB載入類文件,方法是將該EJB的.jar包文件復制一份到Axixlib文件夾中。一般情況下,我們使用Axis將JBoss中的無狀態(tài)會話(Stateless SessionBean)類型的EJB發(fā)布為Web服務,目前可采用如下兩種常用的方法:

    ①使用基于EJB的WSDD,這種方式同上述第2種情形大致相似,只是WSDD中有更多的元素來描述EJB,因為EJB相對于JSE,有更多的要遵循的規(guī)范。

    ②使用JBoss的 JBoss.NET模塊,用 XML Web服務描述符來部署。JBoss.NET[29]是JBoss集成了Axis后的部署Web服務的一個工具。利用它進行部署工作要依賴于.wsr文件,該文件可視為打包版的Axis的WSDD。.wsr文件是一個標準的.jar文件,僅包含一個名為META-INTweb_service.xml的XML Web服務描述符。

    JBoss公司目前正在進行一個被稱為“JBoss-WS”的項目,其目標是重構JBoss應用服務器,以使用他自己的SOAP協(xié)議棧而不是集成Axis。

    6 應用層的設計

    應用層客戶端在構建用戶的業(yè)務流程時,一般要先完成調(diào)用服務以及基于XML的數(shù)據(jù)處理兩項任務??蛻舳苏{(diào)用服務大多數(shù)情況下是為了進行數(shù)據(jù)通信。對于服務的請求方和提供方,二者都基于XML的數(shù)據(jù)格式進行通信,因而在調(diào)用服務進行數(shù)據(jù)通信時,需要將用戶關心的數(shù)據(jù)進行串行化或反串行化(AXIS引擎只自動實現(xiàn)SOAP消息的串行化或反串行化)。所謂串行化數(shù)據(jù)是指將應用程序的數(shù)據(jù)格式轉(zhuǎn)換為XML格式,反串行化則反之。根據(jù)數(shù)據(jù)的流向,可分為兩種情形,一是通過調(diào)用服務向服務提供方發(fā)送數(shù)據(jù)(如圖7所示),如向網(wǎng)上商店提交的訂單,需要進行數(shù)據(jù)串行化。

    圖7 串行化流程

    二是調(diào)用服務從服務提供方獲取數(shù)據(jù)(如圖8所示),如獲取商家的產(chǎn)品信息,這與第一種情形正好相反,需要進行數(shù)據(jù)的反串行化。

    圖8 反串行化流程

    對于第一種情形,客戶端應用程序先將數(shù)據(jù)串行化為XML格式,然后用SOAP協(xié)議進行封裝,調(diào)用服務發(fā)送即可。對于另一種情形,客戶端一般先接收調(diào)用服務所獲取的基于XML格式的字符串,然后將其反串行化為用戶所需類型的數(shù)據(jù)。

    圖9 應用層數(shù)據(jù)處理架構

    客戶端在調(diào)用服務發(fā)送數(shù)據(jù),進行數(shù)據(jù)的串行化之前,需要采集原始數(shù)據(jù)。而在調(diào)用服務獲取數(shù)據(jù)并進行反串行化之后,需要顯示數(shù)據(jù)或進行持久化。因此,應用層除了要進行數(shù)據(jù)串行化或反串行化外,還需要實現(xiàn)數(shù)據(jù)的顯示或提交邏輯。對于客戶端,這一處理邏輯可以基于C/S方式,為用戶提供靈活友好的使用界面,進行顯式處理,或直接用程序組件隱式處理。客戶端亦可基于B/S方式,建立精美的Web頁面顯示或提交數(shù)據(jù)。應用層數(shù)據(jù)處理的架構如圖9所示。

    7 結語

    本文所論述的應用層側(cè)重于服務調(diào)用的設計,而沒有過多涉及應用系統(tǒng)客戶端的具體實現(xiàn)。因為實際上,客戶端程序都將調(diào)用服務作為函數(shù)(或過程)來實現(xiàn)。系統(tǒng)開發(fā)人員在構建客戶端應用程序時,可以采用B/S或C/S方式,并在其中調(diào)用訪問Web服務的函數(shù),來構建最終的應用系統(tǒng)。而不論是B/S還是C/S,都已經(jīng)是很成熟的模型,這兩種模型也都有非常成熟的技術可以實現(xiàn)。

    作為一個剛剛步入實踐的新事物,SOA還面臨著很多的挑戰(zhàn)。SOA還正處在不斷的發(fā)展之中,它的成熟度和完善性還有待于研究人員和企業(yè)在理論和實踐中不斷的加以提高和改善。雖然被稱為是繼面向過程和面向組件的下一代軟件體系結構,但目前還沒有以上兩種架構成熟,且目前的應用才剛剛起步。然而,由于SOA自身具有的優(yōu)勢順應了未來軟件發(fā)展的趨勢,并隨著各大軟件供應商在此展開的深入研究和激烈競爭,它必然會成為成熟的下一代軟件體系架構和主流開發(fā)技術而得到廣泛支持和應用。可以預見在未來的幾年里,SOA將會取得長足的發(fā)展。

    [1]胡光.基于Jini的查找服務實現(xiàn)[J].計算機應用研究,2005(2)http://www.bea.com/framework.jsp?CNT=index.htm&FP=/content/solutions/technical/web_services

    [2][美]科耶爾.XM L、Web服務和數(shù)據(jù)革命[M].袁勤勇,等譯.清華大學出版社,2003

    [3]蔡月茹,柳西玲.Web Service基礎教程[M].北京:清華大學出版社,2005,6

    [4]張凱.軟件復雜性與質(zhì)量控制[M].北京:中國財政經(jīng)濟出版社,2005,11

    [5]姜璐.復雜系統(tǒng)的層次結構,復雜性研究[M].北京:科學出版社,1993,7

    [6]伽瑪,等.設計模式:可復用面向?qū)ο筌浖幕A[M].李英軍,等譯.北京:機械工業(yè)出版社,2000,9

    [7][美]尼戈潘,等.Java Web服務開發(fā)[M].龐太剛,陶程,譯.2004,5

    猜你喜歡
    應用層調(diào)用部署
    一種基于Kubernetes的Web應用部署與配置系統(tǒng)
    晉城:安排部署 統(tǒng)防統(tǒng)治
    部署
    核電項目物項調(diào)用管理的應用研究
    LabWindows/CVI下基于ActiveX技術的Excel調(diào)用
    測控技術(2018年5期)2018-12-09 09:04:46
    基于分級保護的OA系統(tǒng)應用層訪問控制研究
    基于系統(tǒng)調(diào)用的惡意軟件檢測技術研究
    部署“薩德”意欲何為?
    太空探索(2016年9期)2016-07-12 10:00:02
    新一代雙向互動電力線通信技術的應用層協(xié)議研究
    物聯(lián)網(wǎng)技術在信息機房制冷系統(tǒng)中的應用
    久久久色成人| 在线观看66精品国产| 嫩草影院精品99| 91精品一卡2卡3卡4卡| www.色视频.com| 成年av动漫网址| 婷婷色综合大香蕉| 国产单亲对白刺激| 91午夜精品亚洲一区二区三区| 丰满少妇做爰视频| av天堂中文字幕网| 插阴视频在线观看视频| 日韩欧美精品v在线| 亚洲欧美精品专区久久| 日韩,欧美,国产一区二区三区 | 看黄色毛片网站| 99久国产av精品| 久久精品久久久久久噜噜老黄 | 久久精品国产亚洲av涩爱| 久久综合国产亚洲精品| 日产精品乱码卡一卡2卡三| 小说图片视频综合网站| 国产精品不卡视频一区二区| 天堂av国产一区二区熟女人妻| 别揉我奶头 嗯啊视频| 国产单亲对白刺激| 国产一级毛片在线| 国产不卡一卡二| 欧美成人精品欧美一级黄| 春色校园在线视频观看| 久久精品国产亚洲av涩爱| 99久久精品国产国产毛片| 亚洲av福利一区| 寂寞人妻少妇视频99o| 亚洲美女视频黄频| 综合色丁香网| 秋霞在线观看毛片| 亚洲丝袜综合中文字幕| 亚洲欧美精品自产自拍| 亚洲精品乱久久久久久| 亚洲va在线va天堂va国产| 中文字幕制服av| 国产伦理片在线播放av一区| 自拍偷自拍亚洲精品老妇| 国产成人精品婷婷| 日韩亚洲欧美综合| 99热这里只有是精品50| 亚洲中文字幕日韩| 深夜a级毛片| 亚洲伊人久久精品综合 | 欧美性猛交╳xxx乱大交人| 亚洲国产精品成人久久小说| 免费一级毛片在线播放高清视频| 久久精品人妻少妇| 激情 狠狠 欧美| 熟女人妻精品中文字幕| 国产午夜精品一二区理论片| av在线观看视频网站免费| 麻豆国产97在线/欧美| 美女cb高潮喷水在线观看| 国产91av在线免费观看| 一个人看的www免费观看视频| 午夜福利在线在线| 激情 狠狠 欧美| 成人av在线播放网站| 亚洲在线观看片| 国产熟女欧美一区二区| 国产成人91sexporn| 丝袜美腿在线中文| 午夜久久久久精精品| 少妇高潮的动态图| 国产不卡一卡二| 日本av手机在线免费观看| 麻豆精品久久久久久蜜桃| 看片在线看免费视频| 一区二区三区高清视频在线| 综合色av麻豆| 一边亲一边摸免费视频| 搡老妇女老女人老熟妇| 内地一区二区视频在线| 国产熟女欧美一区二区| 有码 亚洲区| 男人和女人高潮做爰伦理| 久久久久久久亚洲中文字幕| 纵有疾风起免费观看全集完整版 | 亚洲一级一片aⅴ在线观看| 精品久久久久久久末码| 亚洲天堂国产精品一区在线| 国产免费一级a男人的天堂| 五月玫瑰六月丁香| 国产精品一区www在线观看| 精品久久久噜噜| 国产成人精品久久久久久| 99久久中文字幕三级久久日本| 欧美xxxx黑人xx丫x性爽| 国产乱人偷精品视频| 久久久久久久久久成人| 菩萨蛮人人尽说江南好唐韦庄 | 亚洲,欧美,日韩| 亚洲乱码一区二区免费版| 美女xxoo啪啪120秒动态图| 青春草国产在线视频| 日韩在线高清观看一区二区三区| 久久国产乱子免费精品| 亚洲婷婷狠狠爱综合网| 午夜精品一区二区三区免费看| 亚洲中文字幕日韩| 色综合站精品国产| 免费看av在线观看网站| 99久久九九国产精品国产免费| 日韩精品有码人妻一区| 一本久久精品| 看片在线看免费视频| 中文字幕av成人在线电影| 婷婷色综合大香蕉| 成人一区二区视频在线观看| 少妇高潮的动态图| 91精品国产九色| 亚洲五月天丁香| 国产精品综合久久久久久久免费| 久久精品国产99精品国产亚洲性色| 亚洲国产精品成人综合色| 精品一区二区三区视频在线| 男女那种视频在线观看| 国内少妇人妻偷人精品xxx网站| 国产精品三级大全| 成人鲁丝片一二三区免费| 亚洲欧美成人精品一区二区| 亚洲成人中文字幕在线播放| 美女内射精品一级片tv| 欧美一级a爱片免费观看看| 国产女主播在线喷水免费视频网站 | 亚洲性久久影院| 国产精品无大码| 嫩草影院新地址| 中文字幕免费在线视频6| 白带黄色成豆腐渣| 日韩欧美三级三区| 久久久国产成人免费| 午夜精品一区二区三区免费看| 国产免费福利视频在线观看| 丰满乱子伦码专区| 蜜桃亚洲精品一区二区三区| 欧美最新免费一区二区三区| 欧美精品国产亚洲| 精品无人区乱码1区二区| 精品国内亚洲2022精品成人| 久久久午夜欧美精品| 国产高清国产精品国产三级 | 日韩制服骚丝袜av| 六月丁香七月| 成人综合一区亚洲| 91aial.com中文字幕在线观看| 日韩强制内射视频| 成人亚洲精品av一区二区| 网址你懂的国产日韩在线| 亚洲av成人精品一二三区| 日韩欧美精品免费久久| 99久久精品一区二区三区| 日韩av在线免费看完整版不卡| 亚洲欧洲日产国产| 国产精品伦人一区二区| 欧美日韩综合久久久久久| 国产成人免费观看mmmm| 国产精品美女特级片免费视频播放器| 国产精品99久久久久久久久| 丰满人妻一区二区三区视频av| 老司机影院成人| 国产高清三级在线| 欧美又色又爽又黄视频| 午夜福利在线观看吧| 国产免费又黄又爽又色| 亚洲国产精品sss在线观看| 少妇猛男粗大的猛烈进出视频 | 国产久久久一区二区三区| 日本-黄色视频高清免费观看| 男女国产视频网站| 亚洲国产精品国产精品| 自拍偷自拍亚洲精品老妇| 国产成人a∨麻豆精品| 日本一本二区三区精品| 日韩欧美精品v在线| 丝袜美腿在线中文| 国产在线男女| 一本—道久久a久久精品蜜桃钙片 精品乱码久久久久久99久播 | 亚洲av.av天堂| 老司机影院成人| 国产精品不卡视频一区二区| 热99在线观看视频| 精品一区二区三区视频在线| 欧美不卡视频在线免费观看| 国产亚洲午夜精品一区二区久久 | 秋霞在线观看毛片| 久久久久国产网址| 免费电影在线观看免费观看| 色视频www国产| 网址你懂的国产日韩在线| 国产一区亚洲一区在线观看| 久久草成人影院| 亚洲成人av在线免费| 国产av不卡久久| 三级国产精品片| 国产精品精品国产色婷婷| 亚洲精品456在线播放app| 欧美日韩综合久久久久久| 日本猛色少妇xxxxx猛交久久| 超碰97精品在线观看| 亚洲经典国产精华液单| 国产视频首页在线观看| 国产大屁股一区二区在线视频| 国产三级中文精品| 国产黄片视频在线免费观看| 日韩欧美国产在线观看| 亚洲欧美日韩无卡精品| 久久久色成人| 亚洲成色77777| 国产精品日韩av在线免费观看| 国产91av在线免费观看| 自拍偷自拍亚洲精品老妇| 一区二区三区乱码不卡18| 国产午夜精品一二区理论片| 精品一区二区免费观看| 嘟嘟电影网在线观看| 高清午夜精品一区二区三区| 岛国在线免费视频观看| 国产又色又爽无遮挡免| 亚洲av免费在线观看| 韩国高清视频一区二区三区| 国产精品一区二区性色av| 一区二区三区四区激情视频| 国产在线男女| 亚洲av福利一区| 午夜精品国产一区二区电影 | 欧美变态另类bdsm刘玥| 国产精品,欧美在线| 国产亚洲一区二区精品| 亚洲精品aⅴ在线观看| 岛国在线免费视频观看| 欧美日韩国产亚洲二区| 有码 亚洲区| 亚洲精品乱码久久久v下载方式| 日韩av在线免费看完整版不卡| 噜噜噜噜噜久久久久久91| 我要搜黄色片| 美女脱内裤让男人舔精品视频| a级毛片免费高清观看在线播放| 男人舔女人下体高潮全视频| av又黄又爽大尺度在线免费看 | 亚洲aⅴ乱码一区二区在线播放| 啦啦啦啦在线视频资源| 又黄又爽又刺激的免费视频.| 亚洲av二区三区四区| 亚洲精品乱码久久久久久按摩| 国产成年人精品一区二区| av国产久精品久网站免费入址| 青春草国产在线视频| 最近最新中文字幕大全电影3| 精品不卡国产一区二区三区| 久久精品夜夜夜夜夜久久蜜豆| 日日干狠狠操夜夜爽| 国产成人aa在线观看| 精品久久久噜噜| 成年女人看的毛片在线观看| 国产大屁股一区二区在线视频| 秋霞在线观看毛片| 日本三级黄在线观看| 国产探花在线观看一区二区| 亚洲第一区二区三区不卡| 汤姆久久久久久久影院中文字幕 | 亚洲人成网站在线观看播放| 老司机影院毛片| av在线观看视频网站免费| 国产成年人精品一区二区| 最近视频中文字幕2019在线8| 成人无遮挡网站| 麻豆成人午夜福利视频| 国产在视频线在精品| 国产精品.久久久| eeuss影院久久| 麻豆成人午夜福利视频| 久久精品91蜜桃| 精品免费久久久久久久清纯| 午夜视频国产福利| 国产欧美另类精品又又久久亚洲欧美| 久久精品国产亚洲av天美| 久久久午夜欧美精品| 最近手机中文字幕大全| 三级经典国产精品| 亚洲av一区综合| 午夜精品一区二区三区免费看| 看非洲黑人一级黄片| 人妻少妇偷人精品九色| 你懂的网址亚洲精品在线观看 | 亚洲电影在线观看av| 免费看美女性在线毛片视频| 在线播放无遮挡| 五月玫瑰六月丁香| 中文在线观看免费www的网站| 精品人妻视频免费看| 51国产日韩欧美| 你懂的网址亚洲精品在线观看 | 亚洲电影在线观看av| 久久99热这里只频精品6学生 | av免费在线看不卡| 精品欧美国产一区二区三| 麻豆一二三区av精品| 免费电影在线观看免费观看| 免费黄色在线免费观看| 国产毛片a区久久久久| 嫩草影院精品99| 青春草视频在线免费观看| 九九久久精品国产亚洲av麻豆| 久久久久性生活片| 国内少妇人妻偷人精品xxx网站| 免费观看的影片在线观看| 国语自产精品视频在线第100页| 中文字幕熟女人妻在线| 精品久久久噜噜| 国产精品国产三级国产av玫瑰| 中文字幕制服av| 91aial.com中文字幕在线观看| 51国产日韩欧美| 麻豆久久精品国产亚洲av| 亚洲婷婷狠狠爱综合网| 白带黄色成豆腐渣| 天天躁日日操中文字幕| 国产白丝娇喘喷水9色精品| 国产精品女同一区二区软件| 日韩成人伦理影院| 国产精品精品国产色婷婷| 啦啦啦韩国在线观看视频| 精品一区二区免费观看| 高清毛片免费看| 久久国产乱子免费精品| 极品教师在线视频| 成人三级黄色视频| 午夜福利成人在线免费观看| www日本黄色视频网| 韩国高清视频一区二区三区| 国内精品一区二区在线观看| 国产不卡一卡二| 春色校园在线视频观看| 欧美高清成人免费视频www| 一区二区三区高清视频在线| 欧美激情在线99| 久久久久久久久久黄片| 欧美成人一区二区免费高清观看| 欧美成人精品欧美一级黄| 色综合色国产| 免费av毛片视频| 国产精品美女特级片免费视频播放器| 亚洲在久久综合| 我的女老师完整版在线观看| 亚洲国产精品成人久久小说| 日韩在线高清观看一区二区三区| 午夜福利高清视频| 国产成年人精品一区二区| 人妻系列 视频| 欧美一级a爱片免费观看看| 久久99精品国语久久久| 少妇猛男粗大的猛烈进出视频 | 亚洲欧洲日产国产| 午夜福利成人在线免费观看| 在线天堂最新版资源| 综合色av麻豆| 亚洲人成网站在线播| 全区人妻精品视频| 国国产精品蜜臀av免费| 国产精品久久久久久久久免| 国产极品精品免费视频能看的| 国产视频首页在线观看| 欧美另类亚洲清纯唯美| 亚洲精品aⅴ在线观看| 日韩成人av中文字幕在线观看| 国产一区有黄有色的免费视频 | 黄片wwwwww| 国产一级毛片在线| 美女大奶头视频| 秋霞在线观看毛片| 亚洲精品自拍成人| 美女高潮的动态| 国产精品无大码| 桃色一区二区三区在线观看| 黄片无遮挡物在线观看| 女人被狂操c到高潮| 日日啪夜夜撸| 99热6这里只有精品| 日韩人妻高清精品专区| a级毛色黄片| 中文天堂在线官网| 国产精品三级大全| 蜜臀久久99精品久久宅男| 91久久精品国产一区二区三区| 最近的中文字幕免费完整| 欧美不卡视频在线免费观看| 日韩成人av中文字幕在线观看| 日韩在线高清观看一区二区三区| 一本—道久久a久久精品蜜桃钙片 精品乱码久久久久久99久播 | 真实男女啪啪啪动态图| 久久久亚洲精品成人影院| 少妇的逼好多水| 干丝袜人妻中文字幕| 人体艺术视频欧美日本| 麻豆国产97在线/欧美| 别揉我奶头 嗯啊视频| 成人毛片60女人毛片免费| 国产高清有码在线观看视频| 尤物成人国产欧美一区二区三区| 22中文网久久字幕| 69人妻影院| 大又大粗又爽又黄少妇毛片口| 国产午夜精品久久久久久一区二区三区| av视频在线观看入口| 精品国内亚洲2022精品成人| 少妇被粗大猛烈的视频| 人妻少妇偷人精品九色| 国语自产精品视频在线第100页| 国产精品爽爽va在线观看网站| 高清毛片免费看| 日本黄大片高清| 男女国产视频网站| 国产91av在线免费观看| 成年女人看的毛片在线观看| 欧美性猛交╳xxx乱大交人| 老司机福利观看| 国产极品精品免费视频能看的| 国产亚洲最大av| 久久精品国产亚洲av天美| 亚洲精品乱码久久久久久按摩| 日韩av在线大香蕉| 成人午夜精彩视频在线观看| 久久婷婷人人爽人人干人人爱| 99热全是精品| 国产av码专区亚洲av| 免费看美女性在线毛片视频| 国产免费又黄又爽又色| 男女下面进入的视频免费午夜| 狂野欧美白嫩少妇大欣赏| 天天躁夜夜躁狠狠久久av| 熟女人妻精品中文字幕| 国产午夜精品久久久久久一区二区三区| 午夜爱爱视频在线播放| 亚洲av日韩在线播放| 日韩 亚洲 欧美在线| 久久精品人妻少妇| 国产一级毛片在线| 搡女人真爽免费视频火全软件| 久久精品国产亚洲av天美| 日韩欧美三级三区| 小蜜桃在线观看免费完整版高清| 欧美性感艳星| 色综合色国产| 午夜免费激情av| 一区二区三区高清视频在线| 婷婷色av中文字幕| 九九久久精品国产亚洲av麻豆| 国产大屁股一区二区在线视频| 亚洲18禁久久av| 亚洲av中文字字幕乱码综合| 日韩成人av中文字幕在线观看| 亚洲成色77777| 久久久色成人| 久久久午夜欧美精品| 超碰97精品在线观看| 搡女人真爽免费视频火全软件| 成人美女网站在线观看视频| 男女国产视频网站| 人妻制服诱惑在线中文字幕| 丰满少妇做爰视频| 国产乱人视频| 国产精品久久久久久久久免| 久久久久久伊人网av| 黄色欧美视频在线观看| 欧美性感艳星| 白带黄色成豆腐渣| 1024手机看黄色片| 久久99蜜桃精品久久| 久久精品国产亚洲av天美| 亚洲av免费在线观看| 成人午夜精彩视频在线观看| 日韩成人av中文字幕在线观看| 免费av不卡在线播放| 亚洲最大成人手机在线| 欧美又色又爽又黄视频| 亚洲av不卡在线观看| 色综合亚洲欧美另类图片| 国产一区有黄有色的免费视频 | 日日干狠狠操夜夜爽| 熟女电影av网| 韩国av在线不卡| 免费播放大片免费观看视频在线观看 | av天堂中文字幕网| 精品欧美国产一区二区三| 国产极品天堂在线| 在线播放国产精品三级| 国产成人福利小说| 99热精品在线国产| 国产三级在线视频| 亚洲伊人久久精品综合 | 国产探花极品一区二区| 18禁在线播放成人免费| 成人午夜精彩视频在线观看| 亚洲精品色激情综合| 欧美成人午夜免费资源| 男人舔女人下体高潮全视频| 久久精品国产99精品国产亚洲性色| 国产精品国产三级专区第一集| 熟女人妻精品中文字幕| 你懂的网址亚洲精品在线观看 | 久久精品熟女亚洲av麻豆精品 | 欧美性猛交黑人性爽| 伦精品一区二区三区| 亚洲婷婷狠狠爱综合网| 男的添女的下面高潮视频| 韩国av在线不卡| 久久久久精品久久久久真实原创| 国产日韩欧美在线精品| 丰满乱子伦码专区| 看十八女毛片水多多多| 亚洲国产精品成人久久小说| 精品人妻视频免费看| 精品久久久久久久久久久久久| 国产成人福利小说| 亚洲欧美日韩东京热| 一区二区三区乱码不卡18| 国产乱人视频| 午夜精品国产一区二区电影 | ponron亚洲| 成年免费大片在线观看| 久久亚洲精品不卡| 欧美潮喷喷水| 卡戴珊不雅视频在线播放| 日本免费一区二区三区高清不卡| 欧美成人精品欧美一级黄| 精品午夜福利在线看| 两性午夜刺激爽爽歪歪视频在线观看| 日本一二三区视频观看| 免费看a级黄色片| 亚洲图色成人| or卡值多少钱| 成人亚洲欧美一区二区av| 国产麻豆成人av免费视频| 免费播放大片免费观看视频在线观看 | 99视频精品全部免费 在线| 国产成人aa在线观看| 亚洲怡红院男人天堂| 久久久久久久久中文| 好男人视频免费观看在线| 国产爱豆传媒在线观看| 18禁动态无遮挡网站| 欧美精品国产亚洲| 免费看光身美女| 男插女下体视频免费在线播放| 欧美日韩在线观看h| 国产日韩欧美在线精品| 两个人视频免费观看高清| 边亲边吃奶的免费视频| 欧美另类亚洲清纯唯美| 色综合站精品国产| 成年版毛片免费区| 水蜜桃什么品种好| 久久亚洲精品不卡| 91精品一卡2卡3卡4卡| 插阴视频在线观看视频| 日韩欧美精品v在线| 午夜精品一区二区三区免费看| 久久精品久久精品一区二区三区| 边亲边吃奶的免费视频| 高清毛片免费看| 狂野欧美激情性xxxx在线观看| 国产熟女欧美一区二区| 又爽又黄无遮挡网站| 国产国拍精品亚洲av在线观看| 成人高潮视频无遮挡免费网站| 国产老妇伦熟女老妇高清| 亚洲精品成人久久久久久| 成人一区二区视频在线观看| 欧美成人a在线观看| 日日啪夜夜撸| 久久久久久久久久久丰满| 成人漫画全彩无遮挡| 身体一侧抽搐| 免费黄网站久久成人精品| 久久久久久久午夜电影| 三级男女做爰猛烈吃奶摸视频| 啦啦啦啦在线视频资源| 亚洲av成人av| 欧美最新免费一区二区三区| 国产精品一二三区在线看| 在线免费观看的www视频| 久久久久国产网址| 国产精品一区www在线观看| 看非洲黑人一级黄片| 国产午夜精品一二区理论片| 日韩高清综合在线| 波多野结衣高清无吗| 国产又黄又爽又无遮挡在线| 一夜夜www| 久久热精品热| 乱码一卡2卡4卡精品| 我要搜黄色片| 欧美一区二区精品小视频在线| 在线播放国产精品三级| 欧美性猛交╳xxx乱大交人| 国产精品一区二区性色av| 国产在线一区二区三区精 | 午夜精品一区二区三区免费看| 国产免费视频播放在线视频 | 免费观看人在逋| 国产精品综合久久久久久久免费| 高清毛片免费看| 国产精品女同一区二区软件| ponron亚洲| 久久人妻av系列| 国产黄色小视频在线观看|