<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    posts - 310, comments - 6939, trackbacks - 0, articles - 3
      BlogJava :: 首頁(yè) :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

    Struts2與Struts1.x的深度比較

    Posted on 2007-07-17 17:09 詩(shī)特林 閱讀(8269) 評(píng)論(5)  編輯  收藏 所屬分類(lèi): J2EE
    俺就IT168寫(xiě)的專(zhuān)稿.http://tech.it168.com/j/2007-07-13/200707131009859.shtml
     

    Struts2Struts1.x的深度比較

    網(wǎng)名:sterning

     

    Struts作為MVC 2Web框架,自推出以來(lái)不斷受到開(kāi)發(fā)者的追捧,得到廣泛的應(yīng)用。作為最成功的Web框架,Struts自然擁有眾多的優(yōu)點(diǎn):MVC 2模型的使用、功能齊全的標(biāo)志庫(kù)(Tag Library)、開(kāi)放源代碼。

    但是,正所謂沒(méi)有最好,只有更好Struts1.x自身也有不少的缺點(diǎn):需要編寫(xiě)的代碼過(guò)多,容易引起類(lèi)爆炸、單元測(cè)試?yán)щy。這些缺點(diǎn)隨著Web的發(fā)展越來(lái)越明顯。這就促生了Struts 2,它的誕生能很好的解決上述問(wèn)題。

    在本文中,筆者將對(duì)Struts2Struts1.x這兩種框架進(jìn)行詳細(xì)的比較。比較將涉及到這兩種框架的Action、驗(yàn)證、類(lèi)型轉(zhuǎn)換及如何開(kāi)發(fā)等方面的內(nèi)容。希望通過(guò)這樣的比較,讓讀者了解這兩種框架各自的特點(diǎn),以便于在自己的項(xiàng)目中,根據(jù)實(shí)際情況,盡快的過(guò)渡到Struts2的時(shí)代。本文的內(nèi)容基于Struts2.0.6

     

    一、       引言

     

    Struts的第一個(gè)版本是在20015月份發(fā)布的。它的最初設(shè)想是通過(guò)結(jié)合JSPServlet,使Web應(yīng)用的視圖和業(yè)務(wù)/應(yīng)用邏輯得以清晰地分離開(kāi)來(lái)。在Struts之前,最常見(jiàn)的做法是在JSP中加入業(yè)務(wù)和應(yīng)用邏輯,或者在Servlet中通過(guò)println()來(lái)生成視圖。

    自從第一版發(fā)布以來(lái),Struts實(shí)際上已成為業(yè)界公認(rèn)的Web應(yīng)用標(biāo)準(zhǔn)。它的炙手可熱也為自己帶來(lái)了改進(jìn)和變更,所以不但要跟上對(duì)Web應(yīng)用框架不斷變化的需求,而且要與日漸增多競(jìng)爭(zhēng)激烈的眾多框架的特性相融合。

    到最后,產(chǎn)生了幾個(gè)下一代Struts的解決方案。其中兩個(gè)最受矚目的方案是ShaleStruts TiShale是一個(gè)基于構(gòu)件的框架,并在最近成為Apache的頂級(jí)項(xiàng)目。而Struts Ti則是在Struts的成功經(jīng)驗(yàn)基礎(chǔ)上繼續(xù)堅(jiān)持對(duì)前端控制器(Front Controller)和MVCmodel-view-controller)模式進(jìn)行改進(jìn)。

    WebWork項(xiàng)目是在20023月發(fā)布的,它對(duì)Struts式框架進(jìn)行了革命性改進(jìn),引進(jìn)了不少新的思想、概念和功能,但和原Struts代碼并不兼容。WebWork是一個(gè)成熟的框架,經(jīng)過(guò)了好幾次重大的改進(jìn)與發(fā)布。

    200512月,WebWorkStruts Ti宣布合并。與此同時(shí),Struts Ti改名為Struts Action Framework 2.0,成為Struts真正的繼承者。

    最后要注意的是,并不是說(shuō)StrutsWebWork項(xiàng)目已經(jīng)停止開(kāi)發(fā)了。由于人們對(duì)這兩個(gè)項(xiàng)目的興趣仍然很高,而且也有很多開(kāi)發(fā)者仍然愿意使用它們,因此這兩個(gè)項(xiàng)目還在繼續(xù)開(kāi)發(fā)中,繼續(xù)修復(fù)Bug,改進(jìn)功能和繼續(xù)添加新功能。

     

    二、       Action的區(qū)別

     

    對(duì)于有著豐富的Struts1.x開(kāi)發(fā)經(jīng)驗(yàn)的朋友來(lái)說(shuō),都十分的清楚Action是整個(gè)Struts框架的核心內(nèi)容,當(dāng)然Struts2也不例外。不過(guò),Struts1.xStruts2Action模型很大的區(qū)別。

    Struts2Struts1.x的差別,最明顯的就是Struts2是一個(gè)pull-MVC架構(gòu)。這是什么意思呢?從開(kāi)發(fā)者角度看,就是說(shuō)需要顯示給用戶(hù)的數(shù)據(jù)可以直接從Action中獲取,而不像Struts1.x那樣,必須把相應(yīng)的Bean存到PageRequest或者Session中才能獲取。Struts1.x 必須繼承org.apache.struts.action.Action或者其子類(lèi),表單數(shù)據(jù)封裝在FormBean中。Struts 2無(wú)須繼承任何類(lèi)型或?qū)崿F(xiàn)任何接口,表單數(shù)據(jù)包含在Action中,通過(guò)GetterSetter獲取(如下面的ActionForStruts2的代碼示例)。

    雖然,在理論上Struts2Action無(wú)須實(shí)現(xiàn)任何接口或者是繼承任何的類(lèi),但是,在實(shí)際編程過(guò)程中,為了更加方便的實(shí)現(xiàn)Action,大多數(shù)情況下都會(huì)繼承com.opensymphony.xwork2.ActionSupport類(lèi),并且重載(Override)此類(lèi)里的String execute()方法。如下所示:

    package ActionDiffer;

     import java.text.DateFormat;

     import java.util.Date;

     

     import com.opensymphony.xwork2.ActionSupport;

     

     public class ActionForStruts2 extends ActionSupport {

         private String message;

       

         public String getMessage() {

             return message;

        }

       

        @Override

         public String execute() {

            message = " This is hello from strtuts2. Now is: " + DateFormat.getInstance().format( new Date());

             return SUCCESS;

        }

    }

    首先,從ActionForStruts2可以看出,返回的對(duì)象不是ActionForward,而是String。如果你不喜歡以字符串的形式出現(xiàn)在你的代碼中,有個(gè)Helper接口Action可以以常量方式提供常見(jiàn)結(jié)果,如“success”“none”“error”“input”“login”

    另外, 按照慣例,在Struts1.x中只有“execute”方法能調(diào)用Action, 但在Struts2中并非必要,任何聲明為public String methodName() 方法,都能通過(guò)配置來(lái)調(diào)用Action

    最后,和Struts1.x最大的革命性的不同是,Struts2處理Action過(guò)程中調(diào)用的方法(“execute”方法)是不帶參數(shù)的。那如何獲取所需要的對(duì)象呢?答案是使用IoC(反轉(zhuǎn)控制,Inversion of Control),也叫依賴(lài)注入(Dependency Injection的模式(想更多地了解這方面信息請(qǐng)看Martin Fowler的文章http://www.martinfowler.com/articles/injection.html)。Spring框架使得這個(gè)模式流行起來(lái),然而Struts2的前身(WebWork)也同時(shí)應(yīng)用上了這個(gè)模式。

     

    三、       IoC

    IoC(Inversion of Control,以下譯為控制反轉(zhuǎn)),隨著Java社區(qū)中輕量級(jí)容器(Lightweight Contianer)的推廣而越來(lái)越為大家耳熟能詳。在此,無(wú)需再多費(fèi)唇舌來(lái)解釋什么是控制反轉(zhuǎn)為什么需要控制反轉(zhuǎn)。因?yàn)榛ヂ?lián)網(wǎng)上已經(jīng)有非常多的文章對(duì)諸如此類(lèi)的問(wèn)題作了精彩而準(zhǔn)確的回答。讀者可以去讀一下Rod JohnsonJuergen Hoeller合著的《Expert one-on-one J2EE Development without EJB》或Martin Fowler所寫(xiě)的《Inversion of Control Containers and the Dependency Injection pattern》。

    眾所周知,Struts2是以Webwork 2作為基礎(chǔ)發(fā)展出來(lái)。而在Webwork 2.2之前的Webwork版本,其自身有一套控制反轉(zhuǎn)的實(shí)現(xiàn),Webwork 2.2Spring 框架的如火如荼發(fā)展的背景下,決定放棄控制反轉(zhuǎn)功能的開(kāi)發(fā),轉(zhuǎn)由Spring實(shí)現(xiàn)。值得一提的是,Spring確實(shí)是一個(gè)值得學(xué)習(xí)的框架,因?yàn)橛性絹?lái)越多的開(kāi)源組件(如iBATIS等)都放棄與Spring重疊的功能的開(kāi)發(fā)。因此,Struts2推薦大家通過(guò)Spring實(shí)現(xiàn)控制反轉(zhuǎn)。

    為了更好地了解反轉(zhuǎn)控制,下面來(lái)看一個(gè)例子,如何利用IoCAction處理過(guò)程中可以訪問(wèn)到當(dāng)前請(qǐng)求HttpServerRequest對(duì)象。

    在例子中,使用的依賴(lài)注入機(jī)制是接口注入。就如其名稱(chēng)一樣,接口注入需要的是已經(jīng)被實(shí)現(xiàn)了的接口。這個(gè)接口包含了相應(yīng)屬性的setter,為Action提供值。例子中使用了ServletRequestAware接口,如下:

    public interface ServletRequestAware {
        public void setServletRequest(HttpServletRequest request);
    }

    當(dāng)繼承這個(gè)接口后,原本簡(jiǎn)單的Action看起來(lái)有點(diǎn)復(fù)雜了,但是這時(shí)可以獲取HttpServerRequest對(duì)象來(lái)使用了。

    public class IoCForStruts2 implements ServletRequestAware {
       private HttpServletRequest request;
       public void setServletRequest(HttpServletRequest request) {
            this.request = request;
       }
       public String execute() throws Exception {
            //
    可以開(kāi)始使用request對(duì)象進(jìn)行工作了
            return Action.SUCCESS;
       }
    }

    看起來(lái)現(xiàn)在這些屬性是類(lèi)級(jí)別的,并不是線(xiàn)程安全的,會(huì)出現(xiàn)問(wèn)題。其實(shí)在Struts2里并沒(méi)有問(wèn)題,因?yàn)槊總€(gè)請(qǐng)求過(guò)來(lái)的時(shí)候都會(huì)產(chǎn)生一個(gè)新的Action對(duì)象實(shí)例,它并沒(méi)有和其他請(qǐng)求共享一個(gè)對(duì)象,所以不需要考慮線(xiàn)程安全問(wèn)題。

     

    四、       攔截器

     

    Interceptor(以下譯為攔截器),在AOPAspect-Oriented Programming)中用于在某個(gè)方法或字段被訪問(wèn)之前,進(jìn)行攔截然后在之前或之后加入某些操作。攔截是AOP的一種實(shí)現(xiàn)策略。

    Webwork的中文文檔的解釋為——攔截器是動(dòng)態(tài)攔截Action調(diào)用的對(duì)象。它提供了一種機(jī)制可以使開(kāi)發(fā)者定義在一個(gè)action執(zhí)行的前后執(zhí)行的代碼,也可以在一個(gè)action執(zhí)行前阻止其執(zhí)行。同時(shí)也提供了一種可以提取action中可重用的部分的方式。

    Struts1.x的標(biāo)準(zhǔn)框架中不提供任何形式的攔截器,雖一個(gè)名為SAIF的附加項(xiàng)目則實(shí)現(xiàn)了這樣的功能,但它的適用的范圍還很有限。

    攔截器是Struts2的一個(gè)強(qiáng)有力的工具,有許多功能(feature)都是構(gòu)建于它之上,如國(guó)際化轉(zhuǎn)換器校驗(yàn)等。談到攔截器,還有一個(gè)流行的詞——攔截器鏈(Interceptor Chain,在Struts2中稱(chēng)為攔截器棧Interceptor Stack)。攔截器鏈就是將攔截器按一定的順序聯(lián)結(jié)成一條鏈。在訪問(wèn)被攔截的方法或字段時(shí),攔截器鏈中的攔截器就會(huì)按其之前定義的順序被調(diào)用。

    Struts 2的攔截器實(shí)現(xiàn)相對(duì)比較簡(jiǎn)單。當(dāng)請(qǐng)求到達(dá)Struts2ServletDispatcher時(shí),Struts 2會(huì)查找配置文件,并根據(jù)其配置實(shí)例化相對(duì)的攔截器對(duì)象,然后串成一個(gè)列表(list),最后一一地調(diào)用列表中的攔截器,如圖1所示。

     

    攔截器調(diào)用序列器

    Struts 2已經(jīng)提供豐富多樣功能齊全的攔截器實(shí)現(xiàn)。讀者可以到struts2-all-2.0.6.jarstruts2-core-2.0.6.jar包的struts-default.xml查看關(guān)于默認(rèn)的攔截器與攔截器鏈的配置。

    作為框架(framework,可擴(kuò)展性是不可缺少的,因?yàn)槭郎蠜](méi)有放之四海而皆準(zhǔn)的東西。雖然,Struts 2為我們提供如此豐富的攔截器實(shí)現(xiàn),但是這并不意味我們失去創(chuàng)建自定義攔截器的能力,恰恰相反,在Struts 2自定義攔截器是相當(dāng)容易的一件事。

     

    五、       Struts2Struts1.x的全面比較

    為了對(duì)Struts2Strtus1.x進(jìn)行全面的比較,讓讀者了解這兩種框架各自的優(yōu)缺點(diǎn),以便于在自己的項(xiàng)目中,根據(jù)實(shí)際情況,選擇合適的框架,對(duì)它們兩者進(jìn)行比較,總結(jié)了如下表分析比較。

    特性

    Struts1.x

    Struts2

    Action類(lèi)

    Struts1.x要求Action類(lèi)要擴(kuò)展自一個(gè)抽象基類(lèi)。Struts1.x的一個(gè)共有的問(wèn)題是面向抽象類(lèi)編程而不是面向接口編程。

    Struts2Action類(lèi)實(shí)現(xiàn)了一個(gè)Action接口,連同其他接口一起來(lái)實(shí)現(xiàn)可選擇和自定義的服務(wù)。Struts2提供一個(gè)名叫ActionSupport的基類(lèi)來(lái)實(shí)現(xiàn)一般使用的接口。當(dāng)然,Action接口不是必須的。任何使用execute方法的POJO對(duì)象可以被當(dāng)作Struts 2Action對(duì)象來(lái)使用。

    線(xiàn)程模型

    Struts1.x Action類(lèi)是單例類(lèi),因?yàn)橹挥幸粋€(gè)實(shí)例來(lái)控制所有的請(qǐng)求。單例類(lèi)策略造成了一定的限制,并且給開(kāi)發(fā)帶來(lái)了額外的煩惱。Action資源必須是線(xiàn)程安全或者同步的。

    Struts2 Action對(duì)象為每一個(gè)請(qǐng)求都實(shí)例化對(duì)象,所以沒(méi)有線(xiàn)程安全的問(wèn)題。(實(shí)踐中,servlet容器給每一個(gè)請(qǐng)求產(chǎn)生許多丟棄的對(duì)象,并且不會(huì)導(dǎo)致性能和垃圾回收問(wèn)題)。

    Servlet 依賴(lài)

    Struts1.xAction類(lèi)依賴(lài)于servlet API,當(dāng)Action被調(diào)用時(shí),以HttpServletRequestHttpServletResponse作為參數(shù)傳給execute方法。

    Struts2Action和容器無(wú)關(guān)。Servlet上下文被表現(xiàn)為簡(jiǎn)單的Maps,允許Action被獨(dú)立的測(cè)試。Struts2Action可以訪問(wèn)最初的請(qǐng)求(如果需要的話(huà))。但是,盡可能避免或排除其他元素直接訪問(wèn)HttpServletRequestHttpServletResponse

    易測(cè)性

    測(cè)試Struts1.x的主要問(wèn)題是execute方法暴露了Servlet API這使得測(cè)試要依賴(lài)于容器)。第三方的擴(kuò)展,如Struts TestCase,提供了一套Struts1的模擬對(duì)象(來(lái)進(jìn)行測(cè)試)。

    Struts2Action可以通過(guò)初始化、設(shè)置屬性、調(diào)用方法來(lái)測(cè)試。依賴(lài)注入的支持也是測(cè)試變得更簡(jiǎn)單。

    捕獲輸入

    Struts1.x使用ActionForm對(duì)象來(lái)捕獲輸入。象Action一樣,所有的ActionForm必須擴(kuò)展基類(lèi)。因?yàn)槠渌?/span>JavaBean不能作為ActionForm使用,開(kāi)發(fā)者經(jīng)常創(chuàng)建多余的類(lèi)來(lái)捕獲輸入。DynaBeans可以被用來(lái)作為替代ActionForm的類(lèi)來(lái)創(chuàng)建。但是,開(kāi)發(fā)者可能是在重新描述(創(chuàng)建)已經(jīng)存在的JavaBean(仍然會(huì)導(dǎo)致有冗余的javabean)。

    Struts2直接使用Action屬性作為輸入屬性,消除了對(duì)第二個(gè)輸入對(duì)象的需求。輸入屬性可能是有自己()屬性的rich對(duì)象類(lèi)型。Action屬性能夠通過(guò)web頁(yè)面上的taglibs訪問(wèn)。Struts2也支持ActionForm模式。rich對(duì)象類(lèi)型,包括業(yè)務(wù)對(duì)象,能夠用作輸入/輸出對(duì)象。這種ModelDriven 特性簡(jiǎn)化了taglib對(duì)POJO輸入對(duì)象的引用。

    表達(dá)式語(yǔ)言

    Struts1.x整合JSTL,所以它使用JSTL的表達(dá)式語(yǔ)言。表達(dá)式語(yǔ)言有基本的圖形對(duì)象移動(dòng),但是對(duì)集合和索引屬性的支持很弱。

    Struts2使用JSTL,但是也支持一個(gè)更強(qiáng)大和靈活的表達(dá)式語(yǔ)言--"Object Graph Notation Language" (OGNL)

    將值綁定到頁(yè)面

    Struts1.x使用標(biāo)準(zhǔn)JSP機(jī)制來(lái)綁定對(duì)象到頁(yè)面上下文。

    Struts2使用“ValueStack”技術(shù),使taglib能夠訪問(wèn)值而不需要把你的頁(yè)面(view)和對(duì)象綁定起來(lái)。ValueStack策略允許通過(guò)一系列名稱(chēng)相同但類(lèi)型不同的屬性重用頁(yè)面(view)。

    類(lèi)型轉(zhuǎn)換

    Struts1.xActionForm屬性經(jīng)常都是StringStruts 1.x使用Commons-Beanutils來(lái)進(jìn)行類(lèi)型轉(zhuǎn)換。轉(zhuǎn)換每一個(gè)類(lèi),而不是為每一個(gè)實(shí)例配置。

    Struts2使用OGNL進(jìn)行類(lèi)型轉(zhuǎn)換。提供基本和常用對(duì)象的轉(zhuǎn)換器。

    驗(yàn)證

    Struts1.x支持在ActionFormvalidate方法中手動(dòng)校驗(yàn),或者通過(guò)Commons Validator的擴(kuò)展來(lái)校驗(yàn)。同一個(gè)類(lèi)可以有不同的校驗(yàn)內(nèi)容,但不能校驗(yàn)子對(duì)象。

    Struts2支持通過(guò)validate方法和XWork校驗(yàn)框架來(lái)進(jìn)行校驗(yàn)。XWork校驗(yàn)框架使用為屬性類(lèi)類(lèi)型定義的校驗(yàn)和內(nèi)容校驗(yàn),來(lái)支持chain校驗(yàn)子屬性

    Action執(zhí)行控制

    Struts1.x支持每一個(gè)模塊有單獨(dú)的Request Processors(生命周期),但是模塊中的所有Action必須共享相同的生命周期。

    Struts2支持通過(guò)攔截器堆棧(Interceptor Stacks)為每一個(gè)Action創(chuàng)建不同的生命周期。堆棧能夠根據(jù)需要和不同的Action一起使用。

     

     

    六、       結(jié)論

    前面已經(jīng)簡(jiǎn)要介紹了Struts2的起源,并詳細(xì)對(duì)比了Struts2Struts1.x的差異,讀者應(yīng)該對(duì)Struts2的基礎(chǔ)有所了解了——包括高層的框架概念和基礎(chǔ)的請(qǐng)求流程,并理解Struts1.xStruts2兩者之間在Action方面的差別,Struts2加強(qiáng)了對(duì)攔截器與IoC的支持,而在Struts1.x中,這些特性是很難想象的。

    同時(shí),讀者應(yīng)該明白:Struts2WebWork的升級(jí),而不是Struts 1.x的升級(jí)。雖然Struts 2提供了與Struts1.x的兼容,但已經(jīng)不是Struts1.x的升級(jí)。對(duì)于已有Struts1.x開(kāi)發(fā)經(jīng)驗(yàn)的開(kāi)發(fā)者而言,Struts1.x的開(kāi)發(fā)經(jīng)驗(yàn)對(duì)于Struts2并沒(méi)有太大的幫助;相反,對(duì)于已經(jīng)有WebWork開(kāi)發(fā)經(jīng)驗(yàn)的開(kāi)發(fā)者而言,WebWork的開(kāi)發(fā)經(jīng)驗(yàn)對(duì)Struts2的開(kāi)發(fā)將有很好的借鑒意義。


    評(píng)論

    # re: Struts2與Struts1.x的深度比較[未登錄](méi)  回復(fù)  更多評(píng)論   

    2007-07-24 19:15 by 阿蜜果
    寫(xiě)得不錯(cuò),加油,sterning!

    # re: Struts2與Struts1.x的深度比較  回復(fù)  更多評(píng)論   

    2007-11-01 10:15 by tuo_bing
    學(xué)習(xí) 中,頂 !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!

    # re: Struts2與Struts1.x的深度比較  回復(fù)  更多評(píng)論   

    2008-07-04 15:23 by leosun
    寫(xiě)得不錯(cuò),只有一點(diǎn)更正那就是Action類(lèi)的比較上,有一點(diǎn)點(diǎn)不同,就是對(duì)針對(duì)接口編程的理解上。針對(duì)接口編程又叫針對(duì)超類(lèi)型編程,不一定非得實(shí)現(xiàn)一個(gè)接口.

    # re: Struts2與Struts1.x的深度比較  回復(fù)  更多評(píng)論   

    2013-02-20 15:41 by re
    總體寫(xiě)的不錯(cuò)額。我就算知道,也寫(xiě)不出這么好,good。

    # re: Struts2與Struts1.x的深度比較  回復(fù)  更多評(píng)論   

    2013-08-29 11:03 by 草之夢(mèng)
    雖然看不明白,但感覺(jué)好厲害的樣子,頂一下!!
    主站蜘蛛池模板: 国产免费黄色无码视频| 亚洲另类古典武侠| 一区二区三区免费高清视频| 免费久久精品国产片香蕉| 亚洲av无码专区在线观看下载| 成人免费男女视频网站慢动作| 亚洲三级在线播放| 一本无码人妻在中文字幕免费| 亚洲香蕉久久一区二区三区四区| 国内精自视频品线六区免费| 亚洲人成电影院在线观看| 日韩精品无码区免费专区 | 美女视频黄的免费视频网页| 亚洲乳大丰满中文字幕| 三年片在线观看免费观看大全动漫 | 青青青国产免费一夜七次郎| 亚洲欧美不卡高清在线| 国产精品免费看久久久无码| 又黄又大的激情视频在线观看免费视频社区在线 | 精品亚洲综合在线第一区| 无码人妻久久一区二区三区免费| 亚洲国产精品婷婷久久| 久热中文字幕在线精品免费| 亚洲色偷偷偷综合网| 亚洲精品自产拍在线观看动漫| 一级毛片免费不卡在线| 亚洲成_人网站图片| 成人男女网18免费视频| 亚洲午夜福利精品久久| 亚洲人成电影亚洲人成9999网| 伊人久久免费视频| 亚洲色大情网站www| 亚洲午夜AV无码专区在线播放| 国产一区二区免费| 精品久久久久久亚洲精品| 又粗又黄又猛又爽大片免费| 成人无码a级毛片免费| 精品亚洲AV无码一区二区| 亚洲一区二区高清| 精品女同一区二区三区免费站| 最新亚洲人成网站在线观看|