《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 設計應用 > 基于IOC的GUI框架設計與實現
基于IOC的GUI框架設計與實現
來源:微型機與應用2011年第10期
廖福保, 張文梅
(廣東農工商職業技術學院 計算機科學系, 廣東 廣州510507)
摘要: 傳統的圖形用戶界面GUI(Graphics User Interface)設計中,存在過度耦合、組件與事件之間的映射關系混亂等問題。對此,提出了基于控制反轉(IOC)的GUI框架,該框架采用Java反射機制,解析xml配置文件完成組件實例化、組件添加事件監聽。實驗表明,利用該框架建立的GUI實現了業務對象的松散耦合,組件和事件處理方法分離,縮短開發周期,具有較高的可擴展性。
Abstract:
Key words :

摘  要:傳統的圖形用戶界面GUI(Graphics User Interface)設計中,存在過度耦合、組件與事件之間的映射關系混亂等問題。對此,提出了基于控制反轉(IOC)的GUI框架,該框架采用Java反射機制,解析xml配置文件完成組件實例化、組件添加事件監聽。實驗表明,利用該框架建立的GUI實現了業務對象的松散耦合,組件和事件處理方法分離,縮短開發周期,具有較高的可擴展性。
關鍵詞:控制反轉;圖形用戶界面;Java反射機制

    Java是目前最優秀的軟件開發語言之一,由于其結構簡單、面向對象、跨平臺等優越特性使它具有極強的生存力,并得到了廣泛的應用。基于Java的圖形用戶界面(GUI)中,AWT是Java提供的用來建立和設置Java圖形用戶界面的第一代開發工具。AWT由java.awt包提供,其中包含了許多可以用來建立與平臺無關的GUI類。由于AWT組件占有系統資源較多,常把java.awt組件稱為重量級組件。Java Swing是Java Foundation Classes(JFC)的一部分,解決了AWT的很多缺點,相對于AWT,Swing是輕量級組件。Swing提供了許多比AWT更好的屏幕顯示元素,使用純Java寫成,與Java一樣可以跨平臺運行[1]。
    圖形用戶界面(GUI)借助于多種組件,包括菜單、按鈕、文本框、選擇框、列表框等,通過相應的事件處理機制,實現與用戶的動態交互。
1  圖形用戶界面的建立
1.1 創建GUI窗口

    javax.swing.JFrame類是用來建立用戶界面的底層窗口容器,能夠容納其他組件的對象,如標簽、按鈕、文本組件等。JFrame類提供的add()方法把不同的組件添加到容器中,通過容器類的setLayout()方法可以設定容器的布局,安排各種組件在容器中。
    使用JFrame類創建GUI窗口的基本步驟如下:用JFrame類或其子類創建一個對象即窗體;設置窗口的部分屬性,如標題、寬度、高度、可見性、圖標等;添加內容面板、組件;編寫事件處理方法;組件添加事件監聽。
1.2 Java事件處理
    在Java中,程序與用戶的交互通過響應各種事件來實現。每當一個事件發生,Java虛擬機就會將事件的消息傳遞給程序,由程序中的事件處理方法對事件進行處理。Java通過委托型事件處理機制來解決對事件的響應。
    事件處理機制可表述如下[2]:事件源對象封裝了事件源、組件狀態等必要信息;當事件源對象發生改變時,向它所注冊的所有監聽器發出通知,各監聽器判斷事件類型是否為自己管轄范圍,若是,則通知給該監聽器的執行器,執行器從事件中獲取事件信息,并執行相應函數,改變組件的狀態。
1.3 傳統創建窗口和事件處理的局限性
    在傳統的GUI創建過程中,存在一些局限性。
    (1)組件創建、添加都采用硬編碼方式,造成程序的過度耦合。
    (2)如果窗體中有很多組件,組件要添加注冊監聽,則在代碼中看到很多重復注冊監聽的代碼,而這些注冊監聽的代碼都與界面本身設計無關,組件與事件之間的映射關系將會很混亂。
    (3)事件處理方法定義在別的類中,無法得到窗體及其組件的引用,只能得到事件源,而無法改變其他組件的狀態;或者把事件處理與窗體設計放在一起,這樣程序的可維護性又不好。
    (4)不利于代碼重用,基于MVC的思想,應該把事件處理方法分離出來;在需要修改事件處理代碼時,就無需修改界面本身的源代碼。
