欧美三区四区_av先锋影音资源站_亚洲第一论坛sis_影音先锋2020色资源网_亚洲精品社区_在线免费观看av网站_国产一区二区伦理_亚洲欧美视频一区二区_99视频精品全部免费在线_精精国产xxxx视频在线

實例解析AJAX與JSF實現帶進度條的批量上傳_JSP教程

編輯Tag賺U幣
教程Tag:暫無Tag,歡迎添加,賺取U幣!

推薦:實例解析Java/JSP中調用SQL Server存儲過程
最近做了個Java的小項目(第一次寫Java的項目哦 ), 到網上搜索了半天,找到了一個比較好點的調用存儲過程的例子,而且網上普遍采用的都是setXXX((int parameterIndex, XXX x)的形式。這種形式感覺不是很直觀,下面就發布一個完整的采用setXXX(String param

一。NetBeans 5.5.1 中的樣例:


 

NetBeans 5.5.1中自帶了一個“文件上載“的例子,使用這個例子,請先下載并安裝以下軟件:

  1. JAVA SE 5 (JDK 1.5) 及以上版本(http://java.sun.com/javase/downloads/index.jsp

  2. NetBeans 5.5.1http://zh-cn.netbeans.org/index_zh_CN.html

  3. Sun Application Server 9.0https://glassfish.dev.java.net/

     

2+3也可以下載“NetBeans IDE 5.5.1 with Java EE Application Server 9.0 U1 Patch 1 bundle ”http://www.netbeans.info/downloads/index.php?rs=22&p=3


 

NetBeans中,選擇菜單“新建項目”-〉“類別”中選擇“樣例”-〉“Java BluePrint Solution” ->AJAX編程模型。項目中選擇“文件上載”。項目名缺省為“fileupload”


 

運行項目“fileupload”, 并且選擇幾個上傳文件,文件類型可以多種多樣,比如pdf, jar, ra, zip, jpeg, gif等等。可以看到如下界面。



傳輸完畢,可以看到如下結果。




 

顯示了上傳文件開始,結束的的時間,上傳文件總的字節數目等等。


 

項目“fileupload”/web/docs/下有一個fileupload.html 的文檔,解釋了這個上傳文件的參數及使用(English)。文件上載是一個JSF控件,開發者需要了解的除了如何在服務器端處理請求中的參數,如何在客戶端顯示響應信息外,所需要了解的僅僅是一些參數的設置。如這個例子中的代碼所示:

<ui:fileUploadTag id="TestFileuploadForm0" retFunction="testRetFunction" retMimeType="text/xml"

postProcessingMethod="#{FileUploadCustomBean.postProcessingMethod}"

progressBarDivId="progress1x" progressBarSubmitId="submit1x" progressBarSize="40">

<input type="file" size="40" name="fileToUpload0" id="fileToUpload0Id"/><br/>

<input type="file" size="40" name="fileToUpload1" id="fileToUpload1Id"/><br/>

<input type="file" size="40" name="fileToUpload2" id="fileToUpload2Id"/><br/>

<input type="submit" id="submit1x" name="submit1x" value="Submit"/><br/>

<div id="progress1x"></div><br/>

</ui:fileUploadTag>


 

參數如下:

id

文件上載JSF控件的標識

serverLocationDir

文件上載的目標目錄。在示范例子中未給出這個參數的應用。缺省的情況下,文件會上載到Sun application Server domains/domain1/lib/upload目錄下。

retFunction

JavaScript 的回調函數,用于客戶端出來服務器返回的響應信息。

retMimeType

服務器端返回響應信息的類型,缺省的是“text/xml ”

postProcessingMethod

服務器端用來處理請求信息的方法。

progressBarDivId

進度條的Id

progressBarSubmitId

和進度條關聯的觸發文件上載的id。示范例子中是“submit”按鈕

progressBarSize

進度條的大小


 


 

二。使用FileUpload控件建立實例PhotoAlbum


 

下面給出另外一個使用這個上傳文件的小例子PhotoAlbum,最主要是為了說明如何提取上傳后的文件名,以及如何用AJAX技術來部分刷新上傳頁面。另外想借這個例子用 NetBeans開發JSF程序的一般流程。


 

1NetBeans中選擇菜單“新建項目”。“類別“中選擇“Web”, 項目中選擇“Web應用程序”。

2。“新建Web應用程序”窗口中,輸入及選擇以下內容:

項目名稱:PhotoAlbum

源代碼結構:Java BluePrints

服務器:Sun Java System Application Server 9

Java EE 版本:Java EE 5





 

注意:如果服務器選擇中沒有出現“Sun Java System Application Server 9”。請在NetBeans中,選擇菜單” 窗口”->“ 運行時”. 在”運行環境”窗口中,鼠標右鍵選擇”服務器”, 點擊”添加服務器”。在”平臺文件夾位置”中選擇安裝”Sun Java System Application Server 9”的目錄。在下一個窗口中,輸入服務器的管理用戶名和密碼(缺省管理用戶名和密碼是“ admin/adminadmin”)。 

3。下一個窗口中,選擇“Java Server Faces”框架。點擊“完成”



 


 





 

4。選擇項目“PhotoAlbum”中的庫,右鍵選擇“添加jar/文件夾”,加入文件上載所需要的幾個jar文件。在NetBeans安裝目錄下,例如C:\Java\netbeans-5.5.1\enterprise3\modules\ext\blueprints,加入以下五個jar文件

    shale-remoting.jar

    bp-ui-5.jar

    commons-logging-1.1.jar

    commons-io-1.2.jar

    commons-fileupload-1.1.1.jar

需要注意的是: 為了完成下面的例子,有兩個jar文件需要比較新的版本,并且需要加入庫rome-0.8.jar. 為方便起見,本文給出下載的jar文件,


 

最后的庫文件為六個:

shale-remoting-1.0.4.jar (http://download.csdn.net/source/236129)

    bp-ui-5-0.8.jar (http://download.csdn.net/source/236127)

    rome-0.8.jar (http://download.csdn.net/source/236128)

    commons-logging-1.1.jar

    commons-io-1.2.jar

    commons-fileupload-1.1.1.jar

     

5。在項目“PhotoAlbum”中的Web目錄下,手工創建一個目錄images. 如果PhotoAlbum的工作目錄是e:\mymodules\PhotoAlbum, 那么這個目錄的絕對路徑是:E:\mymodules\PhotoAlbum\web\images.


 

6。創建JSF Bean, 鼠標右鍵點擊項目“PhotoAlbum”中,選擇“新建文件/文件夾”。在類別中選擇“Web”, 在“文件類型”中選擇“JSF受管Bean”


 


 


 




 

7。“新建JSF受管Bean”窗口中,輸入:

類名:FileUploadBackBean

包:com.sun.sdn.demo.jsf


 


 




 

這步創建完之后,可以查看項目“PhotoAlbum”中“配置文件“下的“faces-config.xml”, 可以看到剛創建的“FileUploadBackBean”已經自動加入到配置文件中。

<managed-bean>
<managed-bean-name>FileUploadBackBean</managed-bean-name>
<managed-bean-class>com.sun.sdn.demo.jsf.FileUploadBackBean</managed-bean-class>
<managed-bean-scope>request</managed-bean-scope>
</managed-bean>

 

8。在 FileUploadBackBean 加入如下代碼:

 

/**//*
* FileUploadBackBean.java
*
* Created on 2007年8月27日, 下午2:48
*
* To change this template, choose Tools | Template Manager
* and open the template in the editor.
*/

package com.sun.sdn.demo.jsf;
import java.util.Enumeration;
import java.util.Hashtable;
import java.io.IOException;

import javax.faces.context.FacesContext;
import javax.faces.context.ResponseWriter;
import javax.servlet.ServletContext;
import org.apache.shale.remoting.faces.ResponseFactory;

import com.sun.javaee.blueprints.components.ui.fileupload.FileUploadStatus;
/** *//**
*
* @author Ada Li
*/
public class FileUploadBackBean {
/** *//**
* <p>Factory for response writers that we can use to construct the
* outgoing response.</p>
*/
private static ResponseFactory factory = new ResponseFactory();
private String serverLocationDir = "E:/mymodules/PhotoAlbum/build/web/images";
String imageRootUrl = "../images";

/** *//** Creates a new instance of FileUploadBackBean */
public FileUploadBackBean() {
}
public void postProcessingMethod(FacesContext context, Hashtable htUpload, FileUploadStatus status) {
// set custom return enabled so Phaselistener knows not to send default response
status.enableCustomReturn();
// Acquire a response containing these results
ResponseWriter writer = factory.getResponseWriter(context, "text/xml");
try {
writer.startElement("response", null);

String imageFileLocation = "";
for (Enumeration e = htUpload.keys() ; e.hasMoreElements() ;) {
String key = (String)e.nextElement();
//System.out.println(key.substring(0, 13));
if (key.substring(0, 13).equals("fileLocation_")){
imageFileLocation = (String)htUpload.get(key);
String fileName = imageFileLocation.replaceFirst(getServerLocationDir(), "");
String imageFileUrl = imageRootUrl + fileName;
writer.startElement("imageFileUrl", null);
writer.write(imageFileUrl);
writer.endElement("imageFileUrl");
}
}
writer.endElement("response");
writer.flush();
} catch (IOException iox) {
System.out.println("FileUploadPhaseListener error writting AJAX response : " + iox);
}
}
public String getServerLocationDir() {
return serverLocationDir;
}
public void setServerLocationDir(String serverLocationDir) {
this.serverLocationDir = serverLocationDir;
}
}

FileUploadBackBean中有兩個參數需要根據情況設定,即 serverLocationDir 和 imageRootUrl 。因為PhotoAlbum缺省部署完成后,項目在應用服務器中的部署位置就是/build目錄。在這個例子中,文件上載到/build/images目錄下,因此還需要手工在PhotoAlbum的web目錄下建立一個images目錄,PhotoAlbum部署完成后,在/build/目錄下自動會建立images目錄。

 


上載后的文件放在/build/images目錄下,通過瀏覽器訪問的話,URL是http://localhost:8080/PhotoAlbum/images/XXXX.jpg, 因此,獲得上傳的文件名之后,之前要加上相對路徑“../images”.


文件中方法 postProcessingMethod 的主要作用是提取上傳文件名,并生成xml格式的響應信息。信息的格式如下:

<response>
<imageFileUrl>../images/Bike.jpg</imageFileUrl>
<imageFileUrl>../images/Bungee.jpg</imageFileUrl>
<imageFileUrl>../images/Duke.in.City.jpg</imageFileUrl>
<imageFileUrl>../images/Pointing.jpg</imageFileUrl>
<imageFileUrl>../images/Thiniing.jpg</imageFileUrl>
</response>
9。現在開始寫JSP頁面。在PhotoAlbum項目中,加入JSF框架之后,項目中自動加入了一個WelcomJSF.jsp頁面。修改后的WelcomJSF.jsp代碼如下:

<%@page contentType="text/html"%>
<%@page pageEncoding="UTF-8"%>
<%@taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
<%@taglib uri="http://java.sun.com/jsf/html" prefix="h" %>
<%@taglib uri="http://java.sun.com/jsf/core" prefix="f" %>
<%@taglib uri="http://java.sun.com/blueprints/ui" prefix="ui" %>
<html>
<head>
<title>AJAX與JSF實現帶進度條的批量文件上載</title>
<script>

function props(namex) {
var listx="";
var ob=dojo.byId(namex);
for(xx in ob) {
listx += xx + " = " + ob[xx] + "<br/>"
}
//document.write(listx);
alert(listx);
}

function testRetFunction(type, data, evt){
// handle successful response here
var photoAlbum = document.getElementById("photo_album");
var resultx = data.getElementsByTagName("response")[0];
if(resultx) {
var photoAlbum = document.getElementById("photo_album");

var tb = document.createElement("table");
tb.setAttribute("border", 1);
var tbody = document.createElement("tbody");
var tr = document.createElement("tr");
tb.insertBefore(tbody, null);
tbody.insertBefore(tr, null);
photoAlbum.insertBefore(tb, null);

var imageUrls = resultx.getElementsByTagName("imageFileUrl");
for (var i=0; i<imageUrls.length; i++){
var td = document.createElement("td");
td.setAttribute("width", "20%");
td.setAttribute("valigh", "top");

var url = imageUrls[i].childNodes[0].nodeValue;
var image = document.createElement("img");
image.setAttribute("src", url);
image.setAttribute("width", "100");

td.insertBefore(image, null);
tr.insertBefore(td, null);
}
}
}

</script>
</head>
<body>
<h1>AJAX與JSF實現帶進度條的批量文件上載</h1>

<f:view>

<table border="1" colspacing="5" colpadding="5">
<tr>
<td>
<br/>
<ui:fileUploadTag id="TestFileuploadForm0"
serverLocationDir="#{FileUploadBackBean.serverLocationDir}"
retFunction="testRetFunction" retMimeType="text/xml"
postProcessingMethod="#{FileUploadBackBean.postProcessingMethod}"
progressBarDivId="progress1x" progressBarSubmitId="submit1x" progressBarSize="40">
<input type="file" size="40" name="fileToUpload0" id="fileToUpload0Id"/><br/>
<input type="file" size="40" name="fileToUpload1" id="fileToUpload1Id"/><br/>
<input type="file" size="40" name="fileToUpload2" id="fileToUpload2Id"/><br/>
<input type="file" size="40" name="fileToUpload3" id="fileToUpload3Id"/><br/>
<input type="file" size="40" name="fileToUpload4" id="fileToUpload4Id"/><br/>
<input type="submit" id="submit1x" name="submit1x" value="Submit"/><br/>
<div id="progress1x"></div><br/>
</ui:fileUploadTag>
</td>
</tr>
</table>
<br><br>
<div id="photo_album"></div>
</f:view>
</body>
</html>


在welcomeJSF.jsp頁面中,重點就是JavaScript函數 testRetFunction(), 它作為AJAX中客戶端的回調函數, 接受來自服務器端的響應信息后,通過DOM技術, 在原有頁面上,動態地創建了table及img 對象,來顯示上傳的圖像.
在 FileUploadBackBean 聲明了屬性 serverLocationDir ,并且有對這個屬性的set和get方法,那么在JSF中,對這個屬性的調用可以直接是#{FileUploadBackBean.serverLocationDir}。


10。運行的結果如下


 



三。小結


 

JSF(JavaServer Faces)主要的目的是把表示和動作分開。在通常的JSP開發中, Http請求映射到事件處理器,在服務器端操作頁面控件,都不是很方便。而JSF技術分離了動作和表示,可以讓開發者更專注于自己的領域,而把一些映射的工作或者底層的工作交給框架來實現。


 

JSF提供了大量的tab library, 前面的文件上載的控件就是其中之一。在使用這個控件的時候,可以注意到,編寫Bean時,并不需要直接從HttpRequest中讀取參數值,并且在返回響應信息時候,也并沒有在代碼中直接指定具體的頁面。AJAXJSF的應用中,體現在增加了JavaScript回調函數的接口,就是WelcomJSF.jsp中的函數testRetFunction()



 

 

分享:如何在Struts 2中實現文件上傳
前一陣子有些朋友在電子郵件中問關于Struts 2實現文件上傳的問題, 所以今天我們就來討論一下這個問題。 實現原理 Struts 2是通過Commons FileUpload文件上傳。Commons FileUpload通過將HTTP的數據保存到臨時文件夾,然后Struts使用fileUpload攔截器將文件綁

來源:模板無憂//所屬分類:JSP教程/更新時間:2010-05-31
相關JSP教程
免费看久久久| 肉色超薄丝袜脚交69xx图片 | www黄色在线| 中文字幕免费高清在线观看| 欧美一区综合| 精品国产精品自拍| 国产精品va在线| 中文字幕亚洲影院| 涩涩视频免费看| 青娱乐精品在线视频| 日韩午夜av电影| 欧美国产二区| 午夜精品一区二区三级视频| 久久a爱视频| 国产精品丝袜在线| 亚洲3p在线观看| 久久国产激情视频| 午夜成人免费影院| 国产一区久久久| 亚洲精品视频在线观看视频| 一区二区三区一级片| 成年人免费高清视频| 欧美第一精品| 福利微拍一区二区| 亚洲精品免费网站| 国产一二三四五区| 国产乱人伦丫前精品视频| 国产精品三级在线观看| 国内自拍欧美激情| 五月天六月丁香| 国产福利亚洲| 久久久久久黄色| 欧美极品少妇xxxxⅹ喷水| 99热成人精品热久久66| 国产福利第一视频| 国内久久精品视频| 国产性猛交xxxx免费看久久| 99热久久这里只有精品| 国产精品欧美久久久久天天影视| 美女被久久久| 日韩av一区二区在线观看| 欧美一级特黄aaaaaa在线看片| 免费看一级视频| 在线一区欧美| 亚洲成人激情在线观看| 日本免费成人网| 国产精品一区二区人人爽| 日韩高清在线电影| 日韩精品在线播放| 久久综合九色综合88i| www.av网站| 国产高清不卡一区| 久99久在线视频| 少妇性l交大片7724com| 日韩高清在线观看一区二区| 亚洲视频资源在线| 91在线网站视频| www欧美com| 亚洲影视一区| 欧美一级艳片视频免费观看| 中文字幕一区二区三区四区五区 | 黄在线观看网站| 天天干免费视频| 99精品在线观看视频| 91国内精品久久| 欧美日韩人妻精品一区在线| 果冻天美麻豆一区二区国产| 亚洲电影一区二区三区| 国产美女精品在线观看| 亚洲国产综合久久| 中日韩视频在线观看| 精品偷拍一区二区三区在线看| 国产不卡一区二区视频| 天天操天天插天天射| 久久毛片高清国产| 国产精品福利在线观看| 福利视频第一页| 欧美 亚欧 日韩视频在线 | 成人高h视频在线| 成人在线观看高清| 午夜久久久久| 精品无人区太爽高潮在线播放 | 艳母动漫在线观看| 午夜精品小视频| 91丨九色porny丨蝌蚪| 国产国产精品人在线视| 99久久99久久精品免费| 欧美日韩影院| 亚洲欧洲日产国产网站| 色国产在线视频| 日韩一区二区三区精品| 精品久久久久人成| 亚洲欧美日韩精品综合在线观看| 国产wwwxxx| 97se亚洲国产综合自在线观| 国产精品美女www爽爽爽视频| 日本一级片免费| 亚洲美洲欧洲综合国产一区| 亚洲视频自拍偷拍| 国内av免费观看| 国产精品一区高清| 欧美一区二区免费视频| 国产网站免费在线观看| 国产成人免费视频网站视频社区| 亚洲国产成人av网| 午夜久久资源| 婷婷综合激情网| 自拍偷拍亚洲欧美日韩| 精品国产免费一区二区三区| 一级日韩一级欧美| 久久久噜噜噜久久人人看| 91精品视频一区| www.久久久久久久| 成人av资源在线观看| 91精品国产综合久久香蕉的用户体验| 日本少妇久久久| 精品亚洲免费视频| 日本午夜在线亚洲.国产| 特级片在线观看| 蜜桃视频一区二区| 91国产精品电影| 青青草原在线免费观看| 日韩专区一卡二卡| 91精品国产一区| 妺妺窝人体色www聚色窝仙踪| 美女视频黄久久| 欧美在线观看一区二区三区| 青青草原国产视频| 美腿丝袜在线亚洲一区| 日韩av不卡电影| 激情五月色婷婷| 福利一区二区在线观看| 成人黄色网免费| 在线观看亚洲黄色| 久久精品人人做人人爽人人 | 国产一区二区电影在线观看| 欧美成人艳星乳罩| av在线网站免费观看| 欧美第一精品| 色偷偷噜噜噜亚洲男人| 国产123在线| 日韩电影免费一区| 日韩暖暖在线视频| 超碰超碰超碰超碰| 91丝袜呻吟高潮美腿白嫩在线观看| av日韩免费电影| 精品国产999久久久免费| 中文字幕一区二区三区在线不卡| 欧美理论一区二区| 日韩免费电影| 日韩欧美精品在线观看| 国产精品视频一区二区三区四区五区| 国内精品偷拍| 亚洲第一区在线观看| 国产高潮失禁喷水爽到抽搐| 国产综合自拍| 高清欧美电影在线| 国产精品7777777| 26uuu另类欧美亚洲曰本| 久久久免费看| 3d欧美精品动漫xxxx无尽| 色av成人天堂桃色av| 亚洲狼人综合干| 色综合久久网| 久久精品中文字幕| www.5588.com毛片| 粉嫩av一区二区三区粉嫩| yellow视频在线观看一区二区| 北条麻妃一二三区| 婷婷亚洲久悠悠色悠在线播放| 国产午夜大地久久| 免费看日本一区二区| 亚洲人成人99网站| 亚洲激情图片网| 国产经典欧美精品| 精品一区二区日本| 国产精品亚洲d| 欧美一级久久久| 成人免费毛片日本片视频| 三级欧美在线一区| 成人中文字幕+乱码+中文字幕| 99久久精品国产成人一区二区 | 人妻精品久久久久中文字幕| 日韩在线一二三区| 亚洲www永久成人夜色| 免费观看黄色一级视频| 在线亚洲欧美专区二区| 亚洲精品免费一区亚洲精品免费精品一区 | 麻豆精品久久久| 亚洲在线视频观看| 卡通欧美亚洲| 91精品国产综合久久久蜜臀粉嫩 | 欧美超级乱淫片喷水| 久久综合亚洲色hezyo国产| 99re在线精品| 在线视频不卡一区二区| 看全色黄大色大片免费久久久| 亚洲欧美日韩另类| 亚洲色婷婷一区二区三区| 91在线视频播放| 亚洲精品中文字幕在线| 久久久久观看| 日日狠狠久久偷偷四色综合免费 | 俄罗斯精品一区二区三区| 91久久国产综合久久91猫猫| 欧美日本韩国一区| 少妇户外露出[11p]| 狠狠狠色丁香婷婷综合激情| 久久精品一二三区| 免费观看性欧美大片无片| 亚洲人成在线观看| 久久久久无码国产精品| 欧美国产国产综合| 99精品在线免费视频| 亚洲精品国产精品乱码视色| 91天天综合| 欧美三级在线看| 中文字幕人妻一区二区三区| 久久99久久99| 日本一区二区精品视频| 伊色综合久久之综合久久| 最近2019中文字幕大全第二页 | 97超碰在线视| 日韩欧美精品一区| 777国产偷窥盗摄精品视频| 99久久精品国产色欲| 欧美区一区二区三区| 精品夜夜澡人妻无码av| 国产成人啪免费观看软件| 视频一区亚洲| 国内黄色精品| 欧美一性一乱一交一视频| 国内精品偷拍视频| 日韩小视频在线观看专区| 日韩黄色中文字幕| 久久久国产一区二区三区四区小说| 日本精品久久久久久久久久| 91tv官网精品成人亚洲| 国产精品久久久久久久美男| 韩国久久久久久| 亚洲精品久久久久中文字幕欢迎你| av激情在线观看| 综合激情成人伊人| 亚洲天堂网2018| 久久国产精品色| 亚洲一区二区三区免费观看| 成人在线电影在线观看视频| 国产成人激情视频| 久久夜夜操妹子| 曰本色欧美视频在线| 久久精品五月天| 91久久精品网| 天天摸日日摸狠狠添| 亚洲国产成人私人影院tom| 少妇激情一区二区三区| 免费在线观看成人| 亚洲春色在线视频| 久久高清精品| 91免费福利视频| 亚洲精品福利| 久久久久久久一| 成人乱码一区二区三区| 亚洲国产成人精品女人久久久 | 日韩一区二区av| 国产精品久久免费| 日韩免费观看高清完整版在线观看| 欧美精品一区二区蜜桃| 香蕉成人伊视频在线观看| bl动漫在线观看| 国产视频亚洲色图| av免费一区二区| 国产成人精品免费在线| 国产精品又粗又长| 裸体素人女欧美日韩| 亚洲精品中字| 国产精品videosex极品| 美日韩免费视频| 97视频热人人精品免费| 99se婷婷在线视频观看| 一呦二呦三呦国产精品| 国产精品久久一区主播| 视频精品国内| 91禁国产网站| 国模私拍国内精品国内av| 久久91精品国产91久久久| 亚洲国产精品18久久久久久| 精品网站999www| 91中文字幕在线视频| 精品福利视频一区二区三区| 国产精品久久久久久人| 91精品国产一区二区三区| 色播视频在线播放| 欧美日韩亚洲综合| 国产精品7777777| 在线电影国产精品| 91美女免费看| 制服丝袜中文字幕亚洲| 少妇一级淫片免费放中国| 欧美日韩国产经典色站一区二区三区 | 色婷婷综合久久久久久| 国产欧美日韩中文字幕在线| 国产亚洲精品美女久久| 国产免费一区视频观看免费 | 色成人免费网站| 欧美日韩成人在线视频| 久久久人成影片一区二区三区在哪下载 | 国产精品亚洲a| 国产成人免费在线观看不卡| 男人操女人免费| 懂色av一区二区三区蜜臀| www.色偷偷.com| 99久久婷婷国产综合精品 | 91啪九色porn原创视频在线观看| 成年网站在线播放| 91视频观看视频| 国产精品99精品无码视亚| 国产精品久久久久久福利一牛影视 | 亚洲午夜久久久久久久久| 国产精品美女久久久久aⅴ | 黄色片子在线观看| 色狠狠综合天天综合综合| 日本天堂网在线观看| 欧美一区三区二区| 中文字幕欧美人妻精品| 国产亚洲激情在线| 五月婷婷丁香网| 久久久视频在线| 91成人噜噜噜在线播放| 91青草视频久久| 99热精品久久| 午夜精品一区二区在线观看| 免费在线成人| 免费看又黄又无码的网站| 国产成人高清在线| 在线a免费观看| 国产精品久久一级| 亚洲色图27p| 欧美色视频一区| 中文字字幕在线中文乱码| 亚洲社区在线观看| 国产超碰精品| 日韩av不卡电影| 欧美一区二区性| 日韩欧美国产二区| 免费成人av资源网| 手机在线免费观看毛片| 欧美国产精品一区二区| 中文字幕欧美激情极品| 欧美性色aⅴ视频一区日韩精品| 高潮毛片又色又爽免费 | 国产日韩成人内射视频 | 日韩av电影国产| 国产成人一区| 日韩欧美三级电影| 久久99久久99小草精品免视看| 波多野结衣xxxx| **欧美大码日韩| 成年人av电影| 欧美不卡123| 开心激情综合网| 4438全国成人免费| 久久成人av| 视频三区二区一区| 国产美女视频91| 国产情侣久久久久aⅴ免费| 午夜精品福利久久久| 亚洲欧美日韩激情| 最近更新的2019中文字幕| 国产色99精品9i| 国产乱码一区| 久久久国产亚洲精品| 成人性生生活性生交12| 亚洲人一二三区| 精品亚洲永久免费| 亚洲精品视频免费| 国产伊人久久| 丁香婷婷久久久综合精品国产| 亚洲欧美日韩专区| 国产精品久久a| 亚洲综合激情另类小说区| 国产精品久久久免费视频| 国产亚洲精品美女久久久| 白嫩亚洲一区二区三区| 99久久无色码| 日韩不卡一区二区| 自拍视频第一页| 色天使色偷偷av一区二区| 一级成人免费视频| 91国自产精品中文字幕亚洲| 日韩中文字幕高清在线观看| 男人的天堂视频在线| 久久久久久综合| 精品99久久久久成人网站免费 | 一级黄色录像大片| 国外色69视频在线观看| 成人高清av| 波多野结衣综合网| 综合久久给合久久狠狠狠97色| 日韩精品一区三区| 久久手机精品视频|