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

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

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

    JAVA—咖啡館

    ——歡迎訪問rogerfan的博客,常來《JAVA——咖啡館》坐坐,喝杯濃香的咖啡,彼此探討一下JAVA技術(shù),交流工作經(jīng)驗,分享JAVA帶來的快樂!本網(wǎng)站部分轉(zhuǎn)載文章,如果有版權(quán)問題請與我聯(lián)系。

    BlogJava 首頁 新隨筆 聯(lián)系 聚合 管理
      447 Posts :: 145 Stories :: 368 Comments :: 0 Trackbacks
    用Maven做項目管理
    在Java世界中我們很多的開發(fā)人員選擇用Ant來構(gòu)建項目,一個build.xml能夠完成編譯、測試、打包、部署等很多任務(wù),但我們也碰到了很多的問題,如jar文件管理混亂,各個項目結(jié)構(gòu)和build.xml相差很大等等。而Maven的出現(xiàn),給項目提供了更多的支持。
    1        簡介
    Maven作為Apache的一個開源項目,旨在給項目管理提供更多的支持,主頁地址為http://maven.apache.org 。它最早的意圖只是為了給apache組織的幾個項目提供統(tǒng)一的開發(fā)、測試、打包和部署,能讓開發(fā)者在多個項目中方便的切換。很多偉大的事業(yè),出發(fā)點都很簡單,ebay就是很好的例證。而maven的成功又一次驗證了這一點,越來越多的項目開始使用maven。
    基本原理
    Maven的基本原理很簡單,采用遠程倉庫和本地倉庫以及一個類似build.xml的pom.xml,將pom.xml中定義的jar文件從遠程倉庫下載到本地倉庫,各個應(yīng)用使用同一個本地倉庫的jar,同一個版本的jar只需下載一次,而且避免每個應(yīng)用都去拷貝jar。如圖1。同時它采用了現(xiàn)在流行的插件體系架構(gòu),只保留最小的核心,其余功能都通過插件的形式提供,所以maven下載很小(1.1M),在執(zhí)行maven任務(wù)時,才會自動下載需要的插件。
    這個基本原理與Pear――PHP擴展與應(yīng)用庫(the PHP Extension and Application Repository)的原理非常相似,都有一個官方的倉庫,都是微內(nèi)核,通過網(wǎng)絡(luò)將需要的文件下載到本地,通過官方倉庫將相應(yīng)的類庫進行統(tǒng)一管理。Pear已經(jīng)成為PHP開發(fā)事實上的標(biāo)準(zhǔn),而Maven在Java世界的地位也逐漸加強,成為標(biāo)準(zhǔn)指日可待。
    另外由于插件的易開發(fā)性,現(xiàn)在有了非常多的可供選擇的插件,如與eclipse結(jié)合的插件,與test相關(guān)的插件,后面我們結(jié)合maven在項目中的使用進行詳細介紹。
    圖1
    2        項目管理
    Maven官方把maven定義為一個項目管理工具,我們不妨看看maven能給我們的項目提供哪些好的支持。
    2.1       項目標(biāo)準(zhǔn)化
    Maven一個重要特性是定義了項目的標(biāo)準(zhǔn)模板,官方說法是最佳實踐。可以通過命令:mvn archetype:create -DgroupId=com.mycompany.app -DartifactId=my-app創(chuàng)建一個單一的maven項目。創(chuàng)建好的項目,具有了特定的項目結(jié)構(gòu)。這個項目結(jié)構(gòu)是參考業(yè)界的最佳實踐而成,為后面使用統(tǒng)一的maven命令打下了基礎(chǔ),如測試mvn test、打包mvn package等,無需寫一行腳本,就可以方便的實現(xiàn)眾多功能。Maven還提供其它一些類型模板,可以通過添加-DarchetypeArtifactId={type}創(chuàng)建,如-DarchetypeArtifactId=maven-archetype-site,生成site類型的項目。
    同時一些好的開源軟件使用了maven,也能作為很好的項目模板,如Equinox(Appfuse的簡化版),它的pom定義了對hiberante,spring…的依賴,可以通過ant new -Dapp.name=NAME快速生成項目原型,然后對pom文件進行裁減,以符合自身項目的需要。
    有了這個標(biāo)準(zhǔn),項目間能方便的進行交流,你也很容易了解其它使用maven項目的結(jié)構(gòu)。對于企業(yè)來說,引入maven就自然引入了規(guī)范,這可比費時費力的寫文檔,定規(guī)范有效的多了。
    2.2       文檔和報告
    使用mvn site可以快速生成項目站點,apache很多開源項目站點都采用maven生成,會出現(xiàn)built by maven字樣的圖標(biāo)。
    而maven提供的針對如junit,checkstyle,pmd等的插件,能夠方便的進行測試和檢查并能直接生成報告。使用都很簡單,如mvn surefire-report:report 就能自動進行junit測試,并生成junit報告,mvn pmd:pmd生成pmd報告。具體使用可以在http://maven.apache.org/plugins/index.html找到。
    2.3       類庫管理
    Maven一個很重要的特色就是類庫管理。通過在pom.xml中定義jar包版本和依賴,能夠方便的管理jar文件。以下是一個簡單的jar定義片斷:
    <dependency>                                                                      
          <groupId>org.hibernate</groupId>
          <artifactId>hibernate</artifactId>
          <version>3.1</version>
          <type>jar</type>
          <scope>runtime</scope>
     </dependency>
    這個片斷告訴我們,依賴的jar包groupId為org.hibernate,artifactId為hibernate,版本為3.1,scope為runtime。在實際項目中,會將M2_REPO(maven本地倉庫地址)/ org/hibernate / hibernate /3.1/ hibernate -3.1.jar放入classpath。
    同時maven會通過pom.xml管理jar包間的依賴。比如上面的hibernate-3.1.jar同級目錄肯定會有一個hibernate -3.1.pom,在這個pom文件中指定了這個jar對其它一些jar的依賴。而這個pom文件是遠程倉庫提供,無需進行修改,執(zhí)行maven相關(guān)命令就會自動根據(jù)相關(guān)依賴去下載jar包。這樣只需定義對hibernate的依賴而無需關(guān)心相關(guān)jar,在構(gòu)建項目上方便了很多。
    因為pom文件對jar的管理,也產(chǎn)生了一個很吸引人的特性:項目文件很小。以往一個web項目中,jar文件都要放入WEB-INF/lib下,并放入cvs(svn)中,很容易就達到幾十M。而通過maven,只需一個pom.xml,在執(zhí)行mvn eclipse:eclipse時再去遠程倉庫下載,項目文件一般只需幾百K。
    2.4       發(fā)布管理
    使用maven可以方便的進行項目發(fā)表管理。在項目開發(fā)到一定階段,可以使用mvn package打包,它會自動先運行mvn test,跑所有的testcase,只有全部通過才能正確打包。生成的war包(如果項目的packaging為war)在target目錄下。這個war包與使用ant腳本生成一樣,但無需一行腳本,這也是maven對比ant的優(yōu)勢之一。使用mvn install將編譯和打包好的文件發(fā)布到distributionManager指定的遠程repository。使用mvn deploy可以自動管理項目版本。
     
    3        使用maven
    Maven使用簡單,插件豐富且經(jīng)過大量項目考驗,在項目中引入的風(fēng)險很小。筆者在項目中使用maven,新進員工在半小時內(nèi)就能成功使用maven構(gòu)建項目,并很快掌握幾個常用的命令。Maven也不需要什么特殊的設(shè)施。如果項目全部使用開源軟件,并且不需要maven管理項目版本,只需要一個SCM環(huán)境(CVS或SVN),共享開發(fā)源碼就可以。把pom.xml中的repository設(shè)為官方地址就行,配置如下:
    <repository>
          <id>central</id>
          <url>http://www.ibiblio.org/maven2</url>
    </repository>
    這個官方remote repository上有非常多的開源軟件,應(yīng)該能滿足大部分項目的需要。如果有項目需要而它上面暫時還沒有的軟件,或者希望使用公司內(nèi)部的軟件,那么就需要自己配置一個repository了。
    3.1       自建私服
    傳奇私服大家應(yīng)該都聽過,一個網(wǎng)吧自己搞個私服,一伙人免費在上面砍殺。官方因此少賺了很多錢,因此總想打擊。而maven官方卻對自建私服很是支持,我們總算可以正正當(dāng)當(dāng)搞把私服了(Springside的老大江南白衣就是創(chuàng)建私服的好手)。我們就來介紹下自建私服的最快方法。
    首先需要一個http server,找臺服務(wù)器裝上apache就行。放一個空的maven目錄到htdocs下,假設(shè)服務(wù)器ip為192.168.0.1,確認能用http://192.168.0.1/maven訪問到。然后在自己機器上裝好maven2,初始化好項目,在pom.xml放入需要的jar定義,運行如mvn eclipse:eclipse就自動從官方下載jar到本地,如果不做配置,默認本地repository為${user.home}/.m2/。對于windows xp來說一般在C:\Documents and Settings\%username%\.m2下,其中%username%為操作系統(tǒng)登錄用戶名。這時你可以看到${user.home}/.m2/下多了個repository目錄,里面有很多的項目相關(guān)jar,目錄按groupId/ artifactId/version排好。把repository目錄整個拷貝到apache服務(wù)器的maven目錄下,如果需要官方缺少的jar或公司內(nèi)部jar,仿照這個目錄結(jié)構(gòu),做好jar放到maven目錄下。自建私服成功!
    要使用私服,只需修改pom.xml,在repository配置后加上:
    <repository>
          <id>companyName</id>
          <url>http:// ${ip}/maven</url>
    </repository>
    這樣需要下載jar時,會先到本地repository查看,沒有下載過再到官方搜索,沒有找到再到后面的repository查找。
    3.2       安裝配置
    Maven的安裝很簡單:
    1.         從apache網(wǎng)站上下載maven安裝包,實際上就是個壓縮文件。將其解壓到你想要存放maven的目錄中。在這里假設(shè)你將maven解壓到C:\Program Files\Apache Software Foundation\maven-2.0.4中。
    2.      C:\Program Files\Apache Software Foundation\maven-2.0.4\bin設(shè)到你的系統(tǒng)環(huán)境變量%PATH%中。
    3.      同時確保你已經(jīng)將你的JDK安裝目錄設(shè)為java_home系統(tǒng)變量。
    4.         打開個命令行窗口,運行mvn –version驗證是否安裝成功。
    5.         如果使用eclipse,在運行mvn eclipse:eclipse生成eclipse項目文件后,需加入M2_REPO到Classpath Variables中,指向本地repository,例如:C:/Documents and Settings/Owner/.m2/repository。
    3.3       基本使用流程
    在項目進程中,不必做什么配置,在pom.xml同級目錄,cmd使用簡單的maven命令,就可以完成初始化->開發(fā)->測試->發(fā)布的全過程。Maven的基本使用流程如下圖:

     

     

    其中在初次使用命令mvn eclipse:eclipse時會下載很多的插件和jar,可能需要較長的時間,建議泡杯咖啡,和同事吹吹牛。如果失敗,可能是網(wǎng)絡(luò)問題,可以重新運行mvn eclipse:eclipse,已下載好的插件和jar不會再下。運行mvn test和mvn package等命令,產(chǎn)出物都會放在target目錄下。如果在使用過程中有什么問題,也可以和我聯(lián)系,mail:pesome@gmail.com,我們一起來嘗試解決。
     
    總結(jié):
    Maven作為新的項目管理工具,簡單易用,能對項目的各個階段提供大力支持,同時由于它易擴展的插件體系架構(gòu),出現(xiàn)了越來越多的插件,也使得其功能更加強大。短短一篇文章,實在很難把其特點一一盡述,maven還有很多好用的功能和插件等待我們?nèi)ナ褂煤烷_發(fā)。而學(xué)習(xí)新技術(shù)的最好方式就是實踐,大家如果有興趣,盡快下載一個最新版,開始你的maven之旅吧!
     
     
    參考文檔:
    1.       http://maven.apache.org 官方網(wǎng)站文檔

    Maven 出現(xiàn)到現(xiàn)在也有很長時間了,初識它的感覺至今仍清晰的印在腦海中。現(xiàn)在想來,當(dāng)時從 Ant 移情 Maven 的想法其實很樸素,就是因為 Maven 可以以網(wǎng)站的形式展現(xiàn)與項目相關(guān)的信息,如開發(fā)人員列表、各種 Report。這種方式為項目的構(gòu)建帶來了極大的方便,尤其是 Report 的。試想對于產(chǎn)生的 Junit-Report、JavaDoc、CheckStyle、PMD 等報告,如果沒有一個統(tǒng)一的入口,每次切換目錄是多么令人厭煩的事情!

    Maven 無疑是相當(dāng)成功的,這一點從越來越多的開源項目開始使用 Maven 就可以看出。Maven 取得成功的原因很簡單:在簡化構(gòu)建腳本的同時,功能并沒有縮水,反而有所增強;提供匯集項目信息的工具,并以相當(dāng)友好的方式呈現(xiàn);豐富的插件簡化了工作。如此有力的工具出現(xiàn),自然是爭相使用。

    新特性

    如今 Maven2 已經(jīng)推出,Maven 的官方網(wǎng)站稱,Maven2 相對于 Maven1 是一個相當(dāng)大的轉(zhuǎn)變,甚至不惜犧牲兼容性來達到這一目的。(為了 Maven1 的用戶著想,Maven1 仍在繼續(xù)他的使命。)如此大的變動到底換來了什么樣的結(jié)果?

    1. 更快、更簡單

    比起 Maven1 那不急不慢的運行速度,Maven2在速度上有了質(zhì)的飛躍,甚至與Ant相比也毫不遜色(當(dāng)然,下載不算)。除此之外,"簡化工作,使用業(yè)界公認的最佳實踐"也是是 Maven2 的另一大主題,其他的新特性無處不在體現(xiàn) Maven2 為簡化工作而做出的努力。

    2. 更少的配置文件

    Maven1 和 Maven2 主要配置文件的對比:

    • Maven1:project.xml、maven.xml、project.properties和build.properties。
    • Maven2:pom.xml和settings.xml。

    POM是Maven的核心對象模型,在Maven2中POM已由project.xml轉(zhuǎn)移到pom.xml中使用,版本也由3升級為4。對于項目,一般只需要pom.xml就行了。

    在Maven2中不需要也不提倡使用maven.xml,原因如下:

    • plugin的易用性的增強。
    • 散布于maven.xml中的內(nèi)容難以在不同項目間共享,也不利于維護。在Maven2中建議使用自定義的plugin來封裝這些內(nèi)容。

    如果仍期望能夠使用類似maven.xml的功能,如<preGoal>,請參考Inserting non-standard build steps using preGoals and postGoals。

    在Maven2中,配置使用settings.xml,它取代了原有的project.properties和build.properties。配置在Maven2中存在兩種級別:

    • 用戶級,針對操作系統(tǒng)登錄用戶而言。一般在$home/.m2/,對于windows用戶,就是目錄:C:\Documents and Settings\用戶名\.m2\settings.xml。
    • 全局級:一般在%M2_HOME%/conf/settings.xml,M2_HOME是Maven2的根目錄環(huán)境變量名。

    在settings.xml中可以配置,如本地Repository、proxy等等,關(guān)于settings.xml的結(jié)構(gòu)可以從Maven的官方網(wǎng)站上獲取。

    3. Plugin語言更換

    在Maven2中,編寫plugin的語言由jelly變更為Java和BeanShell。Java在速度上更有優(yōu)勢,而且開發(fā)人員的熟悉程度更高。對于其他的流行腳本,如groovy,Maven的官方網(wǎng)站的意見是,等待其更成熟時再考慮

    4. 提供預(yù)定義的目錄模板

    好的目錄結(jié)構(gòu)可以使開發(fā)人員更容易理解項目,為以后的維護工作也打下良好的基礎(chǔ)。Maven2根據(jù)業(yè)界公認的最佳目錄結(jié)構(gòu),為開發(fā)者提供了缺省的標(biāo)準(zhǔn)目錄模板。Maven2的標(biāo)準(zhǔn)目錄結(jié)構(gòu)如下:


     

    使用目錄模板,可以使pom.xml更簡潔。因為Maven2已經(jīng)根據(jù)缺省目錄,預(yù)定義了相關(guān)的動作,而無需人工的干預(yù)。以resources目錄為例:

    • src/main/resources,負責(zé)管理項目主體的資源。在使用Maven2執(zhí)行compile之后,這個目錄中的所有文件及子目錄,會復(fù)制到target/classes目錄中,為以后的打包提供了方便。
    • src/test/resources,負責(zé)管理項目測試的資源。在使用Maven2執(zhí)行test-compile之后,這個目錄中的所有文件及子目錄,會復(fù)制到target/test-classes目錄中,為后續(xù)的測試做好了準(zhǔn)備。

    這些動作在 Maven1 中,是需要在 maven.xml 中使用<preGoal>或<postGoal>來完成的。如今,完全不需要在pom.xml中指定就能夠自動完成。在src和test都使用resources,方便構(gòu)建和測試,這種方式本就已是前人的經(jīng)驗。通過使用Maven2,使這個經(jīng)驗在開發(fā)團隊中得到普及。

    創(chuàng)建標(biāo)準(zhǔn)目錄模板,可以通過如下命令:


    
                mvn archetype:create -DgroupId=com.codeline.commons -DartifactId=codelineCommons
                

    groupId和artifactId的含義與Maven1中的含義一樣,參數(shù)artifactId的值會作為項目根目錄的名字。除了建立相應(yīng)的目錄之外,Maven2還會創(chuàng)建缺省的pom.xml。

    Maven2也考慮到:不同類型的項目需要擁有不同的目錄結(jié)構(gòu)。如創(chuàng)建web項目,可以使用命令:


    
                mvn archetype:create -DgroupId=com.mycompany.app
                -DartifactId=my-webapp
                -DarchetypeArtifactId=maven-archetype-webapp
                

    5. 生命周期的引入

    在Maven2中有了明確的生命周期概念,而且都提供與之對應(yīng)的命令,使得項目構(gòu)建更加清晰明了。主要的生命周期階段:

    • validate,驗證工程是否正確,所有需要的資源是否可用。
    • compile,編譯項目的源代碼。
    • test-compile,編譯項目測試代碼。
    • test,使用已編譯的測試代碼,測試已編譯的源代碼。
    • package,已發(fā)布的格式,如jar,將已編譯的源代碼打包。
    • integration-test,在集成測試可以運行的環(huán)境中處理和發(fā)布包。
    • verify,運行任何檢查,驗證包是否有效且達到質(zhì)量標(biāo)準(zhǔn)。
    • install,把包安裝在本地的repository中,可以被其他工程作為依賴來使用
    • deploy,在整合或者發(fā)布環(huán)境下執(zhí)行,將最終版本的包拷貝到遠程的repository,使得其他的開發(fā)者或者工程可以共享。
    • generate-sources,產(chǎn)生應(yīng)用需要的任何額外的源代碼,如xdoclet。

    如果要執(zhí)行項目編譯,那么直接輸入:mvn compile即可,對于其他的階段可以類推。階段之間是存在依賴關(guān)系(dependency)的,如test依賴test-compile。在執(zhí)行mvn test時,會先運行mvn test-compile,然后才是mvn test。

    6. 新增Dependency Scope

    在POM 4中,<dependency>中還引入了<scope>,它主要管理依賴的部署。目前<scope>可以使用5個值:

    • compile,缺省值,適用于所有階段,會隨著項目一起發(fā)布。
    • provided,類似compile,期望JDK、容器或使用者會提供這個依賴。如servlet.jar。
    • runtime,只在運行時使用,如JDBC驅(qū)動,適用運行和測試階段。
    • test,只在測試時使用,用于編譯和運行測試代碼。不會隨項目發(fā)布。
    • system,類似provided,需要顯式提供包含依賴的jar,Maven不會在Repository中查找它。

    <scope>的使用舉例:


    
                <dependency>
                <groupId>hibernate</groupId>
                <artifactId>hibernate</artifactId>
                <version>3.0.3</version>
                <scope>test</scope>
                </dependency>
                

    7. 傳遞依賴,簡化依賴管理

    在Maven1中,需要把依賴所需要的包也一并列出。這對于使用類似如Hibernate的用戶來說所操的心太多了,而且也不方便。在Maven2中實現(xiàn)了傳遞依賴,如此對于Hibernate所依賴的包,Maven2會自動下載,開發(fā)人員只需關(guān)心Hibernate即可。

    注意:只有得到Maven支持的依賴,通常是plugin形式出現(xiàn),才能獲得這個特性。而且對于一些老的plugin,可能由于時間的關(guān)系不支持傳遞依賴。如至少在Maven 2.0.1中,對于Hibernate 2.1.2,仍然需要顯式列出Hibernate 2.1.2所依賴的包。





    使用簡介

    安裝Maven2的步驟非常簡單:首先從Maven官方網(wǎng)站下載相應(yīng)的軟件包,目前是Maven 2.0.1;然后解壓,并設(shè)置環(huán)境變量M2_HOME= Maven2的解壓安裝目錄;最后將%M2_HOME%/bin添加到path中,方便Maven在任何目錄下運行。

    Maven2的運行命令是mvn,使用mvn -h可以獲得相關(guān)的幫助信息。常用情形:

    • 創(chuàng)建Maven項目:mvn archetype:create
    • 編譯源代碼:mvn compile
    • 編譯測試代碼:mvn test-compile
    • 運行測試:mvn test
    • 產(chǎn)生site:mvn site
    • 打包:mvn package
    • 在本地Repository中安裝jar:mvn install
    • 清除產(chǎn)生的項目:mvn clean

    或許是由于剛剛推出的緣故,Maven2目前還是有一些不盡如人意的地方。尤其是Report部分的plugin,有的是因為目前還沒有,如junit-report。有的則是一些莫名其妙的問題,如checktyle和pmd,在本地locale下都無法正常工作。以pmd舉例,在產(chǎn)生PMD報告時會拋出如下異常:


    
                java.util.MissingResourceException: Can't find bundle for base name pmd-report,
                locale zh_CN
                at java.util.ResourceBundle.throwMissingResourceException(ResourceBundle
                .java:839)
                at java.util.ResourceBundle.getBundleImpl(ResourceBundle.java:808)
                at java.util.ResourceBundle.getBundle(ResourceBundle.java:702)
                ……
                

    幸運的是,Maven2一出現(xiàn)就備受關(guān)注,要不了多長時間,諸如此類的問題應(yīng)該就會很快解決。

    結(jié)論

    Maven2在Maven1的優(yōu)勢基礎(chǔ)之上,又向前邁進了一大步。它提供的這些新特性大大地縮短了開發(fā)管理中的工作量,使得開發(fā)人員將精力集中在實際的業(yè)務(wù)問題上。而且這些新特性對于簡化使用,普及最佳實踐,也起到了積極的作用。





    參考資料

    作者簡介

    胡鍵,西安交通大學(xué)碩士,2000年畢業(yè)后一直從事軟件開發(fā)。2002年開始使用Java,在平時的項目開發(fā)中經(jīng)常采用OpenSource的工具,如Ant、Maven、Hibernate、Struts等,目前正在研究信息集成方面的規(guī)范和技術(shù)。可以通過jianhgreat@hotmail.com與他取得聯(lián)系,或訪問個人blog:http://blog.donews.com/foxgem/


     

    胡偉紅,西安交通大學(xué)碩士,目前就職于IBM 區(qū)域合作伙伴支持中心。主要負責(zé)Websphere產(chǎn)品的支持。對開源的項目有很大的興趣。可通過 huweih@cn.ibm.com 與她聯(lián)系

    posted on 2010-02-04 22:41 rogerfan 閱讀(427) 評論(0)  編輯  收藏 所屬分類: 【開源技術(shù)】
    主站蜘蛛池模板: 亚洲国产成人99精品激情在线| 久久亚洲精品无码| 亚洲欧美精品午睡沙发| 中文字幕乱码免费视频| 亚洲天堂电影在线观看| 99久久久精品免费观看国产| 亚洲国产精品xo在线观看| 免费在线观看h片| 亚洲最大成人网色香蕉| 成年女人午夜毛片免费看| 亚洲国产成人无码AV在线| 又大又粗又爽a级毛片免费看| 特级毛片免费播放| 国产亚洲自拍一区| 无码人妻丰满熟妇区免费| 久久久久久亚洲AV无码专区| 国产一卡2卡3卡4卡2021免费观看| 亚洲中文字幕无码中文字| 国产午夜免费福利红片| 成人妇女免费播放久久久| 亚洲人成影院在线| 成人av免费电影| 理论片在线观看免费| 亚洲国产精品无码av| 57pao一国产成永久免费 | 国产V亚洲V天堂无码久久久| 久久综合九色综合97免费下载| 亚洲午夜精品在线| 免费无码看av的网站| 三级网站在线免费观看| 亚洲乱码中文字幕小综合| 免费又黄又爽的视频| 国产精品免费看久久久| 久久久久久亚洲精品影院| 亚洲色偷拍区另类无码专区| 一级毛片成人免费看免费不卡| 亚洲精品自偷自拍无码| 亚洲日韩精品一区二区三区无码| 69天堂人成无码麻豆免费视频| 深夜福利在线免费观看| 亚洲国语精品自产拍在线观看|