2  圖形用戶界面設計的改進
2.1 控制反轉(IOC)

    IOC就是控制反轉[3](Inversion of Control)的縮寫,也稱為依賴注入,控制反轉IOC是一種用于控制業務對象之間依賴關系的機制,將其設計的類與類之間的關系都交由外部容器進行管理,僅需調用類在容器中注冊的名字就可以得到類的實例,有效降低了業務對象之間的依賴程度,實現了業務對象之間的松散耦合。
    IOC的實際意義就是把組件之間的依賴關系(調用關系)反轉出來,對象之前的依賴關系用xml配置文件描述;這樣,各個組件之間就不存在硬編碼的關聯,任何組件都可以最大程度地得到重用。
    考慮如下接口和類的定義:
    public interface ICar{void operate();}
    public class Toyota implements ICar{…}
    public class Honda implements ICar{…}
    public class Driver{
        private ICar car;
        public void setCar(ICar car){this.car = car;}
        public ICar getCar(){return car;}
        public void drive(){car.operator();}
    }
    類Driver依賴于ICar,而類Toyota和Honda實現了接口ICar,即類Driver可以依賴于Toyota或Honda。
    運用了IOC模式后就不再需要自己管理組件之間的依賴關系,只需要聲明由xml配置文件描述去實現這種依賴關系,就好像把對組件之間的依賴關系的控制進行了倒置,不再由組件自己來建立這種依賴關系而是交給xml配置文件去管理。
2.2 設計的改進
       在改進的GUI編程中,把窗體中組件的創建、組件的外觀設置和組件觸發事件時執行什么方法,不是以硬編碼的方式組合在一起,而是通過配置文件來配置。這樣開發人員無須關心組件的創建、組件的樣式設置、事件的監聽與實現,只需要設置相應的get、set方法來存取組件、屬性等,事件處理方法能在任意類中實現,方法名可以自定義,并且在其他類中能夠得到窗體對象及其組件的引用。當組件的樣式發生改變時,只需改動配置文件即可。
     該改進設計通過配置文件,并利用控制反轉和Java反射機制得以實現,這就需要有框架和良好的設計。
3 框架運行機理
     框架中各組成部分在運行過程中的調用關系如圖1所示。


    當程序入口啟動時,框架解析bean-config.xml文件;組件工廠類根據xml配置文件創建各種組件對象;組件外觀設置類查找xml文件為每個組件設置相應的外觀;事件監聽器類查找xml文件為每個組件添加對應的事件監聽器;事件執行類查找xml文件為每個組件設置事件觸發時執行的方法;最后還需要一個保存窗體對象的類。
        GUI程序開發人員只需要設置相應的get、set方法來存取組件,事件發生時要執行的方法和配置xml文件。組件的建立、外觀的設置、事件監聽添加、事件處理方法都由框架來完成。一個編碼的例子如下:
         public class JFrameDemo extends JFrame{
             private JTextField input ;
             private JButton ok ;
             //省略的get, set方法
             //省略構造方法,該方法用于添加組件到窗體
        }
         //事件處理類和方法
         public class EventOperator{
        public void operate(){
            //從保存窗體對象的類中獲得窗體
            //通過窗體的get方法獲得組件
            //執行所需的操作并修改組件狀態
        }
     }

 


4 框架的具體實現
4.1 xml配置文件格式

      xml是一種標記語言,用于各種配置文件和不同語言間交換信息,它只負責信息的存儲,而不負責信息的表達。本框架bean-config.xml文件的設計格式如下:
     <?xml version="1.0" encoding="GB2312"?>
     <beans>
        <bean id="input" class="java.awt.JTextField">
            <setColumns>10;Integer</setColumns>
        </bean>
        <bean id="ok" class="java.awt.JButton">
            <setText>計算;String</setText>
            <event type="ActionListener" class="test.Event-
                Operator" method="operate"></event>
        </bean>
        <bean id="frame" class="test.JFrameDemo">
            <ref>input</ref>
            <ref>ok</ref>    
        </bean>
         </beans>
    配置文件說明如下:
    (1)根節點為beans。
    (2)bean節點中的id屬性用來唯一地標識一個組件,該值要與代碼里的組件名一致,class屬性用來表示所對應的類名。
    (3)event節點的type屬性表示監聽器的類型, class屬性表示事件觸發時將要執行的方法所對應的類名,method屬性表示事件觸發時將要執行的方法。如上面xml文件中,表示當ok組件發生單擊事件時,將執行test. EventOperator類的operate方法。
    (4)ref子節點值表示該組件需要依賴的其他bean的標識。
    (5)bean其他子節點為設置組件外觀的方法,子節點值為調用該方法所需的參數值和對應的參數類型。
