精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

NetBeans Struts之頁面布局

開發(fā) 后端
Struts 內(nèi)置了Tiles,利用它可以很好復(fù)用頁面,使用起來就像我們復(fù)用類一樣。

在以前的開發(fā)過程中,我常常遭遇這樣的經(jīng)歷,要完成某個任務(wù),首先由頁面設(shè)計人員來設(shè)計頁面原型,再交給程序員進行處理。很多情況下,我們總是要整理一個完整的頁面。事實上,我們做了太多的重復(fù)工作。很多頁面的結(jié)構(gòu)是完全相同的,頁面的頭,尾,導(dǎo)航菜單都是相同的,只是主體內(nèi)容部分不同而已。重復(fù)整理這些相同的部分是一個不小的負擔(dān),我們很自然的想到,要是這些頁面元素能夠復(fù)用就會省下很多事。

Struts 內(nèi)置了Tiles,利用它可以很好復(fù)用頁面,使用起來就像我們復(fù)用類一樣。

使用Tiles

在以前的開發(fā)過程中,我常常遭遇這樣的經(jīng)歷,要完成某個任務(wù),首先由頁面設(shè)計人員來設(shè)計頁面原型,再交給程序員進行處理。很多情況下,我們總是要整理一個完整的頁面。事實上,我們做了太多的重復(fù)工作。很多頁面的結(jié)構(gòu)是完全相同的,頁面的頭,尾,導(dǎo)航菜單都是相同的,只是主體內(nèi)容部分不同而已。重復(fù)整理這些相同的部分是一個不小的負擔(dān),我們很自然的想到,要是這些頁面元素能夠復(fù)用就會省下很多事。

Struts 內(nèi)置了Tiles,利用它可以很好復(fù)用頁面,使用起來就像我們復(fù)用類一樣。

使用Tiles

1.如果頁面內(nèi)容對頁面進行劃分,一個頁面可以分成很多塊,如header , footer , menu, content,等,如果新聞門戶網(wǎng)站,content可以進一步細分,footall, entertainment, 等。

這里僅僅作演示,我將頁面分header , footer ,content。

展開Configuration Files,打開tile-defs.xml,定義一個最本的頁面模板,其它頁面在這個基礎(chǔ)上進行擴充(這有點像定義一個基類,其它則子類繼承基類,以獲得基類的特性)。

﹤definition name=".mainLayout" path="/layouts/default.jsp">

﹤put name="title" value="Struts Demo Application" />

﹤put name="header" value="/layouts/header.jsp" />

﹤put name="footer" value="/layouts/footer.jsp" />

﹤put name="body" value=".portal.body" />

﹤/definition>

其它頁面以這個為基礎(chǔ),繼承這個模板內(nèi)容,可以重新定義title和body內(nèi)容。

﹤definition name="logonPage" extends=".mainLayout">

﹤put name="title" value="Logon Page" />

﹤put name="body" value="/layouts/logonBody.jsp" />

﹤/definition>

﹤definition name="registerPage" extends=".mainLayout">

﹤put name="title" value="New Registeration " />

﹤put name="body" value="/layouts/registerBody.jsp" />

﹤/definition>

﹤definition name="indexPage" extends=".mainLayout">

﹤put name="title" value="Home Page " />

﹤put name="body" value="/layouts/indexBody.jsp" />

﹤/definition>

﹤definition name="registeredSuccessPage" extends=".mainLayout">

﹤put name="title" value="Registered Successfully" />

﹤put name="body" value="/layouts/registerSuccessBody.jsp" />

﹤/definition>

事實,這和Java中類的繼承非常類似。

2.相應(yīng)的jsp頁面,在Web pages下新建一個layouts目錄。默認模板(即default.jsp)內(nèi)容如下。

﹤html>

﹤head>

﹤meta http-equiv="Content-Type" content="text/html; charset=UTF-8">

﹤title>﹤tiles:getAsString name="title"/>﹤/title>

﹤/head>

﹤body>

﹤div id="header">﹤tiles:insert attribute="header"/>﹤/div>

﹤div id="content">﹤tiles:insert attribute="body"/>﹤/div>

﹤div id="footer">﹤tiles:insert attribute="footer"/>﹤/div>

﹤/body>

﹤/html>

其中,getAsString表示title以一個字符串的形式插入模板。

header.jsp中定義了頁面標題。

