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

    基于關(guān)系數(shù)據(jù)模型代碼生成器的設(shè)計(jì)與實(shí)現(xiàn)

    2010-11-26 01:06:56冉春娟黃華
    關(guān)鍵詞:代碼生成數(shù)據(jù)模型腳本

    冉春娟,黃華

    (武漢大學(xué) 計(jì)算機(jī)學(xué)院,湖北 武漢 430071)

    近年來(lái),企業(yè)或政府部門的核心業(yè)務(wù)大多通過(guò)管理信息系統(tǒng)MIS實(shí)現(xiàn),MIS系統(tǒng)開發(fā)成為應(yīng)用系統(tǒng)開發(fā)的主流.在當(dāng)前計(jì)算機(jī)技術(shù)條件下,MIS系統(tǒng)大部分是構(gòu)建在關(guān)系數(shù)據(jù)模型上,其系統(tǒng)的開發(fā)方法也有很多的相似性.通過(guò)考察基于主流開發(fā)平臺(tái)(如Java與.Net)多層架構(gòu)的程序?qū)崿F(xiàn)代碼,發(fā)現(xiàn)大量相似程序代碼都與關(guān)系數(shù)據(jù)模型相關(guān),根據(jù)所做的統(tǒng)計(jì),其平均代碼行數(shù)占到總代碼行數(shù)的50%,有的甚至接近70%.如能以關(guān)系數(shù)據(jù)模型作為輸入,自動(dòng)生成相關(guān)程序代碼,必將可以大大縮短MIS系統(tǒng)的開發(fā)周期,提高軟件代碼的質(zhì)量,也可快速適應(yīng)MIS系統(tǒng)頻繁的需求變化.

    1 現(xiàn)有代碼生成技術(shù)分析

    從現(xiàn)有的主流代碼生成技術(shù)看,都采用了基于模板的方法,即以成功應(yīng)用的程序代碼作為藍(lán)本,將其中固定不變的部分作為靜態(tài)代碼框架部分,將其中需要變化的部分通過(guò)結(jié)合一定的標(biāo)記或生成語(yǔ)言改寫為可動(dòng)態(tài)替換的腳本,從而構(gòu)成代碼模板文件,再結(jié)合生成工具同數(shù)據(jù)源相作用,生成實(shí)際的程序代碼[1].盡管原理相似,但不同的代碼生成工具在具體實(shí)現(xiàn)技術(shù)上卻不盡相同,概括起來(lái)分為兩種類型:內(nèi)置模板型和可定制模板型.(1)內(nèi)置模板型:代碼的模板與生成工具是一體的,模板的格式和內(nèi)容都隱含在生成工具中,不能定制.這一類的生成工具如動(dòng)軟.Net代碼生成器,JAG-Java代碼生成器等.(2)可定制模板型:代碼的模板與生成工具分離,代碼生成工具提供一種標(biāo)記語(yǔ)言作為模板的編寫規(guī)則.用戶可通過(guò)標(biāo)記語(yǔ)言編寫代碼模板,從而滿足不同應(yīng)用平臺(tái)和應(yīng)用環(huán)境的需要.這一類的生成工具如CodeSmith,Freemarker,Velocity等.

    對(duì)于以上兩種類型的代碼生成工具,內(nèi)置模板型由于將模板內(nèi)置在程序中,用戶不能定制模板和生成規(guī)則,其應(yīng)用環(huán)境非常有限,通用性也比較差.對(duì)于CodeSmith,Freemarker,Velocity等[2]可定制模板型生成工具.盡管功能強(qiáng)大,能滿足各種代碼生成需要,具備較強(qiáng)的通用性,但這些生成工具所支持的代碼生成控制語(yǔ)言要么基于一種實(shí)際的開發(fā)語(yǔ)言(如CodeSmith基于C#語(yǔ)言),要么基于一種通用解釋型語(yǔ)言,掌握語(yǔ)言本身就需要花費(fèi)大量的時(shí)間,同時(shí)這些語(yǔ)言同關(guān)系數(shù)據(jù)模型結(jié)合不緊密,往往編寫的模板代碼結(jié)構(gòu)復(fù)雜,難于維護(hù),也很難在軟件開發(fā)團(tuán)隊(duì)中得到快速的應(yīng)用.

    2 基于關(guān)系數(shù)據(jù)模型的代碼生成原理

    2.1設(shè)計(jì)思路通過(guò)上述代碼生成技術(shù)分析可知:如果能在保持可定制模板型代碼生成工具框架結(jié)構(gòu)基礎(chǔ)上,對(duì)其代碼生成控制語(yǔ)言進(jìn)行改進(jìn),采用一種與關(guān)系數(shù)據(jù)模型緊密結(jié)合的代碼生成控制語(yǔ)言,將可以保持生成工具通用性,并提高代碼生成工具的可用性.據(jù)此,我們對(duì)代碼生成工具的設(shè)計(jì)劃分為兩部分:(1)與關(guān)系數(shù)據(jù)模型緊密相關(guān)的代碼生成控制語(yǔ)言(以下稱RDM CodeMark語(yǔ)言)的設(shè)計(jì);(2)基于RDM CodeMark語(yǔ)言的代碼生成工具(以下簡(jiǎn)稱RDM代碼生成工具)的設(shè)計(jì).

    2.2 RDM代碼生成工具工作原理

    圖1 RDM代碼生成工具結(jié)構(gòu)模型

    2.2.1 RDM代碼生成工具結(jié)構(gòu)模型 RDM代碼生成工具在原理上仍是一種基于模板的代碼生成工具,具有該類型代碼生成工具的通用結(jié)構(gòu),具體實(shí)現(xiàn)上有特殊之處,圖1是RDM代碼生成工具組成模型:(1) 關(guān)系模型建模:對(duì)關(guān)系模型進(jìn)行的形式化描述,代表系統(tǒng)的關(guān)系模式信息,構(gòu)成RDM代碼生成器的輸入.模型可以采用Word文檔、運(yùn)行的數(shù)據(jù)庫(kù)以及UML文檔等;(2) RDM CodeMark語(yǔ)言:同關(guān)系數(shù)據(jù)模型相關(guān)的代碼生成控制語(yǔ)言,采用類XML語(yǔ)言的語(yǔ)法格式和迭代語(yǔ)義規(guī)則,用于編寫代碼模板文件中動(dòng)態(tài)代碼生成腳本;(3) 模板文件:采用RDM CodeMark語(yǔ)言編寫的代碼生成控制腳本文件(即RDM CodeMark語(yǔ)言程序),用于定義輸出代碼文件的創(chuàng)建信息和在生成文件中定制代碼內(nèi)容;(4) RDM代碼生成器:代碼生成工具核心程序,以關(guān)系模型建模作為輸入,執(zhí)行指定代碼模板文件,輸出生成后的代碼文件.主要由關(guān)系數(shù)據(jù)模型管理部件和代碼生成部件兩部分組成,其中關(guān)系數(shù)據(jù)模型管理部件用于將不同的外部關(guān)系模型建模導(dǎo)入后轉(zhuǎn)換到內(nèi)部標(biāo)準(zhǔn)關(guān)系模型對(duì)象集進(jìn)行維護(hù)和管理,為代碼生成部件提供一致的關(guān)系模型訪問(wèn)接口.代碼生成部件則通過(guò)調(diào)入指定模板文件按照RDM CodeMark語(yǔ)言迭代語(yǔ)義規(guī)則執(zhí)行,在執(zhí)行過(guò)程中嵌入對(duì)關(guān)系數(shù)據(jù)模型對(duì)象集標(biāo)記的解析,最終生成實(shí)際程序代碼文件;(5) 代碼文件:實(shí)際生成代碼的輸出文件,是可以在項(xiàng)目系統(tǒng)中加入的可編譯源程序文件.

    2.2.2 代碼生成工具工作過(guò)程 (1) 采用RDM CodeMark語(yǔ)言編寫代碼模板文件;(2) 采用word文檔、數(shù)據(jù)庫(kù)建庫(kù)工具或UML對(duì)關(guān)系模型建模;(3) 在RDM代碼生成器中導(dǎo)入關(guān)系模型建模,轉(zhuǎn)換為內(nèi)部統(tǒng)一關(guān)系數(shù)據(jù)模型對(duì)象集,并維護(hù)對(duì)象集信息的完整性;(4) 在RDM代碼生成器中選擇模板文件并執(zhí)行,生成目標(biāo)代碼輸出文件.

    表1 表對(duì)象屬性及其標(biāo)記

    3 基于關(guān)系數(shù)據(jù)模型的代碼生成技術(shù)

    3.1關(guān)系數(shù)據(jù)模型對(duì)象集設(shè)計(jì)

    關(guān)系數(shù)據(jù)模型對(duì)象集是對(duì)具體項(xiàng)目所設(shè)計(jì)的數(shù)據(jù)字典的統(tǒng)一對(duì)象化表示,構(gòu)成代碼生成部件的實(shí)際輸入支持對(duì)象.關(guān)系數(shù)據(jù)模型對(duì)象集由表集合、表、列集合、列對(duì)象組成,對(duì)應(yīng)關(guān)系數(shù)據(jù)模型中的元模型數(shù)據(jù).

    表對(duì)象主要屬性及其在腳本中的代碼標(biāo)記如表1,列對(duì)象主要屬性及其在腳本中的代碼標(biāo)記如下表2.

    表2 列對(duì)象屬性及其標(biāo)記

    3.2 RDM CodeMark標(biāo)記語(yǔ)言RDM CodeMark標(biāo)記語(yǔ)言是結(jié)合關(guān)系數(shù)據(jù)模型設(shè)計(jì)的代碼標(biāo)記語(yǔ)言,在語(yǔ)法格式上接近XML語(yǔ)言,通過(guò)在代碼模板中嵌入標(biāo)記語(yǔ)言編寫的腳本程序,為代碼生成部件提供代碼生成控制.RDM CodeMark語(yǔ)言的語(yǔ)法成分分為三種類型:迭代控制語(yǔ)句、輸出控制語(yǔ)句和關(guān)系模型對(duì)象代碼標(biāo)記.

    3.2.1 迭代控制語(yǔ)句

    1) 表迭代語(yǔ)句TableLoop:執(zhí)行對(duì)所有的表進(jìn)行一次迭代展開.

    語(yǔ)法格式:,其中:

    (1) 對(duì)參加迭代的表進(jìn)行過(guò)濾,其語(yǔ)法為:

    .

    (2) 為迭代的表模板展開項(xiàng)之間提供分割符,語(yǔ)法為:.

    2) 表檢查語(yǔ)句TableCheck:執(zhí)行表屬性檢查,滿足條件的,執(zhí)行對(duì)應(yīng)的模板.

    語(yǔ)法格式為:,其中:

    構(gòu)成判斷的條件部分,其語(yǔ)法為:

    .

    (3)列迭代語(yǔ)句ColumnLoop:對(duì)表中所有列進(jìn)行一次迭代展開.

    語(yǔ)法格式為:,

    (4)列檢查語(yǔ)句ColumnCheck:執(zhí)行列屬性檢查,滿足條件的,執(zhí)行對(duì)應(yīng)的模板.

    語(yǔ)法格式為:.

    (5)調(diào)用腳本語(yǔ)句CallScript:將嵌入的模板腳本執(zhí)行,并引用其輸出.

    語(yǔ)法格式為:.

    (6) 腳本包含語(yǔ)句Using:將指定的模板文件嵌入到當(dāng)前文本中.

    語(yǔ)法格式為:.

    3.2.2 輸出控制語(yǔ)句 輸出控制語(yǔ)句只有一個(gè)OutputToFile語(yǔ)句,用于將迭代生成的文本寫入到指定文件中.在一個(gè)文本文件中多次使用則可控制生成多個(gè)文件.

    語(yǔ)法格式為:,

    其中,用于提供程序文件的相對(duì)輸出路徑,語(yǔ)法為 .

    3.2.3 關(guān)系模型對(duì)象代碼標(biāo)記 見表1和表2中各個(gè)對(duì)應(yīng)屬性的標(biāo)記語(yǔ)法部分.

    3.3 RDM代碼生成腳本(模板)文件使用RDM CodeMark標(biāo)記語(yǔ)言編寫的腳本文件是一種特殊的解釋型代碼生成控制程序(簡(jiǎn)稱RDM CodeMark腳本程序),能夠在對(duì)應(yīng)的翻譯器中控制執(zhí)行,以關(guān)系數(shù)據(jù)模型對(duì)象集作為輸入,動(dòng)態(tài)生成與關(guān)系數(shù)據(jù)模型相關(guān)的各種程序代碼.

    RDM CodeMark腳本程序中文本分為兩類:RDM CodeMark標(biāo)記語(yǔ)言語(yǔ)法成分和普通文本.RDM CodeMark腳本翻譯器針對(duì)RDM CodeMark標(biāo)記語(yǔ)言語(yǔ)法成分進(jìn)行迭代解釋輸出,而對(duì)于普通文本則不做處理直接輸出.RDM CodeMark腳本程序的編寫規(guī)則取決于翻譯器的代碼生成規(guī)則,具體規(guī)則見4.2節(jié)代碼生成的算法.

    RDM CodeMark腳本程序示例如下:

    (1)用于生成對(duì)表進(jìn)行Insert操作的SQL語(yǔ)句,見圖2:

    圖2 表的Insert操作模板腳本

    (2).Net平臺(tái)下數(shù)據(jù)操作模型對(duì)象的生成實(shí)例,見下圖3:

    圖3 .Net數(shù)據(jù)操作對(duì)象模板及代碼生成實(shí)例

    4 RDM代碼生成工具實(shí)現(xiàn)

    4.1 RDM代碼生成器的靜態(tài)類結(jié)構(gòu)RDM代碼生成器的靜態(tài)類設(shè)計(jì)可劃分為數(shù)據(jù)模型管理、數(shù)據(jù)模型導(dǎo)入,詞法解析,文件寫入,腳本迭代解析,代碼生成等不同職責(zé)的類集合.其對(duì)象關(guān)系見圖4.

    圖4 RDM 代碼生成工具類結(jié)構(gòu)框架

    數(shù)據(jù)模型管理類集合的作用是對(duì)關(guān)系數(shù)據(jù)模型的標(biāo)準(zhǔn)化表示和統(tǒng)一管理.由TableStandar-dModel、TableSet、Column-StandardModel、ColumnSet、DataModel-Catalog類構(gòu)成,分別對(duì)應(yīng)表標(biāo)準(zhǔn)模型類、表集合類、列標(biāo)準(zhǔn)模型類、列集合類、數(shù)據(jù)模型管理類.

    數(shù)據(jù)模型導(dǎo)入類集合的作用是將外部各種形式的應(yīng)用系統(tǒng)關(guān)系數(shù)據(jù)模型設(shè)計(jì)轉(zhuǎn)換為內(nèi)部標(biāo)準(zhǔn)數(shù)據(jù)模型,IDataModelImporter是導(dǎo)入類的抽象接口,主要方法為 DataModel-Catalog ImportDataModel(),為所有具體的導(dǎo)入類提供統(tǒng)一的功能規(guī)約.DataBase-Importer、XMLImporter、DocImporter、UmlImpo-rter類實(shí)現(xiàn)IDataModel-Importer接口,對(duì)應(yīng)實(shí)現(xiàn)以數(shù)據(jù)庫(kù)系統(tǒng)、XML數(shù)據(jù)模型設(shè)計(jì)文檔、Word數(shù)據(jù)模型設(shè)計(jì)文檔和UML數(shù)據(jù)模型設(shè)計(jì)文檔作為源模型向標(biāo)準(zhǔn)數(shù)據(jù)模型的轉(zhuǎn)換.ScriptBuilder、FileWriter、CodeParser-Util類屬于工具類,分別實(shí)現(xiàn)腳本文件的構(gòu)造、腳本文件的輸出、腳本的語(yǔ)法成分解析,為模板文件的迭代生成提供底層支持.

    腳本迭代解析類集合按照RDM CodeMark標(biāo)記語(yǔ)言的各個(gè)語(yǔ)句的語(yǔ)義要求,實(shí)現(xiàn)各種語(yǔ)句的腳本迭代解析,解析的過(guò)程就是局部生成目標(biāo)代碼的過(guò)程.所有語(yǔ)句解析類實(shí)現(xiàn)一個(gè)統(tǒng)一的腳本解析接口IScriptParser,其主要方法為string ParseScript(),實(shí)現(xiàn)腳本的迭代生成的功能規(guī)約.圖2中實(shí)現(xiàn)IScriptParser的各類分別對(duì)應(yīng)實(shí)現(xiàn)各個(gè)語(yǔ)句的語(yǔ)義迭代翻譯,限于篇幅此處不再詳述.RDMCodeGenerator類是代碼生成器的核心控制器類,以數(shù)據(jù)模型為輸入,執(zhí)行加載的模板文本,并生成最終的程序代碼.

    4.2 RDM代碼生成的關(guān)鍵算法RDMCodeGenerator類的方法Generate()是生成目標(biāo)程序代碼的關(guān)鍵方法,該方法的執(zhí)行算法見下圖5的代碼生成序列圖.

    圖5 代碼生成序列圖

    圖6 采用Delphi實(shí)現(xiàn)的RDM代碼生成工具的主界面

    4.3 RDM代碼生成器界面與功能按照RDM代碼生成工具的設(shè)計(jì),可以采用任意支持面向?qū)ο缶幊痰拈_發(fā)工具進(jìn)行實(shí)現(xiàn),圖6為采用Delphi實(shí)現(xiàn)的RDM代碼生成工具的主界面,其主要功能包括:數(shù)據(jù)模型設(shè)計(jì)文件的導(dǎo)入和編輯管理,模板文件的編輯和管理,模板的選擇與執(zhí)行管理,腳本的生成與輸出管理等.

    5 RDM代碼生成工具應(yīng)用實(shí)例

    RDM代碼生成工具可按照應(yīng)用系統(tǒng)數(shù)據(jù)模型設(shè)計(jì)快速生成應(yīng)用系統(tǒng)開發(fā)的基礎(chǔ)框架代碼,以“武漢大學(xué)本科生課程標(biāo)準(zhǔn)化考試系統(tǒng)”為例說(shuō)明生成工具搭建系統(tǒng)框架程序的過(guò)程,如下圖7所示:

    圖7 RDM代碼生成工具搭建系統(tǒng)框架程序?qū)?/p>

    圖8 .Net中生成的項(xiàng)目解決方案圖示

    過(guò)程說(shuō)明:(1)采用word文檔將系統(tǒng)的數(shù)據(jù)模型設(shè)計(jì)進(jìn)行文檔化并導(dǎo)入工具中轉(zhuǎn)換為標(biāo)準(zhǔn)數(shù)據(jù)模型對(duì)象;(2)生成數(shù)據(jù)庫(kù)建庫(kù)腳本SQL文件,在MS SQL Server2005中執(zhí)行并創(chuàng)建數(shù)據(jù)庫(kù);(3)按照.Net多層程序框架,依次生成應(yīng)用系統(tǒng)的Model層(模型層)、DAL層(數(shù)據(jù)存取層)、FacadeBLL層(基礎(chǔ)數(shù)據(jù)邏輯層)、UI層(基礎(chǔ)用戶界面層)代碼[3],見圖8;(4)在.Net開發(fā)工具VS2005中完成系統(tǒng)業(yè)務(wù)邏輯編程以及界面和程序的優(yōu)化.

    在此項(xiàng)目的實(shí)踐中,大約70%的程序代碼編寫工作轉(zhuǎn)變?yōu)楣ぞ呱桑蟠筇岣吡讼到y(tǒng)開發(fā)的效率,增強(qiáng)了代碼的穩(wěn)定性.

    6 結(jié)束語(yǔ)

    通過(guò)采用RDM代碼生成工具,可以形成一套完整的程序開發(fā)模式.通過(guò)在WORD文檔或直接在軟件中建立系統(tǒng)數(shù)據(jù)模型,使用此生成工具可以生成從數(shù)據(jù)庫(kù)創(chuàng)建SQL腳本文件,到.Net或J2EE開發(fā)平臺(tái)上的各層直接可編譯代碼文件,從而大幅度簡(jiǎn)化項(xiàng)目的代碼開發(fā)工作量.另通過(guò)在開發(fā)工具中增加對(duì)生成文檔和程序文件的自動(dòng)比對(duì)功能,則可識(shí)別出生成代碼中被維護(hù)的部分,從而在數(shù)據(jù)模型改變時(shí)可很快的遷移這部分修改,進(jìn)一步增強(qiáng)了代碼的可維護(hù)性.

    當(dāng)然,本文所描述的關(guān)系數(shù)據(jù)模型只是一個(gè)簡(jiǎn)化模型方案,若在此基礎(chǔ)上結(jié)合更多的數(shù)據(jù)模型特征或增加腳本語(yǔ)言的功能,則可進(jìn)一步提高生成代碼的質(zhì)量和生成工具的可適用性.

    參考文獻(xiàn):

    [1] 肖寒.J2EE平臺(tái)下代碼自動(dòng)生成技術(shù)研究[J].電腦知識(shí)與技術(shù),2009,5(20):5421-5422,5434.

    [2] 孫茂增,李鳳華,都婧.基于Velocity的J2EE應(yīng)用代碼生成系統(tǒng)[J].儀器儀表用戶,2008,15(1):105-106.

    [3] 陸遠(yuǎn),胡瑩..NET平臺(tái)下敏捷開發(fā)架構(gòu)及代碼生成技術(shù)[J].微計(jì)算機(jī)信息,2009(33):11-12,32.

    [4] 楊美榮,史建鋒,李明星.基于MDA 的代碼生成器設(shè)計(jì)與實(shí)現(xiàn)[J].計(jì)算機(jī)工程,2009,35(12):47-49,53.

    [5] 楊皓,楊忠,吳愚.基于XML腳本的代碼生成技術(shù)及其應(yīng)用[J].電腦知識(shí)與技術(shù),2009(7):7.

    猜你喜歡
    代碼生成數(shù)據(jù)模型腳本
    酒駕
    安奇奇與小cool 龍(第二回)
    Lustre語(yǔ)言可信代碼生成器研究進(jìn)展
    面板數(shù)據(jù)模型截面相關(guān)檢驗(yàn)方法綜述
    數(shù)據(jù)庫(kù)系統(tǒng)shell腳本應(yīng)用
    加熱爐爐內(nèi)跟蹤數(shù)據(jù)模型優(yōu)化
    快樂(lè)假期
    代碼生成技術(shù)在軟件開發(fā)中的應(yīng)用
    電子世界(2016年15期)2016-08-29 02:14:28
    基于XML的代碼自動(dòng)生成工具
    電子科技(2015年2期)2015-12-20 01:09:20
    面向集成管理的出版原圖數(shù)據(jù)模型
    精品久久久噜噜| 国精品久久久久久国模美| 国产午夜精品久久久久久一区二区三区| 亚洲精品aⅴ在线观看| 高清午夜精品一区二区三区| 一级毛片aaaaaa免费看小| 老师上课跳d突然被开到最大视频| 国产亚洲av片在线观看秒播厂 | 天天一区二区日本电影三级| 欧美潮喷喷水| 国产在线男女| 国产伦精品一区二区三区四那| 亚洲国产日韩欧美精品在线观看| 亚洲丝袜综合中文字幕| 夜夜爽夜夜爽视频| 国产一区有黄有色的免费视频 | 亚洲欧美成人精品一区二区| 久久久久久久久中文| 亚洲精华国产精华液的使用体验| 国产伦在线观看视频一区| 欧美高清成人免费视频www| 国产伦在线观看视频一区| 看十八女毛片水多多多| 亚洲最大成人中文| eeuss影院久久| 亚洲电影在线观看av| 亚洲精品aⅴ在线观看| 精品不卡国产一区二区三区| 国产男女超爽视频在线观看| 夫妻性生交免费视频一级片| av天堂中文字幕网| 天堂中文最新版在线下载 | av在线天堂中文字幕| 亚州av有码| 草草在线视频免费看| 国产成人福利小说| 国产亚洲午夜精品一区二区久久 | 国产欧美另类精品又又久久亚洲欧美| 人妻少妇偷人精品九色| 久久久色成人| 熟女人妻精品中文字幕| 午夜激情福利司机影院| 亚洲精品中文字幕在线视频 | 亚洲精品国产av成人精品| 91久久精品国产一区二区成人| 91精品伊人久久大香线蕉| 亚洲欧美清纯卡通| 亚洲国产色片| 青春草国产在线视频| 又爽又黄无遮挡网站| 嘟嘟电影网在线观看| 精品人妻一区二区三区麻豆| videos熟女内射| 欧美高清性xxxxhd video| 国产综合懂色| 久久久精品免费免费高清| 亚洲性久久影院| 九草在线视频观看| 色网站视频免费| 全区人妻精品视频| 肉色欧美久久久久久久蜜桃 | 国产毛片a区久久久久| 看十八女毛片水多多多| 高清午夜精品一区二区三区| 国产爱豆传媒在线观看| 国产精品无大码| 免费播放大片免费观看视频在线观看| 黑人高潮一二区| 精品久久国产蜜桃| 久久97久久精品| 国产精品嫩草影院av在线观看| 99热全是精品| 久久久久久久国产电影| 日日啪夜夜爽| 啦啦啦韩国在线观看视频| 国产日韩欧美在线精品| 精品久久久久久久人妻蜜臀av| 人妻一区二区av| 亚洲色图av天堂| 夫妻性生交免费视频一级片| 成年女人看的毛片在线观看| 久久久亚洲精品成人影院| 97人妻精品一区二区三区麻豆| 国内揄拍国产精品人妻在线| 亚洲精品色激情综合| 激情五月婷婷亚洲| 亚洲av一区综合| 一二三四中文在线观看免费高清| 日韩av在线大香蕉| av国产久精品久网站免费入址| 久99久视频精品免费| 中文字幕亚洲精品专区| 青春草国产在线视频| 欧美成人午夜免费资源| 亚洲在线自拍视频| 精品少妇黑人巨大在线播放| 精品国产露脸久久av麻豆 | 久久国产乱子免费精品| 国产精品一区二区性色av| 边亲边吃奶的免费视频| 精品熟女少妇av免费看| 只有这里有精品99| 黑人高潮一二区| 婷婷色综合www| 99热全是精品| 国产乱人偷精品视频| 天堂av国产一区二区熟女人妻| 十八禁网站网址无遮挡 | 精品一区二区三区人妻视频| 国产黄频视频在线观看| av免费在线看不卡| 舔av片在线| 国产在视频线精品| 啦啦啦啦在线视频资源| 国产日韩欧美在线精品| 精品少妇黑人巨大在线播放| 1000部很黄的大片| av国产免费在线观看| 国产精品日韩av在线免费观看| 久久久国产一区二区| 国产国拍精品亚洲av在线观看| 欧美一区二区亚洲| 禁无遮挡网站| 天堂俺去俺来也www色官网 | 日韩,欧美,国产一区二区三区| 99视频精品全部免费 在线| 国产黄频视频在线观看| 天堂√8在线中文| 一区二区三区四区激情视频| 亚洲av免费高清在线观看| 免费看日本二区| 国产淫语在线视频| 女人久久www免费人成看片| 亚洲精品乱码久久久久久按摩| 久久久成人免费电影| 搡老乐熟女国产| 久久久久九九精品影院| 99热6这里只有精品| 久久久a久久爽久久v久久| 欧美人与善性xxx| 午夜福利在线观看免费完整高清在| 亚洲乱码一区二区免费版| 亚洲av福利一区| 免费观看无遮挡的男女| 少妇人妻精品综合一区二区| 男女那种视频在线观看| 成年版毛片免费区| 日韩av在线免费看完整版不卡| 我的女老师完整版在线观看| 美女xxoo啪啪120秒动态图| 亚洲高清免费不卡视频| 能在线免费观看的黄片| 亚洲人成网站在线播| 成人欧美大片| 亚洲成人av在线免费| 国产精品无大码| 亚洲av成人av| 在线观看美女被高潮喷水网站| 亚洲高清免费不卡视频| 亚洲成人一二三区av| 日韩一区二区视频免费看| 插逼视频在线观看| 亚洲国产精品sss在线观看| 一级毛片电影观看| 精品一区二区三区视频在线| 亚洲av在线观看美女高潮| 欧美日本视频| 1000部很黄的大片| 日日撸夜夜添| 欧美成人a在线观看| 晚上一个人看的免费电影| av专区在线播放| 亚洲国产高清在线一区二区三| 日韩不卡一区二区三区视频在线| 乱人视频在线观看| 国产精品一区www在线观看| 高清毛片免费看| 中国美白少妇内射xxxbb| 久久热精品热| 国产精品一及| 国产av国产精品国产| 三级国产精品片| 秋霞伦理黄片| 国产永久视频网站| 最新中文字幕久久久久| 深爱激情五月婷婷| 久久久久网色| 女的被弄到高潮叫床怎么办| 日韩视频在线欧美| 全区人妻精品视频| 久久精品夜夜夜夜夜久久蜜豆| 欧美性猛交╳xxx乱大交人| 毛片女人毛片| 亚洲天堂国产精品一区在线| 亚洲最大成人中文| 91aial.com中文字幕在线观看| 777米奇影视久久| 国产精品熟女久久久久浪| 亚洲国产成人一精品久久久| 午夜免费男女啪啪视频观看| 亚洲电影在线观看av| 搡女人真爽免费视频火全软件| 听说在线观看完整版免费高清| 亚洲欧美中文字幕日韩二区| 欧美97在线视频| 一级毛片黄色毛片免费观看视频| 亚洲成人中文字幕在线播放| 一级毛片久久久久久久久女| 99热这里只有是精品在线观看| 一个人看视频在线观看www免费| 街头女战士在线观看网站| 激情 狠狠 欧美| 国产美女午夜福利| 成人欧美大片| ponron亚洲| 我的女老师完整版在线观看| 亚洲精品中文字幕在线视频 | 国产在线一区二区三区精| 免费大片黄手机在线观看| 91av网一区二区| 最近视频中文字幕2019在线8| 97精品久久久久久久久久精品| 欧美潮喷喷水| 三级国产精品欧美在线观看| 亚洲一级一片aⅴ在线观看| 色播亚洲综合网| 韩国高清视频一区二区三区| 午夜精品一区二区三区免费看| 永久网站在线| 有码 亚洲区| 人妻少妇偷人精品九色| 国产亚洲av片在线观看秒播厂 | 一级毛片 在线播放| 18禁裸乳无遮挡免费网站照片| 久久久久久久国产电影| 伊人久久精品亚洲午夜| 日本与韩国留学比较| 午夜亚洲福利在线播放| 国产视频内射| 天堂av国产一区二区熟女人妻| 中文天堂在线官网| 五月玫瑰六月丁香| 99久国产av精品国产电影| 国产成人a区在线观看| av天堂中文字幕网| 亚洲国产av新网站| 丰满少妇做爰视频| 免费黄网站久久成人精品| 亚洲欧美日韩东京热| 中文字幕av成人在线电影| 亚洲精品色激情综合| 能在线免费观看的黄片| 波多野结衣巨乳人妻| 中文天堂在线官网| 色综合站精品国产| 少妇人妻精品综合一区二区| 国产精品人妻久久久久久| 2021天堂中文幕一二区在线观| 91在线精品国自产拍蜜月| 成年av动漫网址| 国产精品1区2区在线观看.| 亚洲伊人久久精品综合| 国产精品久久视频播放| 国产在视频线在精品| 国产av码专区亚洲av| 亚洲精品色激情综合| 欧美xxxx黑人xx丫x性爽| 99久久人妻综合| 在线天堂最新版资源| 色吧在线观看| 午夜福利视频1000在线观看| 成人美女网站在线观看视频| 永久网站在线| 午夜激情久久久久久久| 熟女人妻精品中文字幕| 国产午夜精品一二区理论片| 1000部很黄的大片| 丰满乱子伦码专区| 国产视频内射| 日韩,欧美,国产一区二区三区| 亚洲欧美成人综合另类久久久| 嫩草影院入口| 色尼玛亚洲综合影院| 欧美最新免费一区二区三区| 美女黄网站色视频| 国产精品嫩草影院av在线观看| 欧美潮喷喷水| 纵有疾风起免费观看全集完整版 | 一区二区三区乱码不卡18| 欧美 日韩 精品 国产| 国产精品.久久久| 九九久久精品国产亚洲av麻豆| 高清欧美精品videossex| 久久这里有精品视频免费| 神马国产精品三级电影在线观看| 亚洲av电影在线观看一区二区三区 | 亚洲无线观看免费| 欧美日韩在线观看h| 欧美成人a在线观看| 国产成人a区在线观看| 天天躁夜夜躁狠狠久久av| 激情五月婷婷亚洲| av线在线观看网站| 高清午夜精品一区二区三区| 亚洲av男天堂| 在线 av 中文字幕| 成年女人在线观看亚洲视频 | 亚洲av国产av综合av卡| av在线天堂中文字幕| 精品久久久久久成人av| 内射极品少妇av片p| 成人国产麻豆网| 最近手机中文字幕大全| 啦啦啦韩国在线观看视频| 国产黄色免费在线视频| 久久精品久久精品一区二区三区| 久久人人爽人人片av| 搞女人的毛片| 免费播放大片免费观看视频在线观看| 最近手机中文字幕大全| 成年女人在线观看亚洲视频 | 精品人妻视频免费看| 久久韩国三级中文字幕| 精品人妻一区二区三区麻豆| 精品一区二区三区人妻视频| 亚洲精品国产成人久久av| 嘟嘟电影网在线观看| 免费无遮挡裸体视频| 美女黄网站色视频| av女优亚洲男人天堂| 日日摸夜夜添夜夜添av毛片| 免费播放大片免费观看视频在线观看| 一本久久精品| 可以在线观看毛片的网站| av播播在线观看一区| 大片免费播放器 马上看| 天堂网av新在线| 亚洲av国产av综合av卡| 欧美激情在线99| 久久久久久久亚洲中文字幕| 国产女主播在线喷水免费视频网站 | 搡老乐熟女国产| 精品99又大又爽又粗少妇毛片| 国产有黄有色有爽视频| 麻豆国产97在线/欧美| 男人狂女人下面高潮的视频| 国产白丝娇喘喷水9色精品| xxx大片免费视频| 麻豆精品久久久久久蜜桃| 亚洲成色77777| 亚洲国产欧美在线一区| 国产69精品久久久久777片| 亚洲av二区三区四区| 免费不卡的大黄色大毛片视频在线观看 | 国产 一区 欧美 日韩| 在线观看av片永久免费下载| 91精品伊人久久大香线蕉| 成人综合一区亚洲| 免费看a级黄色片| 嫩草影院入口| 青春草视频在线免费观看| 国产成人精品久久久久久| 我要看日韩黄色一级片| 精品久久久久久久久久久久久| 91久久精品电影网| 69av精品久久久久久| 一级爰片在线观看| 久久99精品国语久久久| 天美传媒精品一区二区| 九九爱精品视频在线观看| 永久免费av网站大全| 久久精品久久精品一区二区三区| 国产一区有黄有色的免费视频 | 激情 狠狠 欧美| 亚洲不卡免费看| 在线观看av片永久免费下载| 丝袜美腿在线中文| av专区在线播放| 亚洲精品成人久久久久久| 99久久精品国产国产毛片| 91精品一卡2卡3卡4卡| 高清日韩中文字幕在线| 三级国产精品片| 成人亚洲欧美一区二区av| 亚洲欧洲日产国产| 久久久久久久国产电影| 国内少妇人妻偷人精品xxx网站| 在线观看免费高清a一片| 国产欧美日韩精品一区二区| 美女主播在线视频| 99久久精品国产国产毛片| 91狼人影院| 日韩欧美三级三区| a级毛色黄片| 人人妻人人澡人人爽人人夜夜 | 51国产日韩欧美| 欧美不卡视频在线免费观看| 一边亲一边摸免费视频| 晚上一个人看的免费电影| 国产成人精品久久久久久| 国产综合精华液| 国产免费又黄又爽又色| 日韩中字成人| 国产麻豆成人av免费视频| 色网站视频免费| 色综合站精品国产| 久久久久久久久久久丰满| 欧美日韩在线观看h| 国产淫片久久久久久久久| 看十八女毛片水多多多| av一本久久久久| videos熟女内射| 亚洲乱码一区二区免费版| 婷婷色综合www| 搞女人的毛片| 777米奇影视久久| 亚洲av电影不卡..在线观看| 22中文网久久字幕| 欧美成人a在线观看| 亚洲无线观看免费| 日韩三级伦理在线观看| 中文字幕免费在线视频6| 汤姆久久久久久久影院中文字幕 | 免费人成在线观看视频色| 在线观看一区二区三区| 少妇熟女欧美另类| 免费观看av网站的网址| 日韩成人av中文字幕在线观看| 啦啦啦韩国在线观看视频| 男人舔女人下体高潮全视频| 欧美xxxx性猛交bbbb| 国产午夜福利久久久久久| 女人十人毛片免费观看3o分钟| 国产又色又爽无遮挡免| 亚洲精品色激情综合| 精品人妻一区二区三区麻豆| 婷婷色麻豆天堂久久| 最后的刺客免费高清国语| 色综合色国产| 国产亚洲午夜精品一区二区久久 | 99热这里只有是精品50| 哪个播放器可以免费观看大片| 亚洲人与动物交配视频| 大陆偷拍与自拍| 亚洲精品久久午夜乱码| 欧美高清成人免费视频www| 七月丁香在线播放| 欧美高清性xxxxhd video| 亚洲欧美精品专区久久| 午夜爱爱视频在线播放| 在线天堂最新版资源| 日韩成人av中文字幕在线观看| 可以在线观看毛片的网站| 我的女老师完整版在线观看| 国产精品爽爽va在线观看网站| 亚洲婷婷狠狠爱综合网| 久久精品熟女亚洲av麻豆精品 | 九色成人免费人妻av| 午夜激情欧美在线| 亚洲精华国产精华液的使用体验| 街头女战士在线观看网站| 国精品久久久久久国模美| 国产v大片淫在线免费观看| 亚洲av二区三区四区| 日本wwww免费看| 在线观看美女被高潮喷水网站| 色尼玛亚洲综合影院| 神马国产精品三级电影在线观看| 国产淫片久久久久久久久| 一级毛片黄色毛片免费观看视频| 天天躁日日操中文字幕| 欧美激情国产日韩精品一区| 一级毛片电影观看| 观看免费一级毛片| 国产成人a区在线观看| 国产午夜精品久久久久久一区二区三区| 一本一本综合久久| 国产精品久久久久久久电影| 国模一区二区三区四区视频| 久久久久国产网址| a级毛片免费高清观看在线播放| 国产成人精品一,二区| 久久久久久久久大av| 午夜精品国产一区二区电影 | 99久久九九国产精品国产免费| 国产高清国产精品国产三级 | 丝袜美腿在线中文| 中文资源天堂在线| 国产国拍精品亚洲av在线观看| 中文字幕人妻熟人妻熟丝袜美| 亚洲成人中文字幕在线播放| 日韩一区二区三区影片| 国产女主播在线喷水免费视频网站 | 国产黄色视频一区二区在线观看| 国产有黄有色有爽视频| 久久97久久精品| 亚洲无线观看免费| 激情五月婷婷亚洲| 成人欧美大片| 亚洲怡红院男人天堂| 欧美丝袜亚洲另类| 99视频精品全部免费 在线| 国产黄片视频在线免费观看| 国产精品99久久久久久久久| 国产成人精品婷婷| 国产一区有黄有色的免费视频 | av在线播放精品| 久久久久久久久久成人| 中国国产av一级| 中国美白少妇内射xxxbb| av一本久久久久| 波多野结衣巨乳人妻| 有码 亚洲区| av专区在线播放| 亚洲熟妇中文字幕五十中出| 国产成人精品一,二区| 中文精品一卡2卡3卡4更新| 又爽又黄a免费视频| 九九久久精品国产亚洲av麻豆| 成人二区视频| 精品人妻视频免费看| 免费看日本二区| 国产午夜精品久久久久久一区二区三区| 久久99热6这里只有精品| 久久久午夜欧美精品| 麻豆乱淫一区二区| freevideosex欧美| 三级毛片av免费| 亚洲av国产av综合av卡| 人妻少妇偷人精品九色| 国产av码专区亚洲av| 亚洲va在线va天堂va国产| .国产精品久久| 一区二区三区乱码不卡18| av福利片在线观看| 91精品伊人久久大香线蕉| 久久久久国产网址| 91在线精品国自产拍蜜月| 欧美激情久久久久久爽电影| 久久6这里有精品| 伦理电影大哥的女人| 91久久精品国产一区二区成人| 黄色一级大片看看| 国产黄片视频在线免费观看| 国产伦理片在线播放av一区| 男女国产视频网站| 联通29元200g的流量卡| 2018国产大陆天天弄谢| 国产色婷婷99| 九色成人免费人妻av| 亚洲三级黄色毛片| 日韩三级伦理在线观看| 国产色爽女视频免费观看| 菩萨蛮人人尽说江南好唐韦庄| 欧美日韩亚洲高清精品| 精品人妻视频免费看| 免费在线观看成人毛片| 男女边摸边吃奶| 最近的中文字幕免费完整| 亚洲av日韩在线播放| 好男人在线观看高清免费视频| 九九在线视频观看精品| 偷拍熟女少妇极品色| 伦精品一区二区三区| 亚洲精品久久午夜乱码| 日本熟妇午夜| 一夜夜www| 国产成人freesex在线| 国产高清有码在线观看视频| 国产探花极品一区二区| 深爱激情五月婷婷| 欧美日本视频| 听说在线观看完整版免费高清| 日韩在线高清观看一区二区三区| 噜噜噜噜噜久久久久久91| 在线播放无遮挡| 一级毛片久久久久久久久女| 中国美白少妇内射xxxbb| 青青草视频在线视频观看| 欧美人与善性xxx| 亚洲精品久久午夜乱码| 天天一区二区日本电影三级| 欧美日韩视频高清一区二区三区二| 欧美日本视频| 欧美一区二区亚洲| 一个人看视频在线观看www免费| 日本av手机在线免费观看| 岛国毛片在线播放| 精品久久久精品久久久| 亚洲欧美精品自产自拍| 亚洲人与动物交配视频| 国产三级在线视频| 中文字幕制服av| 国产成人91sexporn| 国产成人精品一,二区| 精品一区在线观看国产| 在线播放无遮挡| 免费观看性生交大片5| 国产精品1区2区在线观看.| 亚洲va在线va天堂va国产| 两个人的视频大全免费| 久久久久性生活片| 久久精品久久久久久噜噜老黄| 国产大屁股一区二区在线视频| 亚洲av成人av| 91狼人影院| 欧美成人一区二区免费高清观看| 永久网站在线| 国产精品国产三级国产专区5o| 精品久久久久久久久亚洲| 亚洲av在线观看美女高潮| av又黄又爽大尺度在线免费看| 免费av观看视频| 色播亚洲综合网| 三级国产精品欧美在线观看|