4.2 Java的反射機制
    因為所對應的類、方法都保存在xml文件中,而對xml解析得到的類名和方法名都是字符串類型,要把字符串實例化成相應的對象并調用就要用到Java的反射技術[4]。
    Java的反射機制允許程序在運行時透過Reflection APIs取得任何一個已知名稱的類的內部信息,包括其訪問權限、父類、實現接口,也包括成員變量和方法的所有信息,并可在運行時改變成員變量的內容或執行方法。
    本框架主要利用反射機制來實例化對象和調用方法。其關鍵代碼如下(className,methodName均為字符串):
       Class instance = Class.forName(className).newInstance();
                //獲得目標類實例,傳入目標類名及包名
         Class c = Class.forName(className);
         Method m = c.getMethod(methodName,new Class[]{...});
                        //傳入方法名和參數類型數組
         m.invoke(instance, new Object[]{});
        //方法執行,傳入目標類的實例和方法參數值數組
4.3 xml文件處理器
    xml文件處理器主要用于對bean-config.xml文件進行解析, 本框架采用jdk1.5自帶的 org.w3c.dom包來解析xml文檔,為文檔對象模型(DOM) 提供接口。
     xml文件處理器根據傳入的xml文件生成Document節點,Document可看做是xml在內存中的一個鏡像,對Document操作能夠直接同步到該xml文件。關鍵代碼如下:
    DocumentBuilderFactory dbf=DocumentBuilderFactory.new
        Instance();    
  DocumentBuilder db=dbf.newDocumentBuilder();    
                    //通過工廠得到一個DocumentBuilder    
  Document doc=db.parse("bean-config.xml");         
    //DocumentBuilder通過解析xml文件得到一個Document
4.4 組件工廠類的實現
    根據xml文件的bean節點建立組件對象,首先利用Document的getElementsByTagName方法獲得所有bean節點的NodeList對象,遍歷NodeList對象獲得每個bean節點的Node對象,再利用Node的getAttributes方法獲得該節點的所有屬性,然后根據獲得的id、class屬性就可以實例化組件。關鍵代碼如下:
  NodeList nodes = doc.getElementsByTagName("bean");
                                //獲得所有的bean節點
    ... ...
  Node node = nodes.item(i);//獲得其中一個bean節點        NamedNodeMap attributes = node.getAttributes();
                                     //取出該節點的所有屬性值
      ... ...
    Class cl = Class.forName(class屬性值);                     Object instance = cl.newInstance();    //創建該類的實例
4.5 組件外觀設置類實現
    從組件工廠類中獲得組件對象并從xml文件中獲得的方法名、參數值和參數類型,利用Java反射技術就可以為組件執行方法設置組件外觀。
4.6 事件執行類
    事件執行類繼承多個事件接口,同時實現接口對應的方法。在每個實現的方法中,獲得xml文件中event節點的class屬性值以及method屬性值,利用Java反射技術就可以執行方法。這時當組件觸發事件時,執行事件執行類的對應方法,而事件執行類的方法是調用method屬性值的方法。這樣就實現了當組件觸發事件時,執行method屬性值的方法。
     通過事件執行類,可以自定義觸發事件時執行的方法名,實現了事件監聽與事件處理的分離。事件執行類采用單例模式實現即僅有一個實例運行,節省了內存消耗。
4.7 事件監聽器添加類
     傳統GUI編程中,事件監聽器的添加是利用組件調用相應的方法,并傳入對應的事件監聽器對象。在本框架事件監聽器添加類中,首先獲得event節點的type屬性值,通過Java反射技術把事件執行類實例添加到組件中,這樣當組件觸發事件時就可以執行事件執行類的相關方法。
    在GUI設計中將組件設計和事件處理交予本文框架管理,降低了對象之間的依賴程度。在代碼中僅需要編寫get、set方法,也不需注冊監聽器、實現接口等代碼,減少了代碼編寫量,實現了業務對象的松散耦合。事件觸發和事件執行實現了分離,提高了程序的可維護性。對組件狀態或事件信息的改變不需修改源代碼,只需要修改配置文件,易于實現重構。
    實踐表明,該框架簡單易用,建立的圖形用戶界面(GUI)具有較高的靈活性、可維護性和可擴展性,對構建中小型的GUI應用具有良好的支撐作用和借鑒意義。