﹤%@page contentType="text/html"%>

﹤%@page pageEncoding="UTF-8"%>

﹤div>﹤h1>Struts Demo Application﹤/h1>﹤/div>

footer.jsp內(nèi)容版本聲明,如下:

﹤%@page contentType="text/html"%>

﹤%@page pageEncoding="UTF-8"%>

﹤div>Copyright 2007© hantsy<hantsy@tom.com>﹤/div>

其它頁面,各復(fù)制一份到layouts目錄中,頁面只留body之間的內(nèi)容。

如indexBody.jsp內(nèi)容如下:

﹤%@page contentType="text/html"%>

﹤%@page pageEncoding="UTF-8"%>

﹤%@ taglib uri="/WEB-INF/struts-html.tld" prefix="html" %>

﹤%@ taglib uri="/WEB-INF/struts-bean.tld" prefix="bean" %>

﹤%@ taglib uri="/WEB-INF/struts-logic.tld" prefix="logic" %>

﹤h1>Home Page﹤/h1>

Welcome,

﹤logic:notPresent name="username" scope="session">

Guest !﹤html:link forward="newLogon">Logon ﹤/html:link> or

﹤html:link forward="newRegister">Register Now...﹤/html:link>

﹤/logic:notPresent>

﹤logic:present name="username" scope="session">

﹤bean:write name="username" scope="session"/>,

﹤html:link forward="logout">Log Out..﹤/html:link>

﹤/logic:present>

3.修改Struts配置文件,將所有jsp文件路徑替換成tile配置文件中定義的名稱。

﹤action-mappings>

﹤action path="/logout" type="com.myapp.web.LogoutAction"/>

﹤action input="registerPage" name="UserForm" path="/register" scope="session" type="com.myapp.web.RegisterAction">

﹤forward name="success" path="registeredSuccessPage"/>

﹤/action>

﹤action input="logonPage" name="UserForm" path="/logon" scope="session" type="com.myapp.web.LogonAction"/>

﹤action path="/index" forward="indexPage"/>

﹤action path="/newLogon" forward="logonPage"/>

﹤action path="/newRegister" forward="registerPage"/>

﹤/action-mappings>

值得注意的是,使用Tile必須的兩個最重要的配置,NetBeans在創(chuàng)建項目時已經(jīng)幫我們自動完成了。

一個是注冊Tile插件,打開Struts配置文件struts-config.xml我們就可以看到。

﹤plug-in className="org.apache.struts.tiles.TilesPlugin" >

﹤set-property property="definitions-config" value="/WEB-INF/tiles-defs.xml" />

﹤set-property property="moduleAware" value="true" />

﹤/plug-in>

另外一個是,重新定義controller,將processorClass改成使用 org.apache.struts.tiles.TilesRequestProcessor。

﹤controller processorClass="org.apache.struts.tiles.TilesRequestProcessor"/>

4.運行項目進行測試。

使用Sitemesh

Sitemesh是www.opensymphony.org帶來的另一款優(yōu)秀的頁面布局工具。它不專門針對Struts ,甚至其它語言的web程序也可以使用它。

它使用Decorator模式達到預(yù)期效果。這里可以將頁面分為兩類,decorator(修飾)和decoratored(被修飾)。這就好比有一個相框和各種不同可以用來變換的相片,當相框中放入不同的相片,就得到不同的視覺效果。

1.下載并安裝Sitemesh。

從www.opensymphony.org下載最新的sitemesh 2.3,解壓到硬盤。

將﹤sitemesh>/lib下的common- collections.jar,freemarker.jar, velocity-deps-1.3.1.jar,velocity-tools-view-1.3.1.jar 和﹤sitemesh>/dist下sitemesh-2.3.jar添加到項目Libraries中。

將﹤sitemesh>\src\etc\tld\jsp1.2的sitemesh-decorator.tld和sitemesh-page.tld復(fù)制一份到項目的web/WEB-INF/下面。

2.配置sitemesh。

從configurations中打開web.xml,定義Sitemesh Filter。

﹤filter>

﹤filter-name>sitemesh﹤/filter-name>

﹤filter-class>

com.opensymphony.module.sitemesh.filter.PageFilter

 ﹤/filter-class>

﹤/filter>

﹤filter-mapping>

﹤filter-name>sitemesh﹤/filter-name>

