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

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

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

    小菜毛毛技術(shù)分享

    與大家共同成長

      BlogJava :: 首頁 :: 聯(lián)系 :: 聚合  :: 管理
      164 Posts :: 141 Stories :: 94 Comments :: 0 Trackbacks
    AppFuse是一個集成了眾多當前最流行開源框架與工具(包括Hibernate、ibatis、Struts、Spring、DBUnit、Ant、Log4J、Struts Menu、Xdoclet、SiteMesh、OSCache、JUnit、JSTL)于一身的Web開發(fā)框架。AppFuse提供了Web系統(tǒng)開發(fā)過程中都需要開發(fā)的一些功能,如登陸、用戶密碼加密,用戶管理、根據(jù)不同的用戶可以展現(xiàn)不同的菜單.J2EE開發(fā)者也可以在此基礎(chǔ)上開發(fā)加入自己的功能模塊。利用這個框架可以大幅度的提高開發(fā)速度。

    轉(zhuǎn)自:http://blog.chinaunix.net/u/11409/showart_436247.html

    http://blog.csdn.net/changzhang/category/369570.aspx可參考這個網(wǎng)址
    AppFuse是一個集成了當前最流行的Web應(yīng)用框架的一個更高層次的Web開發(fā)框架,也可以說是一個Web開發(fā)基礎(chǔ)平臺,它與它所集成的各種框架相比,它提供了一部分所有Web系統(tǒng)開發(fā)過程中都需要開發(fā)的一些功能,如登陸、用戶密碼加密,用戶管理、根據(jù)不同的用戶可以展現(xiàn)不同的菜單,可以自動生成 40%-60%左右的代碼,自帶了默認的一些在CSS中設(shè)定的樣式,使用這些樣式能很快的改變整個系統(tǒng)的外觀,還有自動化測試的功能。

    它最大的價值就是為我們提供了一個Web開發(fā)的新的方式和思路,盡管這些技術(shù)在國外都已進很流行了,但在國內(nèi)能夠?qū)ibernate、Struts、 Spring、DBUnit、Ant、Log4J、Struts Menu、Xdoclet、SiteMesh、Velocity、JUnit、JSTL、WebWork這些技術(shù)集成到一個框架中的還不多見,所以即使不使用它的全部功能,它也給我們提供了一個很好的借鑒、學(xué)習(xí)的機會。

    通過關(guān)注AppFuse,我們可以看到目前國外的主流開發(fā)都使用了哪些技術(shù),開發(fā)方式是什么樣的,可能達到什么樣的結(jié)果,而在以前,是很少能夠看到這樣完整的例子的。

    AppFuse的另一個啟示是:我們可以依靠開源軟件的功能降低開發(fā)成本,而且可以閱讀開源軟件的代碼提高所在團隊的整體實力。

    AppFuse 的作者 Matt Raible是當今開源世界一個比較活躍的開發(fā)者,它是AppFuse、Struts Menu的作者,也是XDoclet、DisplayTag等一些著名開源項目的積極參與者,《Hibernate In Action》的作者就在感謝的名單里面提到他,XDoclet的下載版本中所帶的Hibernate標簽部分的例子就是他寫的,他還是2004年 Apache技術(shù)年會的主講人之一。

    但是通過2個月的實際學(xué)習(xí)和使用,我也遇到一系列的問題,因為AppFuse是將其他的一些類庫或者框架集成在一起的,集成的技術(shù)眾多,而且有一些技術(shù)在國內(nèi)甚至很少有人知道,資料也比較少,所以雖然作者經(jīng)過了一些測試,但都是基于英文編碼的,而對于中文編碼來說,還潛在的存在著一些問題,雖然不是AppFuse的問題,但卻降低了開發(fā)速度,下面是我在開發(fā)過程中遇到過的問題,有些解決了,有些還沒有解決:
    一.Struts
    1. AppFuse中默認的MVC框架是Struts,而且使用的是LookupDispatchAction,并且使用的是按鈕(button),在XP下用IE瀏覽效果還可以,但如果在2000或者98下,就使外觀很難看,而且當時我還遇到一個問題:如果按鈕顯示中文,則在DisplayTag中翻頁失靈,而且報錯,后來我把BaseAction的相關(guān)方法改變了,才可以使用,因為國內(nèi)的客戶都比較重視界面,所以后來我將那些按鈕都改成圖片了,當然也要添加一些方法了,有點麻煩!
    2. Struts中的標簽如今推薦使用的只有html部分的標簽了,其他的標簽或者可以使用JSTL替代,或者已經(jīng)不推薦使用了,而且AppFuse中推薦使用JSTL,而JSTL和struts的標簽的聯(lián)合使用時,需要的不是<html:標簽>,而是<html-el:標簽>,這個問題曾經(jīng)困擾了我整整2天。
    3. Struts的Validation的校驗規(guī)則并不完善,比如如果使用客戶端的javascript校驗,則在郵箱中輸入漢字根本校驗不出來,到了服務(wù)器端報錯。
    4.最嚴重的問題是AppFuse生成的Struts的validation.xml文件中有許多多余的“.”,如果你去掉了,常常在執(zhí)行ant的 deploy任務(wù)時又恢復(fù)原樣。這樣是提交表單的時候經(jīng)常會報javascript的腳本錯誤或者缺少對象或者缺少value,所以我會手工的修改這個文件,然后把修改后的文件備份,當重新生成有錯誤的文件時,我會用備份的沒有錯誤的文件去覆蓋。
    5. Struts的validatioin對于使用同一個FormBean的Action的校驗方式比較復(fù)雜。(待解決)。
    二.Hibernate
    1. Hibernate是現(xiàn)在受到越來越多的人推崇的一個ORM工具(框架、類庫),它將我們從繁瑣的使用JDBC的開發(fā)過程中解放出來,但同時也帶來了新的問題,如學(xué)習(xí)曲線,執(zhí)行效率,數(shù)據(jù)庫設(shè)計優(yōu)化,還有最重要的靈活性。Hibernate不是一個很容易上手的東西,要完全駕馭它還需要讀很多資料,但好的資料卻很少。
    2. 使用Xdoclet可以很方便的生成Hibernate中的持久類的配置文件(*.hbm.xml),但對一些特殊的映射卻無能為力,如使用序列的id生成規(guī)則,序列的名字沒有地方寫,所以也只好先利用它生成主要的內(nèi)容,然后手工修改。
    3. 同樣還是id的生成策略問題,如果使用序列、hilo等需要一些數(shù)據(jù)庫機制支持的策略時,schemaExport并不能自動生成序列或者保存當前id的表,這項工作仍然要手工解決。
    4. Hibernate中提供了幾種關(guān)聯(lián),一對一、一對多、多對多,但對于怎樣調(diào)整效率卻沒有一個很明確的提示,還要根據(jù)情況判定,這就帶來和一些彈性的設(shè)計。
    5. Hibernate中可以選擇的操作數(shù)據(jù)庫的方式有3種,其中HQL功能最強大,但有些功能使用標準查詢可能會更方便,但會有一些限制,所以雖然它很靈活,但易用性不如JDBC好。
    三.Spring
    在AppFuse的過程中,Spring完全隱藏在幕后,除了一些配置外,幾乎感覺不到它的存在,所以我在使用它的過程中并沒有遇到什么麻煩,這里只是簡單的介紹一下它在AppFuse中起到的作用。
    1. Spring在AppFuse中起到的主要作用是對Hibernate的Session和事務(wù)的管理,利用Spring封裝的Hibernate模板類,我們大大地減少了實現(xiàn)DAO的代碼行數(shù)。
    2. Spring還起到了連接映射文件和類之間的關(guān)聯(lián),及接口和實現(xiàn)類之間的關(guān)聯(lián),這些都依賴于Spring的IoC的機制的實現(xiàn)。
    3. 對于字符進行編碼和解碼部分用到了Spring自帶的Filter,只需要在配置文件中配置就好了。

    四.SiteMesh
    SiteMesh是一個基于Decorator模式的技術(shù),它可以修飾返回的網(wǎng)頁文件,它的工作方式受到越來越多的人的推崇,這點從Manning出版的一些技術(shù)書籍中可以看出來。
    我在使用SiteMesh的過程中并不順利,我參考了《Java Open Source Programming》,這本書中說SiteMesh在默認的情況下不對下載文件進行裝飾,但我在下載文件時發(fā)現(xiàn),我的文件內(nèi)容被丟棄了,取而代之的是 SiteMesh的模板的內(nèi)容,后來我通過修改SiteMesh的配置文件解決了這個問題,但感覺還有一些不太清楚的地方需要學(xué)習(xí)。

    五.DisplayTag
    DisplayTag 是一個優(yōu)秀的顯示內(nèi)容的標簽,從SourceForge的訪問量來看,它是很活躍的項目,僅次于Ant、Hibernate、Xdoclet等幾個著名的項目,我總結(jié),它的主要功能有4項:顯示、分頁、排序、將顯示的數(shù)據(jù)寫入指定類型的文件中,然后下載。
    1. 據(jù)我使用的情況看,我只使用了分頁和顯示的功能,因為當時我沒有很好的解決中文編碼的問題,所以排序會有問題,直到昨天,我在朋友的幫助下解決了這個問題,至此我可以放心使用的功能又增加了排序(我昨天簡單的測試了一下是可以的)。

    2. 但對于將顯示的內(nèi)容生成到一個指定格式的文件中的功能卻有著很多缺陷,如:
    (1) 生成的文件中只有顯示的數(shù)據(jù),那些沒有顯示在界面上的的數(shù)據(jù),則不會被寫到文件中。
    (2) 如果修改了DisplayTag的顯示的內(nèi)容,比如添加一列,在這列中的內(nèi)容不是字符,而是HTML的標簽,則生成的文件只有這些HTML標簽,而沒有數(shù)據(jù)。
    (3) 即使DisplayTag中沒有我們定制的HTML腳本,生成的文件偶爾也有問題,比如:它會把“007”生成為“7”,把字符串自動的轉(zhuǎn)換為整型值。有時候還生成空白內(nèi)容的文件。
    (4) DisplayTag生成的Excel文件兼容性不好,有時在Excel2003中不能正常打開,或者在XP下打開報錯。
    后來,我看了作者寫的《Spring Live》,書中說如果想實現(xiàn)穩(wěn)定的Excel,推薦使用POI,于是我使用POI生成Excel,穩(wěn)定性和兼容性都不錯。

    六.DBUnit
    DBUnit是一個可以被Ant集成的向數(shù)據(jù)庫中添加數(shù)據(jù)和備份數(shù)據(jù)的一個類庫,配置很方便,因為AppFuse已經(jīng)集成好了,所以使用也很容易。
    但是如果你使用EditPlus之類的工具手工修改了AppFuse生成的內(nèi)容,則執(zhí)行Ant的setup、setup-db或者deploy的任務(wù)時,常常報錯,說無效的格式,這是因為這個被手工修改的文件再次被AppFuse執(zhí)行后,它的第一行的文件聲明的前幾個字母是無效的,是因為本地的字符集編碼的原因而引起了亂碼,如果把這幾個無效的字母去掉,問題就解決了。

    七.Struts Menu
    Struts Menu也是AppFuse的作者開發(fā)的一個開源軟件,它可以根據(jù)配置文件讀取當前用戶可以使用的功能菜單,這個功能是我一直以來都想要的,我也找到了一些代碼,但實現(xiàn)的都不如這個完善,沒什么好說的,使用簡單,配置容易,很好的解決了我的問題。
    問題是我只使用了AppFuse提供的2個角色,對于多個角色的實驗我還沒有做。

    八.XDoclet
    在AppFuse中,使用Xdoclet生成了幾乎一切的配置文件:Struts-config.xml、web.xml、validation.xml、*.hbm.xml等文件,如果使用AppGen的話,還會生成更多的文件,這一切都是使用Xdoclet實現(xiàn)的。
    問題是我在Struts部分提到的,生成的Validation.xml文件中會多生成一個“.”,另外在生成資源文件時也會多生成一個“.”,目前我沒有很好的閱讀這段代碼,不知道是不是Xdoclet的問題。

    九.Ant
    Ant并沒有什么問題,但在執(zhí)行作者寫的Ant任務(wù)的時候,有一些任務(wù)不能正常執(zhí)行,比如,運行模擬對象測試的任務(wù),作者也在1.7版本的修復(fù)列表中提到以前版本有些ant任務(wù)不能執(zhí)行,在1.7中修改了一些ant任務(wù),使他們能夠正常的執(zhí)行了。
    實際上,我們?nèi)绻褂肁ppGen進行開發(fā)的話,使用的任務(wù)一般不超過8個。

    十.JSTL
    JSTL 是個好東西,我常用的有<c:>和<fmt:>部分的標簽,但是如果使用JSTL進行邏輯判斷,我并沒有感覺比使用JSP的代碼塊優(yōu)雅多少。另外,熟悉JSTL也需要一段時間,我就經(jīng)歷了面對著JSP頁面不知道該怎么寫JSTL語法的困境。當然,AppFuse中使用的基本都是 JSTL,包括向DisplayTag傳遞顯示的數(shù)據(jù),使用的都是JSTL語法,這方面的資料挺多,我參考的是電子工業(yè)出版社出的《JSP2.0技術(shù)》,說的很詳細。

    十一.Tomcat
    你也許會說:“Tomcat就不用說了吧?”,是的,Tomcat一般都會使用,但是 ―――――――――――――Tomcat5和Tomcat4.X對于中文編碼使用了不同的機制,這個問題困擾了我好久,我解決了頁面上寫入漢字顯示亂碼的問題,我也曾經(jīng)以為DisplayTag對漢字不能排序,也不能正常分頁是因為DisplayTag的開發(fā)者都是老外,是因為他們沒有考慮中文的關(guān)系的原因。
    直到昨天,我才知道這一切都是因為Tomcat5對漢字編碼的實現(xiàn)的方式和Tomcat4不一樣的原因,如果感興趣,可以看看這個帖子: http://www.javaworld.com.tw/jute/post/view?bid=9&id=44042&sty=1&tpg=1&age=0

    十二.JavaScript
    JavaScript簡單易學(xué),但想運用自如就不太容易了。AppFuse中嵌入了幾個js文件,里面包含了許多函數(shù),值得我們好好的研究一下,比如,如果有一個必填字段沒有填寫,AppFuse會自動的聚焦在那個input上,類似的小技巧有很多,你可以自己去翻看。
    但AppFuse 自帶的JavaScript腳本有一個Bug,就是當DisplatyTag中沒有可以顯示的數(shù)據(jù)時,你用鼠標單擊,它會報JavaScript錯誤,你仔細研究一下function highlightTableRows(tableId) 就知道了:我的解決辦法是在location.href = link.getAttribute("href");前面添加一行判斷:if (link != null)。

    十三.資源文件國際化
    對于Struts和DisplayTag都涉及到資源文件國際化AppFuse1.6.1很好的解決了Struts資源映射文件國際化的問題,你只需要在對應(yīng)本國語言的資源文件中寫入漢字,Ant中有一項執(zhí)行native2ascii的任務(wù),AppFuse自動的為你進行了資源文件的編碼轉(zhuǎn)換,而對于 DisplayTag的資源文件問題,還要自己執(zhí)行native2ascii命令,為了避免每次都輸入一串命令,我用Delphi寫了個小工具,可視化的選擇資源文件,點擊按鈕自動執(zhí)行該命令,底層依賴于JDK。


    經(jīng)過2個多月的學(xué)習(xí),我感覺這個框架非常不錯,它為我以后的項目開發(fā)指出了一個新的方向,但如果想很熟練的使用這個框架進行開發(fā),至少要對以下幾種技術(shù)比較熟練:Struts(或者WebWork、Spring及其他的已經(jīng)整合進來的MVC框架)、Hibernate(或者ibatis)、JSTL,當然其他的技術(shù)至少也要知道一點,否則遇到問題都不知道出在哪里。


    目前我還沒有解決的問題有:
    1. 如何在翻頁的時候才讀取下面的數(shù)據(jù)?
    2. 怎樣對使用同一個FormBean的多個Form進行客戶端校驗?
    3. 怎樣優(yōu)化Hibernate的效率?《Hibernate In Action》中提供了多種策略,有些時候應(yīng)該使用lazy,有些時候應(yīng)該使用outer-join。
    4.在什么時機生成導(dǎo)出文件?目前我是在查詢的Action中同時生成了導(dǎo)出文件,否則,到了下一頁,我就不知道查詢條件了,當然,如果把拼裝后的HQL存儲在Session或者Hidden中也可以解決這個問題,但是這樣就破壞了DAO的封裝,要把DAO封裝后的HQL發(fā)送給Action,然后發(fā)送的到 Web界面層,所以目前我還在猶豫生成導(dǎo)出文件的時機選擇在哪里?
    5. 什么時候應(yīng)該自己獲取數(shù)據(jù)庫連接,執(zhí)行native SQL?具體需要注意些什么?
    6. SiteMesh的模板優(yōu)化?
    7. DisplayTag的底層實現(xiàn)?


    每個問題都比較棘手,要一個一個解決!

    這個框架的優(yōu)點是:如果熟悉了開發(fā)流程,可以大幅度的提高開發(fā)速度,如果業(yè)務(wù)不是很復(fù)雜,使用AppGen可以生成60%左右的代碼,而且程序可維護性好,因為作者使用了多個設(shè)計模式對各個層面進行了封裝,所以不同的模塊代碼風格出奇的一致,有利于開發(fā)人員快速上手,也有利于接收其他開發(fā)人員遺留的代碼。

    兔八哥
    2004-2-3下午15:51

    ++++++++++++++++++++

    引用:
    有沒有成功的項目同我們分享一下?

     

    我已經(jīng)使用AppFuse開發(fā)了2個項目了,都是教育系統(tǒng)的,系統(tǒng)都不大,我一個人用實際開發(fā)一個月,因為是公司的項目,源碼不好外發(fā),但主要的東西都是一樣的,對于AppFuse我也沒有修改多少,否則,往新版本移植就會有問題了。
    我遇到的問題,能想起來的我都寫下來了,如果有其他的問題,我們可以一起討論。
    最近我有個朋友在使用WebWork的AppFuse版本進行開發(fā),他遇到的問題和我基本差不多,有交流才有進步,呵呵!
    Very Happy

    感謝樓上幾位的熱心解答,謝謝!

    +++++++++++++++++++++++

    引用:
    目前我還沒有解決的問題有:
    1. 如何在翻頁的時候才讀取下面的數(shù)據(jù)?
    2. 怎樣對使用同一個FormBean的多個Form進行客戶端校驗?
    3. 怎樣優(yōu)化Hibernate的效率?《Hibernate In Action》中提供了多種策略,有些時候應(yīng)該使用lazy,有些時候應(yīng)該使用outer-join。
    4.在什么時機生成導(dǎo)出文件?目前我是在查詢的Action中同時生成了導(dǎo)出文件,否則,到了下一頁,我就不知道查詢條件了,當然,如果把拼裝后的HQL存儲在Session或者Hidden中也可以解決這個問題,但是這樣就破壞了DAO的封裝,要把DAO封裝后的HQL發(fā)送給Action,然后發(fā)送的到 Web界面層,所以目前我還在猶豫生成導(dǎo)出文件的時機選擇在哪里?
    5. 什么時候應(yīng)該自己獲取數(shù)據(jù)庫連接,執(zhí)行native SQL?具體需要注意些什么?
    6. SiteMesh的模板優(yōu)化?
    7. DisplayTag的底層實現(xiàn)?


    1.關(guān)于翻頁的問題,如果你剛開始使用AppFuse開發(fā)的話,推薦使用valuelist,它可以和Hibernate很好的集成,我的一個網(wǎng)友用的就是這個東西,雖然界面沒有DisplayTag漂亮,但關(guān)于分頁卻不用你操太多的心,
    因為這幾天天天開會,所以也沒有做些技術(shù)實驗,另一個朋友告訴我有一個老外把DisplayTag分頁部分修改了,在JIRA上有源碼下載,我下來了,還沒有看,還有一個思路,就是分析DisplayTag的分頁的格式,然后用Filter解析,然后把當前頁號傳入DAO,然后使用標準查詢進行查詢分頁,但要對AppFuse的接口和方法添加參數(shù),正在猶豫中,還有更簡單的方法,直接在Session中放入當前的頁號,每次都刷新,就不用Filter了,然后同樣修改方法和接口。

    2.對于Struts的使用同一個FormBean的多個Form進行客戶端校驗,在孫衛(wèi)琴的Struts的書中已經(jīng)提到了,即使她的方法不管用,也可以手寫JavaScript來解決,只是我不愿意而已,如果別無他法,則只能如此了。

    3. 優(yōu)化Hibernate的效率,其實對我的程序來說問題不大,我的表比較少,基本只有3層的級聯(lián),而且對于數(shù)據(jù)字典和業(yè)務(wù)表之間的關(guān)聯(lián),我采用的是業(yè)務(wù)表到數(shù)據(jù)字典表的many-to-one,這樣的單向關(guān)聯(lián)比較簡單,也能夠滿足我的要求,性能會好一點點,再加上分頁功能,只查詢當前也內(nèi)容,然后參考《Hibernate In Action》的第七章的內(nèi)容,提高接收效率應(yīng)該是沒有問題的。

    4.關(guān)于到處文件的時機,我正在看關(guān)于模式的書籍,正在找答案,其實還有個簡單的辦法,就是把生成導(dǎo)出文件單獨的實現(xiàn),用戶點擊按鈕才生產(chǎn),當然這樣就要把用戶的查詢條件記下來,當然也涉及到修改接口和方法了,AppFuse中,修改接口和方法很麻煩,如果代碼生成后再修改,要改動很多處,所以前期設(shè)計很重要。

    5.關(guān)于這一點,我一直在找一個硬性的標準,比如關(guān)聯(lián)表超過多少個等等條件就應(yīng)該自己獲取數(shù)據(jù)庫連接,但現(xiàn)在看來這也不是絕對的,如果能夠大幅度提高效率,或者使用 native SQL可以減少工作量或者節(jié)省時間的話,那就可以使用,只是要對這種方式的利弊要有所了解,不幸的是,我還沒有這樣試過,試過的朋友請?zhí)峁┬┙ㄗh,謝謝!

    6.SiteMesh的優(yōu)化,我看到一片文章,也是個老外寫的,忘了出處,說SiteMesh對性能影響不大,可以放心使用,那我就暫時不考慮它了,呵呵。

    7.DisplayTag的底層的原理我早就知道,而且它的文檔的流程圖也有,只是我需要知道更詳細的實現(xiàn)細節(jié),最近在讀源碼,應(yīng)該很快就有結(jié)果了,如果我有好消息,會來這里把解決方案貼出來。


    上面的文字只是我目前的一些思路,因為天天開會,也沒有做技術(shù)實驗,還不知道可行的程度,但我想應(yīng)該都可以實現(xiàn),我只不過是在找更好的辦法,如果你有任何好的思路或者建議,請不吝告知,謝謝,任何建議和意見都是受歡迎的,只是要詳細些,不要拿些空洞的模式來敷衍我,呵呵,目前這樣的“高手”不少,我有些受夠了,呵呵

     

    本文來自CSDN博客,轉(zhuǎn)載請標明出處:http://blog.csdn.net/changzhang/archive/2008/03/12/2172675.aspx




    只有注冊用戶登錄后才能發(fā)表評論。


    網(wǎng)站導(dǎo)航:
    相關(guān)文章:
     
    主站蜘蛛池模板: 亚洲精品亚洲人成在线观看| 成人a视频片在线观看免费| 青草草在线视频永久免费| 亚洲av午夜电影在线观看| 国内精品99亚洲免费高清| 69精品免费视频| 午夜亚洲国产精品福利| 久久精品国产亚洲AV麻豆不卡| 成人毛片18女人毛片免费96| a毛片成人免费全部播放| 亚洲精品成人网站在线播放| 2021在线观看视频精品免费| 亚洲视频日韩视频| 五月亭亭免费高清在线| 极品色天使在线婷婷天堂亚洲 | 亚洲一区二区在线免费观看| 亚洲性无码一区二区三区| 亚洲一区二区三区香蕉| 成年女人午夜毛片免费看| 久久久WWW成人免费精品| va天堂va亚洲va影视中文字幕| 51在线视频免费观看视频| 欧美亚洲精品一区二区| 亚洲酒色1314狠狠做| 亚洲视频在线精品| 丁香花在线观看免费观看| 暖暖免费在线中文日本| 婷婷国产偷v国产偷v亚洲| 亚洲激情电影在线| 在线播放亚洲第一字幕| 国产成人青青热久免费精品| 中文字幕视频免费在线观看 | 国产亚洲精品美女2020久久| 亚洲精品**中文毛片| 自拍偷自拍亚洲精品第1页| 日韩高清在线高清免费| ww4545四虎永久免费地址| 日本免费A级毛一片| youjizz亚洲| 亚洲中文字幕无码专区 | 亚洲成电影在线观看青青|