參考文獻
[1] 錢銀中.Java程序設計案例教程[M]. 北京:機械工業出版社,2010.
[2] 宋淼,袁兆山,陳剛.Java事件處理機制中設計模式的分析[J].安徽工業大學學報,2004,27(11):1383-1386.
[3] 魏學松,張育平.IOC框架的研究與設計[J]. 計算機技術與發展,2006,16(3):213-216.
[4] 吳其慶. Java編程思想與實踐[M]. 北京:冶金工業出版社,2006.

此內容為AET網站原創,未經授權禁止轉載。
主站蜘蛛池模板: 天天综合在线观看 | 久久亚洲国产成人精品性色 | 天天做爰裸体免费视频 | 男人靠女人免费视频网站 | 日本老小玩hd老少配 | 国产高清av在线播放 | 国产香蕉在线观看 | 国产极品美女高潮抽搐免费网站 | 久久天天躁夜夜躁狠狠躁2022 | 国产亚洲精品久 | 亚洲国产精品午夜久久久 | 国产成人精品123区免费视频 | 亚洲xxxx做受欧美 | 人人看人人做 | 日日碰狠狠躁久久躁蜜桃 | 亚洲国产精品免费 | 欧美成人免费 | caopeng在线视频 | 久久天天躁狠狠躁夜夜网站 | 艳妇臀荡乳欲伦交换在线播放 | 亚洲午夜无码久久久久 | 国产精品久久久久久亚洲徐婉婉 | 国产精品一区二区不卡 | 色综合天天操 | 亚洲a∨国产av综合av下载 | 国产又粗又硬又大爽黄 | 精品蜜桃一区二区三区 | 国产伦理五月av一区二区 | 日本老少配xxx | 色五月丁香六月欧美综合 | 肥白大屁股bbwbbwhd | 日韩精品a片一区二区三区妖精 | 亚洲色av性色在线观无码 | 激情综合五月丁香亚洲 | 狠狠色噜噜 | 久久婷婷五月综合色丁香 | 日批视频 | 中文字幕在线播放一区 | 红桃av永久久久 | 玖玖热视频 | 亚洲综合少妇 | 性欧美长视频 | 欧美日韩精品 | 尤物精品 | 97在线国产 | 动漫卡通精品一区二区三区介绍 | 成人免费视频国产免费网站 | 国产精品无码av天天爽 | 黄色大片免费在线观看 | 国产v亚洲v天堂无码久久久 | 超碰人人澡 | 特黄特色免费视频 | 女性向av免费网站 | 2018天天干天天射 | 6080啪啪 | 亚洲日本国产 | 中文字幕一精品亚洲无线一区 | 69久久久成人看片免费一区二 | 日韩亚洲在线观看 | 翔田千里高潮在线播放 | 久久免费视频1 | 中日韩在线视频 | 欧美一级免费在线观看 | 亚洲 另类 熟女 字幕 | av网页在线观看 | 国产精品理论片 | 小辣椒福利视频导航 | 少妇被粗大的猛进69视频 | 国产美女视频国产视视频 | 漂亮人妻被中出中文字幕久久 | 99在线播放视频 | 国产免费丝袜调教视频 | 黄色小视频在线看 | 欧产日产国产精品乱噜噜 | 精品二区在线观看 | 国产又黄视频 | 狠狠躁夜夜躁人人躁婷婷视频 | 让少妇高潮无乱码高清在线观看 | 两根大肉大捧一进一出好爽视频 | 性猛交xxxx乱大交3 | 国产黄色精品视频 | 亚洲精品国偷拍 | 凹凸精品熟女在线观看 | 国产精品成人亚洲一区二区 | 精品国产乱码久久久久久1区二区 | 男女性网站 | 欧美精品在线观看 | 国产真实乱对白精彩久久小说 | 日本中文字幕一区二区有码在线 | 香蕉网久久 | 国产最新进精品视频 | 国产福利萌白酱在线观看视频 | 另类αv欧美另类aⅴ | 亚洲精品粉嫩美女一区 | 国精产品一品二品国精品69xx | 蜜臀91丨九色丨蝌蚪中文 | 免费又黄又爽又猛的毛片 | 日女人毛片| 俺来也俺来啦awww官网 | 最新中文字幕免费视频 | 18成人在线观看 | 无遮挡1000部拍拍拍免费 | 蜜臀999| 久久久久人妻精品一区三寸蜜桃 | 日本欧美一区二区免费视频 | 亚洲精品一品区二品区三品区 | 国产伦精品一区二区三区免.费 | 亚洲不卡中文字幕无码 | 在线成人亚洲 | 日本一区二区三区高清在线观看 | 久久久久久久免费看 | 欧美性猛交99久久久久99按摩 | 欧美成人精品欧美一级私黄 | 黄色激情小说视频 | 偷拍网亚洲 | 一本一道人人妻人人妻αv 自拍日韩亚洲一区在线 | 涩涩的视频网站 | 玖玖在线 | 一本一道精品欧美中文字幕 | www国产亚洲精品久久久日本 | 无码一区二区三区av免费 | 香蕉午夜福利院 | 日韩中文字幕2019 | 色就是色欧美 | 情欲少妇人妻100篇 国产精品日韩av在线播放 | 亚洲人成电影网站色 | 久久免费少妇做爰 | 久久久久久97免费精品一级小说 | 亚洲中文字幕无码专区 | 成人18视频 | 国产精选视频在线观看 | 国产成人免费看 | 亚洲一二三四五 | 国产三香港三韩国三级古装 | 国产69精品久久久久9999apgf | 少妇高潮18zzzzzzzyⅹ | 婷婷午夜天 | 在线网站av| 青青草在线免费 | 偷拍夫妻性生活 | 免费在线看污 | 天使萌一区二区三区免费观看 | 亚洲精品无码永久在线观看你懂的 | 69日本xxxxxxxx96| 乱子伦一区二区三区 | 91精品91久久久中77777 | 深爱激情五月婷婷 | 老头吃奶性行交 | 国产精品成人免费视频一区二区 | 久久综合91 | 免费体验区试看120秒 | 在线视频资源 | 又粗又硬又猛又黄网站在线观看高清观看视频 | 中文字幕中文在线 | 免费看中国毛片 | 粉嫩av四季av绯色av | 一区二区三区在线播放视频 | 成人a视频片观看免费 | 国产精品人人爽人人做av片 | 亚洲国产精品福利 | 日本一级淫片免费看 | 黄色成人免费网站 | 亚洲精品热 | 成人国内精品久久久久影院成人国产9 | 日日草夜夜草 | 九九久久九九久久 | 99蜜桃在线观看免费视频网站 | 在线观看免费av网 | 天堂中文视频在线 | 国产a级免费视频 | 欧美交换配乱吟粗大在线观看 | 国产激情精品一区二区三区 | 欧美z○zo重口另类黄 | 美女尻逼视频 | 两个人看的www在线观看 | 亚洲色图18p| 一本色综合亚洲精品88 | 亚洲中文字幕av无码区 | 在线五月天| 亚洲精品综合一区二区三区在线 | 国产精品一区二区香蕉 | 欧美在线激情 | 欧美一级一级 | aaaaaabbbbbb毛片| 亚洲瑟瑟 | 成人欧美一区二区三区黑人 | 日本美女上床 | 爱爱视频在线免费观看 | 亚洲 另类 春色 国产 | 国产成人秘密网站视频999 | 久久国产这里只有精品 | 丰满人妻在公车被猛烈进入电影 | 天天夜碰日日摸日日澡性色av | 久久婷婷五月综合色丁香 | 亚洲国产一区二区三区 | av播放在线 | 亚洲中文无码av永久 | 国产三级做爰在线播放 | 免费高清毛片 | 欧美成人国产精品高潮 | 日本在线视频www鲁啊鲁 | 亚洲色图视频在线观看 | 国产69精品久久久久人妻刘玥 | 亚洲性无码av中文字幕 | 朝鲜交性又色又爽又黄 | 日韩欧美一级在线 | 国产女上位 | 亚洲色欲久久久综合网东京热 | 人妻激情偷乱视频一区二区三区 | 顶级尤物极品女神福利视频 | 欧美3p激情一区二区三区猛视频 | 拔插拔插海外华人免费视频 | 久久精品国产成人av | 成人女同av免费观看 | 国产欧美又粗又猛又爽老小说 | 丰满少妇被猛烈进入高清播放 | 波多野结衣视频播放 | 欧美激情第五页 | www.涩涩爱| 亚洲欧美一区二区三区视频 | 窝窝午夜精品一区二区 | 精品国产一区二区三区av 性色 | 大桥未久中文字幕 | 91国内精品自线在拍白富美 | 无码专区人妻系列日韩 | 性少妇videoxxⅹ中国69 | 久久久国产精品入口麻豆 | 亚洲乱码国产乱码精品天美传媒 | 国产乱淫精品一区二区三区毛片 | 精二青青河边草解释正确的是 | 国语粗话呻吟对白对白 | 国产精品99久久久久久人 | 色妞www精品免费视频 | 日韩亚洲欧美在线 | 菠萝蜜视频在线观看入口 | 性一交一乱一乱一视频 | 国产在线123 | 亚洲人毛耸耸少妇xxx | 色吊丝永久性观看网站 | 亚洲视频二 | 亚洲综合久| 国产熟女一区二区三区四区五区 | 成人免费在线观看网站 | 久久丁香| 国产又大又硬又粗 | 欧美激情15p | 国产精品久久777777 | 综合久久综合 | 欧美成人三级 | 国产在线精品一区在线观看 | 中文字幕亚洲乱码熟女一区二区 | 日韩欧美群交p片內射中文 三级4级全黄60分钟 | 在线黄色网 | 亚洲最大成人综合 | 天海翼一区二区三区四区演员表 | 欧美性猛交xxxx乱大交蜜桃 | 欧洲女女同videos| 91亚洲成人 | 国产九九热| 日产一二三四五六七区麻豆 | 亚洲第一成年人网站 | 色婷婷狠狠五月综合天色拍 | 三级三级三级a级全黄公司的 | 侵犯亲女在线播放视频 | 国产94在线 | 亚洲 | 欧美激情日韩 | 国产无套精品一区二区三区 | 国产剧情一区 | 亚洲一区二区三区无码久久 | 欧美xxxx黑人又粗又长精品 | 日产欧美一区二区三区不上 | 美女爆吸乳羞羞免费网站妖精 | 日本国产在线 | 国产精品无码不卡一区二区三区 | 青青操精品 | 日本免费人成视频播放 | 99视频| 日日摸夜夜添夜夜躁好吊 | 成人影院中文字幕 | www.av日韩| 韩国三级hd中文字幕 | 绯色av粉嫩av蜜臀av | 久久久久久国产精品免费免费男同 | 日本黄网站色大片免费观看 | 色综合久久久久久久久五月 | 国产无遮挡又黄又爽又色 | 久久看毛片 | 国产成人三级一区二区在线观看一 | 少妇的丰满3中文字幕 | 久久久久国产一区二区 | 欧美日韩精品久久久免费观看 | 99热免费| 精品美女一区二区三区 | 欧美午夜精品久久久久久人妖 | www99热| 求毛片网站 | 青青草国产成人av片免费 | 亚洲精品久久久久999中文字幕 | 老熟仑妇乱一区二区 | 污污的网站在线观看 | 色综合天天综合网天天狠天天 | 久久久久久亚洲综合影院红桃 | 又色又爽又大免费区欧美 | 国产在线一二三区 | 亚洲乱码国产乱码精品精小说 | 国产99精品视频 | av一卡二卡 | 亚洲人成网站18禁止 | 亚洲精品国产乱码久久久1区 | 性仑少妇av啪啪a毛片 | 中文人妻无码一区二区三区信息 | 性久久久 | 人禽杂交18禁网站免费 | 久久精品人妻少妇一区二区三区 | 中文字幕 欧美日韩 | 亚洲第一色在线 | 丁香婷婷色 | 最新视频 - 88av| 杂技xxx裸体xxxx欧美 | 欧美成人高清在线 | 强开小婷嫩苞又嫩又紧视频韩国 | 精品乱子伦一区二区三区 | 在线色图 | 免费日韩一区二区 | 亚洲精品第一区二区三区 | 亚洲一区二区福利视频 | 精产国品一二三产区m553麻豆 | 性欧美老妇另类xxxx | 亚洲我射av | 三级av网站| 少妇特黄a一区二区三区 | 欧美成人精品激情在线观看 | 特大黑人巨交吊性xxxxhd | 无码里番纯肉h在线网站 | 99精品国产99久久久久久51 | 丁香六月激情 | 国产一区二区三区在线免费 | 青娱乐欧美 | 国产色视频一区二区三区 | 中国人与拘一级毛片 | 1级黄色大片儿 | 黑人一区 | 日韩欧美中文字幕在线观看 | 国产成人三级一区二区在线观看一 | 天天射av | 国模裸体无码xxxx视频 | 日本人与黑人做爰视频网站 | 妞妞色www在线精品观看视频 | 久草成人在线 | 日日操日日碰 | 黄网在线播放 | 色婷婷一区 | 日韩中文一区二区 | 美日韩在线| 亚洲国产精品婷婷 | a在线观看免费 | 欧美国产日韩在线观看成人 | 欧美人与禽zoz0性伦交 | 中文字幕日韩欧美一区二区 | 久久亚洲精品中文字幕无男同 | 精品一区精品二区 | 日本又色又爽又黄的大片 | 色婷婷一区二区三区四区 | 性女次台湾三级 | 夫妻啪啪呻吟x一88av | www色午夜com | 成人免费无码大片a毛片软件 | 丰满人妻熟妇乱又伦精品软件 | 国产三级在线 | 日本a级c片免费看三区 | 青青草视频偷拍 | 神马香蕉久久 | 在线涩涩| 无码任你躁久久久久久 | 无码乱人伦一区二区亚洲 | 国产一区二区三区小说 | 无尽3d精品hentai在线视频 | 九九福利 | 欧美激情视频二区 | 色一情一交一乱一区二区三区 | 国产乱国产乱300精品 | 亚洲欧美日韩久久精品 | 青青久在线视频免费观看 | 精品久久人人妻人人做精品 | 一本—道久久a久久精品蜜桃 | 欧美肥妇多毛bbw | 91精品国产闺蜜国产在线闺蜜 | 精品视频一区二区三区在线观看 | 免费一区| 精品推荐国产精品店 | 亚洲天堂一级 | 久久国产成人午夜av影院 | 性歌舞团一区二区三区视频 | 亚洲啊啊啊啊啊 | 欧美天天综合色影久久精品 | 涩涩免费网站 | 91久久人人夜色一区二区 | 国产一区二区片 | 熟妇人妻av无码一区二区三区 | 免费色片| 亚洲一级一级一级 | 热玖玖| 永久福利视频 | 男女做爰全过程免费视频播放 | 男人猛躁进女人免费视频夜月 | 我要色综合网 | 怡红院av久久久久久久 | 久久艹综合 | 欧美裸体xxxx极品少妇 | 成人一级大片 | 欧美人人爽 | 欧美日韩一区二区三区四区五区 | 青青草国产在线观看 | 久草美女| 国产精品香蕉在线观看 | 亚洲精品黄色 | 在线看中文字幕 | 91精彩视频在线观看 | 亚洲成人激情小说 | 亚洲国产精品久久久久秋霞影院 | 中文字幕老妇偷乱视频在线小说 | 91社区在线播放 | 一区免费在线 | 国产中年夫妇交换高潮呻吟 | 夫妻性生活黄色大片 | 福利在线视频观看 | 日韩一二三区在线 | 欧美草b| 国产精品黄在线观看免费软件 | 欧美最新精品videossexohd | 国产午夜福利100集发布 | 性色一区 | 国产精品毛片大码女人 | 亚洲国产精品成人精品无码区在线 | 精品一区日韩 | 51福利视频 | 国内毛片精品av一二三 | 欧美一级欧美三级在线观看 | 北条麻妃在线一区二区韩世雅 | 日日爱886 | 国产精品毛片一区 | 亚洲精品一区二区另类图片 | 一个人在线观看免费视频www | 国产在线播放一区二区 | 亚洲天堂成人在线观看 | 99国产精品免费播放 | 无码东京热一区二区三区 | 丰满爆乳在线播放 | 综合三区后入内射国产馆 | sm在线看| 精品成人免费视频 | 激情综合五月婷婷 | 精品日产乱码久久久久久仙踪林 | 国产一二三在线视频 | aaaaa一级片| 九九在线观看视频 | 欧美在线综合 | 不卡在线| 在线国产一区二区三区 | 久久亚洲欧美国产精品 | 成人精品视频一区二区 | 欧美日韩激情在线一区二区三区 | 亚洲精品久久久艾草网 | 色哟哟一区二区三区精华液 | 99re热这里只有精品视频 | 91夫妻视频 | 国产成人精品白浆久久69 | 国产免费看插插插视频 | 久久亚洲区 | 天天天天天天天天干 | 日日色综合 | xxxx性视频 | 天天色小说 | 福利视频99 | 丰满人妻被黑人猛烈进入 | 国产精品视频免费看人鲁 | 波多野结衣免费在线视频 | 亚洲福利视频在线 | 中文字幕av手机版 | 国产无套精品一区二区 | 国产精品久久久国产偷窥 | 性欧美一级毛毛片a | 午夜插插插| 国产精品影音先锋 | 色综合久久久久综合一本到桃花网 | www.se天堂| 伊人www| 中文字幕无码乱码人妻系列蜜桃 | 色综合自拍| 成人小片 | 偷拍中年夫妇激情嗷嗷叫 | 亚洲日韩精品a∨片无码 | 直接看的av| 网址av| 狠狠撸狠狠干 | 国产精品日日做人人爱 | 一本色道久久hezyo加勒比 | 136微拍宅男导航在线 | 国产一区二区福利 | 国产成人免费ā片在线观看 | 波多在线播放 | 亚洲一区二区三区无码国产 | 国产成人免费高清激情视频 | 拔擦拔擦8x国产精品免费 | 国产精品午夜一区二区三区视频 | 中文天堂网| 视频丨9l丨白浆 | 97色碰碰公开视频 | 国产中文 | 噜噜噜在线 | awww在线天堂bd资源在线 | 亚洲国产天堂久久综合 | 五月天婷婷爱 | 国产淫 | 性感美女毛片 | 色偷偷成人 | 性做爰过程免费视频美女按店 | www一级片| 久久久久久国产精品免费免费 | 日韩人妻无码一区二区三区99 | 蜜桃国精产品二三三区视频 | 九九九视频在线观看 | 国产乱国产乱 | 成人羞羞在线观看网站 | 欧美一级性生活 | 久久精品国产精品青草 | 国产精品无人区一区二区三区 | 四川骚妇无套内射舔了更爽 | 亚洲精品99久久久久中文字幕 | 色婷婷六月天 | 夜夜嗨av一区二区三区网页 | av影视天堂 | 久久99国产综合精品 | 一本久久综合亚洲鲁鲁五月天 | 成人做爰69片免费看网站 | 女人被狂躁到高潮视频免费软件 | 农村乱人伦一区二区 | 国偷自产一区二区三区蜜臀 | 少妇二级淫片免费 | 国产黄色片免费看 | bnb99八度免费影院 | 91精品久久久久久综合乱菊 | 五月天亚洲综合 | 亚洲国产精品无码久久98 | 成人a级做爰生活片 | 国产伦子伦对白视频 | 成人免费观看49www在线观看 | 老司机久久精品视频 | 国产欧美精品日韩区二区麻豆天美 | 欲妇荡岳丰满少妇岳 | 夜夜爽日日澡人人添蜜臀 | 亚洲成a人片777777久久 | 国精产品999永久天美 | 欧美天天影院 | 91精品视频国产 | 日本猛少妇色xxxxx猛叫 | 台湾佬久久| 婷婷导航 | jzzjzz日本丰满少妇 | 日韩国产一区二区 | 国产人妻人伦精品1国产丝袜 | 久久精品国产色蜜蜜麻豆 | 深夜国产福利 | 国产精品久久久久久久白丝制服 | 亚洲少妇激情 | 97视频在线看 | 91一区二区三区久久久久国产乱 | 天天上天天干 | 免费无码又爽又黄又刺激网站 | 国产成人在线免费观看视频 | 国产嫩草在线观看 | 欧美色图亚洲自拍 | 欧美国产日韩亚洲中文 | 久久久久久亚洲精品无码 | 免费看一级 | 日韩专区第一页 | 免费观看一区二区三区 | 精品久久久久久成人av | 久久久精品中文 | 国产综合精品视频 | 国产乱肥老妇女精品视频网站 | 欧美精品久久久久久久监狱 | 无码日韩精品一区二区人妻 | 婷婷色国产偷v国产偷v小说 | 国产精品久久久久久久毛片 | 爆乳一区二区三区无码 | 欧美在线观看视频一区二区 | 青春草在线视频观看 | 操人视频免费看 | 亚洲第一av网站 | 欧美激情第五页 | 高h破瓜受孕龙精 | 成人一级大片 | 精品一区二区国产 | 国产精品久久久久亚洲影视 | 国产精选中文字幕 | 午夜男人网 | 国产涩涩视频在线观看 | 久久久久99人妻一区二区三区 | 久久久国产精品入口麻豆 | 色呦呦在线观看视频 | 91av导航 | 男人天堂国产 | 饥渴少妇勾引水电工av | 亚洲不卡在线观看 | 国产精品一区二区福利视频 | 丝袜 亚洲 另类 欧美 重口 | 岳狂躁岳丰满少妇大叫 | 永久免费汤不热视频 | 日本久久久网站 | 激情黄色小视频 | 成人免费视频在线观看 | 国精产品一区二区 | 中文字幕一区二区三区不卡 | 日韩精品精品 |