﹤url-pattern>/*﹤/url-pattern>

﹤/filter-mapping>

在下面的jsp-config中添加sitemesh的taglib定義,在最新的jsp 2.0標準,這不是必須的。

﹤taglib>

﹤taglib-uri>sitemesh-page﹤/taglib-uri>

﹤taglib-location>

/WEB-INF/lib/sitemesh-page.tld

﹤/taglib-location>

﹤/taglib>

﹤taglib>

﹤taglib-uri>sitemesh-decorator﹤/taglib-uri>

﹤taglib-location>

/WEB-INF/lib/sitemesh-decorator.tld

﹤/taglib-location>

﹤/taglib>

在web/WEB-INF在定義兩個基本的sitemesh配置文件,這兩個文件可以sitemesh包復(fù)制過來。

sitemesh.xml定義最基本的應(yīng)用規(guī)則。

﹤sitemesh>

﹤property name="decorators-file" value="/WEB-INF/decorators.xml"/>

﹤excludes file="${decorators-file}"/>

﹤page-parsers>

﹤parser content-type="text/html" class="com.opensymphony.module.sitemesh.parser.HTMLPageParser" />

﹤/page-parsers>

﹤decorator-mappers>

﹤mapper class="com.opensymphony.module.sitemesh.mapper.PageDecoratorMapper">

﹤param name="property.1" value="meta.decorator" />

﹤param name="property.2" value="decorator" />

﹤/mapper>

﹤mapper class="com.opensymphony.module.sitemesh.mapper.FrameSetDecoratorMapper">

﹤/mapper>

﹤mapper class="com.opensymphony.module.sitemesh.mapper.AgentDecoratorMapper">

﹤param name="match.MSIE" value="ie" />

﹤param name="match.Mozilla [" value="ns" />

﹤param name="match.Opera" value="opera" />

﹤param name="match.Lynx" value="lynx" />

﹤/mapper>

﹤mapper class="com.opensymphony.module.sitemesh.mapper.PrintableDecoratorMapper">

﹤param name="decorator" value="printable" />

﹤param name="parameter.name" value="printable" />

﹤param name="parameter.value" value="true" />

﹤/mapper>

﹤mapper class="com.opensymphony.module.sitemesh.mapper.RobotDecoratorMapper">

﹤param name="decorator" value="robot" />

﹤/mapper>

﹤mapper class="com.opensymphony.module.sitemesh.mapper.ParameterDecoratorMapper">

﹤param name="decorator.parameter" value="decorator" />

﹤param name="parameter.name" value="confirm" />

﹤param name="parameter.value" value="true" />

﹤/mapper>

﹤mapper class="com.opensymphony.module.sitemesh.mapper.FileDecoratorMapper">

﹤/mapper>

﹤mapper class="com.opensymphony.module.sitemesh.mapper.ConfigDecoratorMapper">

﹤param name="config" value="${decorators-file}" />

﹤/mapper>

﹤/decorator-mappers>

﹤/sitemesh>

decorators.xml中定義具體的decortor應(yīng)用規(guī)則。

﹤?xml version="1.0" encoding="ISO-8859-1"?>

﹤decorators defaultdir="/decorators">

﹤!-- Any urls that are excluded will never be decorated by Sitemesh -->

﹤excludes>

﹤pattern>/exclude.jsp﹤/pattern>

﹤pattern>/exclude/*﹤/pattern>

﹤/excludes>

﹤decorator name="main" page="main.jsp">

﹤pattern>/*﹤/pattern>

﹤/decorator>

﹤decorator name="panel" page="panel.jsp"/>

﹤/decorators>

3.定義Decorator。

在Web Pages下新建一個目錄,命名為decorators,在這個新建的目錄中新建main.jsp,作為主要的decorator。

﹤%@page contentType="text/html"%>

﹤%@page pageEncoding="UTF-8"%>

﹤%@ taglib uri="http://www.opensymphony.com/sitemesh/decorator" prefix="decorator" %>

﹤%@ taglib uri="http://www.opensymphony.com/sitemesh/page" prefix="page" %>

﹤html>

﹤head>

﹤title>Demo-﹤decorator:title default="Struts Sitemesh Demo..." />﹤/title>

﹤!--link href="﹤%= request.getContextPath() %>/decorators/main.css" rel="stylesheet" type="text/css"-->

﹤decorator:head />

﹤/head>

﹤body>

﹤div>

﹤table width="100%">

﹤tr>

﹤td id="pageTitle">

﹤h1> ﹤decorator:title />﹤/h1>

﹤/td>

﹤/tr>

﹤tr>

﹤td valign="top" height="100%">

﹤decorator:body />

﹤/td>

﹤/tr>

﹤tr>

﹤td id="footer">

﹤page:applyDecorator page="/footer.html" name="panel" />

﹤/td>

﹤/tr>

﹤/table>

﹤/div>

﹤/body>

﹤/html>

另外再定義一個panel。

﹤%@ taglib uri="http://www.opensymphony.com/sitemesh/decorator" prefix="decorator" %>

﹤p>

﹤table width="100%" border=0 cellpadding=0 cellspacing=0>

﹤tr>

﹤td class="panelBody">

﹤decorator:body />

﹤/td>

﹤/tr>

﹤/table>

﹤/p>

文件中,decorator:title和decorator:body定義要被替換的內(nèi)容位置,應(yīng)用之后,分別替換成decoratored頁面的title和body標簽中間的內(nèi)容。

下面將Web Pages下的頁面恢復(fù)成原貌。如index.jsp內(nèi)容如下。

﹤%@page contentType="text/html"%>

﹤%@page pageEncoding="UTF-8"%>

﹤%@ taglib uri="/WEB-INF/struts-html.tld" prefix="html" %>

﹤%@ taglib uri="/WEB-INF/struts-bean.tld" prefix="bean" %>

﹤%@ taglib uri="/WEB-INF/struts-logic.tld" prefix="logic" %>

﹤html>

﹤head>﹤title>HomePage ﹤/title>﹤/head>

﹤body>

Welcome,

﹤logic:notPresent name="username" scope="session">

Guest !﹤html:link forward="newLogon">Logon ﹤/html:link> or

﹤html:link forward="newRegister">Register Now...﹤/html:link>

﹤/logic:notPresent>

﹤logic:present name="username" scope="session">

﹤bean:write name="username" scope="session"/>,

﹤html:link forward="logout">Log Out..﹤/html:link>

﹤/logic:present>

﹤/body>

﹤/html>

同時還要修改Struts定義文件,將上一節(jié)中tiles定義的page名稱全部還要成具體的頁面路徑。

﹤action-mappings>

﹤action path="/logout" type="com.myapp.web.LogoutAction"/>

﹤action input="/register.jsp"

name="UserForm"

path="/register"

scope="session"

type="com.myapp.web.RegisterAction">

﹤forward name="success" path="/registerSuccess.jsp"/>

﹤/action>

﹤action input="/logon.jsp"

name="UserForm"

path="/logon"

scope="session"

type="com.myapp.web.LogonAction"/>

﹤action path="/Welcome" forward="/welcomeStruts.jsp"/>

﹤action path="/index" forward="/index.jsp"/>

﹤action path="/newLogon" forward="/logon.jsp"/>

﹤action path="/newRegister" forward="/register.jsp"/>

﹤/action-mappings>

另外還要禁用tiles,以免和sitemesh發(fā)生沖突。注釋掉controller定義,讓Struts使用默認的requestProcessor。

【編輯推薦】

  1. NetBeans 6.7 RC2發(fā)布 正式版月底出爐
  2. Eclipse還是Netbeans
  3. 使用Netbeans操作MySQL數(shù)據(jù)庫
  4. Ubuntu9.04下的Netbeans6.5.1字體無法抗鋸齒的解決辦法
  5. Netbeans6.7平臺Scala插件V1版發(fā)布

 

責(zé)任編輯:佚名 來源: 163博客
相關(guān)推薦

2009-06-10 14:53:25

netbeans st實例

2012-05-14 21:08:47

Android頁面布局

2010-09-03 10:58:45

DIVCSS

2009-07-06 18:23:56

Struts和JSPJSP頁面

2010-09-14 08:53:06

DIVTable

2010-05-25 15:22:30

NetBeans SV

2010-05-25 14:54:18

2009-06-09 16:01:36

NetBeansIDEjava

2009-08-07 10:27:45

Eclipse和Net

2010-09-09 16:36:36

DIV標簽

2009-06-05 15:22:28

NetbeansEclipse

2013-02-22 13:55:37

CSSWeb

2010-08-16 09:32:01

DivCSS

2009-06-22 13:15:00

NetBeans XS

2009-06-09 16:41:46

NetBeans快捷鍵java

2009-06-11 09:24:59

NetBeans入門

2009-06-10 20:30:49

NetBeans Pl

2009-07-17 12:44:01

NetBeans開發(fā)S

2010-09-13 09:17:27

DIV頁面

2021-08-12 15:01:09

鴻蒙HarmonyOS應(yīng)用
點贊
收藏

51CTO技術(shù)棧公眾號

欧美美女直播网站| 国产精品欧美一区二区三区| 97久久精品在线| 非洲一级黄色片| 精品国产亚洲一区二区三区大结局| 一级女性全黄久久生活片免费| 久久久久久久久久久一区 | 久久伊伊香蕉| 精品无人码麻豆乱码1区2区| 国内精品久久久久久影视8| 偷拍夫妻性生活| 久久久久毛片免费观看| 亚洲午夜羞羞片| 少妇精品久久久一区二区| 久久夜靖品2区| 国产伦一区二区三区色一情| 欧美日韩中文字幕| 久久蜜桃资源一区二区老牛| 成年永久一区二区三区免费视频 | 综合激情久久| 国产在视频线精品视频| 国产精品自拍偷拍| 欧美性做爰猛烈叫床潮| 国产精品a久久久久| 亚洲国产精品无码久久久| 国产一区再线| 99久久久久久| 成人在线免费视频| 国产免费裸体视频| 欧美四级电影在线观看| 韩国精品一区二区三区| 国产在线观看精品一区| 久久精品视频在线观看免费| 日韩中文字幕国产| 日韩电影免费一区| 性生活三级视频| 中文字幕中文字幕一区三区| 日韩精品极品在线观看播放免费视频| 亚洲乱码精品| 精品国产av一区二区三区| 亚洲国产一二三精品无码| 欧美主播一区二区三区| 亚洲动漫精品| av最新在线观看| 欧美日韩综合精品| 欧美日韩dvd在线观看| 精品久久91| 中国精品一区二区| 黄色小视频大全| 精品亚洲男同gayvideo网站| 在线亚洲自拍| 日韩精品成人av| 91猫先生在线| 亚洲免费视频网站| 国内精品写真在线观看| 日韩欧美中文字幕在线视频| 久久久久久**毛片大全| 国产精品一区二区三区四区五区| 极品魔鬼身材女神啪啪精品| 不卡av中文字幕| 秋霞午夜av一区二区三区| 欧美最顶级的aⅴ艳星| 日韩免费一二三区| 99成人在线| 日产日韩在线亚洲欧美| 天天干天天操天天操| 日韩精品国产精品| 国产精品亚洲片夜色在线| 制服丝袜在线一区| 极品少妇一区二区三区精品视频 | 日本美女高清在线观看免费| 国产精品白丝在线| 日韩亚洲欧美一区二区| 91超碰国产在线| 色诱视频网站一区| 粉色视频免费看| 99香蕉久久| 亚洲欧美制服丝袜| 精品国产国产综合精品| 国内精品美女在线观看| 日本高清+成人网在线观看| 一级久久久久久| 国产一区二区三区在线观看免费视频 | 亚洲成人免费在线视频| 人妻丰满熟妇aⅴ无码| 欧美综合一区| 久久福利视频导航| 国偷自拍第113页| 九九视频精品免费| 国产精品三区www17con| a视频网址在线观看| 一区二区三区日韩欧美| 男人亚洲天堂网| 国产午夜亚洲精品一级在线| 亚洲精品97久久| 少妇视频一区二区| 一本色道久久综合亚洲精品高清 | 亚洲欧美tv| 精品国模在线视频| 国产欧美一区二区三区在线看蜜臂| 日本不卡一区二区| 97中文在线| 国产高清视频在线观看| 亚洲午夜私人影院| 做a视频在线观看| 天海翼精品一区二区三区| 日韩中文视频免费在线观看| 日韩 欧美 精品| 六月丁香婷婷色狠狠久久| 国产乱码精品一区二区三区中文 | 偷拍视屏一区| 欧美老女人在线视频| 亚洲高清视频免费观看| 不卡一区在线观看| 国产精品一区在线免费观看| 日韩成人亚洲| 精品国产免费视频| 极品魔鬼身材女神啪啪精品| 日韩av中文在线观看| 国产精品有限公司| 91麻豆免费在线视频| 欧美在线看片a免费观看| 成人性生活免费看| 欧美日韩精品| 国产日韩在线亚洲字幕中文| 日本福利在线观看| 午夜精品久久久久久久久久久 | 狠狠狠狠狠狠狠| 成人18视频日本| 99久久久精品视频| 日本精品在线播放| 久久国产精品99国产精| 亚洲视频中文字幕在线观看| 国产欧美综合在线| 精品免费国产一区二区| 午夜欧洲一区| 97精品国产91久久久久久| www.热久久| 亚洲在线观看免费视频| 国产伦理在线观看| 国产一区美女| 成人欧美视频在线| 久久五月精品中文字幕| 日韩精品一区在线观看| 午夜69成人做爰视频| 国产精品99久久久久久久vr| 中文字幕第一页亚洲| 国产va免费精品观看精品| 精品国产一区二区三区久久久| 夜夜爽8888| 国产精品天美传媒沈樵| aaa一级黄色片| 亚洲一区欧美| 爱情岛论坛亚洲入口| 天堂va在线| 亚洲福利视频二区| 黄色片免费观看视频| 2021久久国产精品不只是精品| 黄色免费观看视频网站| 你懂的视频欧美| 国产精品视频久久| 成人在线影视| 亚洲精品一区二区精华| www亚洲视频| 日本一区二区三区dvd视频在线| 性生活免费在线观看| 亚洲经典一区| 国产日韩在线一区二区三区| 粉嫩一区二区| 中文字幕日韩欧美精品在线观看| 一区二区三区免费观看视频| 尤物av一区二区| 亚洲第一黄色网址| 日韩成人精品在线| 日本一级淫片演员| 精品淫伦v久久水蜜桃| 国产成人97精品免费看片| 免费观看久久久久| 亚洲成人av在线| 久久永久免费视频| 一区二区三区欧美日韩| 一级黄色片大全| 国产在线视频一区二区三区| 欧美视频在线观看视频| 欧美男男gaytwinkfreevideos| 国产裸体写真av一区二区| 青青在线视频| 亚洲深夜福利在线| 超碰在线人人干| 色狠狠一区二区三区香蕉| 黄色录像免费观看| 久久综合久久综合九色| 一级 黄 色 片一| 久久成人国产| 国产 国语对白 露脸| 国产精品嫩模av在线| 99高清视频有精品视频| 亚洲天堂一区二区| 久久久久久久网站| 在线免费观看黄色av| 亚洲国产精久久久久久| 国产精品久久久久久无人区| 欧美三级免费观看| 免费麻豆国产一区二区三区四区| 久久久久国产免费免费| 国内自拍偷拍视频| 麻豆视频观看网址久久| 97成人在线观看视频| 亚洲破处大片| 色综合久久av| 天堂资源在线亚洲| 99热最新在线| 日韩一级视频| 国产精品扒开腿做| 日韩电影免费看| 欧美激情成人在线视频| 日本亚洲精品| 一区二区三区黄色| 欧美色图另类| 亚洲精品久久久久中文字幕二区| 国产女无套免费视频| 欧美视频你懂的| 天堂中文在线网| 亚洲国产精品嫩草影院| 疯狂试爱三2浴室激情视频| 国产欧美在线观看一区| xxxxx在线观看| 91视频免费观看| 波多野结衣先锋影音| 高清不卡一区二区| 一区二区三区人妻| 国产乱码一区二区三区| 欧美成人手机在线视频| 久久国产精品露脸对白| 中文字幕第21页| 日本欧美加勒比视频| 欧美激情成人网| 久久精品三级| 99久久久无码国产精品6| 性欧美精品高清| 情侣黄网站免费看| 久久永久免费| 又色又爽又高潮免费视频国产| 六月天综合网| www.国产区| 日本中文字幕一区二区有限公司| 日韩av在线综合| 蜜臀精品久久久久久蜜臀| 毛葺葺老太做受视频| 日本欧美在线观看| 欧美美女性视频| 国产一区二区三区免费| 又黄又爽又色的视频| 国产成人免费xxxxxxxx| 美女伦理水蜜桃4| 99久久伊人网影院| 中文字幕免费高清| 日本一区免费视频| 久艹在线观看视频| 亚洲免费在线播放| 国产一级视频在线观看| 好吊成人免视频| 国产美女www爽爽爽| 555www色欧美视频| 你懂的网站在线| 亚洲欧美日韩精品| 香蕉视频在线看| 欧美交受高潮1| 成人自拍av| 成人精品网站在线观看| 91午夜精品| 欧美日韩国产综合在线| 欧美超碰在线| 成人性免费视频| 日日摸夜夜添夜夜添亚洲女人| 欧美视频国产视频| a级高清视频欧美日韩| 能免费看av的网站| 亚洲欧美日韩国产手机在线| 国产精品2020| 欧美唯美清纯偷拍| 亚洲成人第一区| 国产亚洲精品久久久优势 | 国内自拍欧美激情| 成人黄色免费网站| 电影午夜精品一区二区三区| 久久不见久久见免费视频7| 一区二区三区四区不卡| 亚洲精品影视| 久久人人爽av| 91亚洲国产成人精品一区二区三| 国产馆在线观看| 五月婷婷综合激情| 国产精品主播一区二区| 亚洲精品一区av在线播放| 91精品久久久久久粉嫩| 国产91精品最新在线播放| 中文字幕一区二区三区四区久久| 神马影院午夜我不卡| 在线高清一区| 色噜噜狠狠一区二区三区狼国成人| 97超碰欧美中文字幕| 永久免费看黄网站| 在线日韩国产精品| 日韩在线观看视频一区二区三区| 色爱精品视频一区| 不卡av播放| 国产精品久久一区二区三区| 欧美成人直播| 无码内射中文字幕岛国片| 成人免费的视频| 69av视频在线| 欧美日韩一本到| 精品乱码一区二区三四区视频| 久久久久久久久网站| 国产在线一区不卡| 伊人av成人| 日韩激情一二三区| 无码人妻aⅴ一区二区三区 | 国产日韩一级二级三级| 国产真实乱偷精品视频| 欧美一区二区视频在线观看2022 | 777国产偷窥盗摄精品视频| 久久天堂久久| 中文字幕一区二区三区5566| 日韩av一级片| 一色道久久88加勒比一| 精品欧美aⅴ在线网站| 日韩在线观看视频一区| 欧美极品少妇xxxxⅹ喷水| 2020最新国产精品| 最新av网址在线观看| 精品伊人久久久久7777人| 黄大色黄女片18免费| 91国偷自产一区二区开放时间| 欧洲一级在线观看| 91精品国产色综合久久不卡98口| 粉嫩精品导航导航| 免费人成自慰网站| 成人网页在线观看| 国产精品不卡av| 亚洲国内精品在线| 92久久精品| 精品麻豆av| 亚洲美女网站| 亚洲一级中文字幕| 91国在线观看| 97超碰国产一区二区三区| 国产精品影片在线观看 | 欧美成人高潮一二区在线看| 成人免费看视频| 久久不卡免费视频| 亚洲人成在线观| 777午夜精品电影免费看| 亚洲人久久久| 国产一区二区网址| 日韩人妻无码一区二区三区99 | 在线毛片网站| 92国产精品视频| 今天的高清视频免费播放成人| 香港三日本8a三级少妇三级99| 岛国精品视频在线播放| 国产美女性感在线观看懂色av | 毛片一区二区三区四区| 欧美国产欧美综合| 国产三级小视频| 97色在线视频观看| 国产一区国产二区国产三区| 亚洲另类第一页| 亚洲一区二区视频在线观看| 天堂网在线中文| 国产精品极品美女粉嫩高清在线| 日韩影院二区| 少妇伦子伦精品无吗| 黑人巨大精品欧美一区二区一视频 | 久久精品视频2| 欧美另类在线播放| 西瓜成人精品人成网站| 手机av在线免费| 午夜精品123| 岛国在线大片| 国产福利一区二区三区在线观看| 免费在线观看成人av| 日本一级二级视频| 亚洲欧美成人精品| 久久久精品区| 黄色成人免费看| 亚洲成人免费在线观看| 国产二区视频在线观看| av噜噜色噜噜久久| 热久久国产精品| 伊人国产在线观看| 丝袜一区二区三区| 日韩深夜影院| 图片区乱熟图片区亚洲| 色拍拍在线精品视频8848| 污污视频在线| 亚洲亚洲精品三区日韩精品在线视频| 成人一区二区三区| 91在线视频国产|