久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁技術文章
文章詳情頁

Ajax基礎使用詳解

瀏覽:15日期:2022-06-14 13:47:46
目錄Ajax基礎1.1ajax簡介1.2XML簡介1.3AJAX的特點1.3.1AJAX的優點1.3.2AJAX的缺點1.4HTTP協議1.4.1 Express1.5AJAX的應用1.5.1原生Ajax GET請求1.6設置請求頭信息2.1服務端響應JSON數據2.2解決ie緩存問題2.3超時與網絡錯誤的處理2.4取消AJAX請求2.5Ajax重復發送請求情況3.1JQuery發送AJAX請求4.1 axios4.12發起一個get請求4.13 發起一個 POST 請求4.1.4 可以向 axios 傳遞相關配置來創建請求5.1使用fetch函數發送Ajax請求6.1同源策略6.2跨域的解決6.2.1 JSONP7. CORSapp.post('/postcors',(request,response)=>{ // 設置響應頭. 名字,* (設置所有協議、域名、端口、允許跨域) response.setHeader('Access-Control-Allow-Origin','*'); // 指定端口允許跨域 response.setHeader('Access-Control-Allow-Origin','http://127.0.0.1:8082'); // 響應頭,允許所有的響應頭類型 response.setHeader('Access-Control-Allow-Headers','*'); // 設置響應體 const data = { name:'cors JSON',type:'POST JSON Type' } response.send(JSON.stringify(data));});Ajax基礎1.1ajax簡介

AJAX全稱是Asynchronous JavaScript And XML,就是異步的JS和XML

通過Ajax可以在瀏覽器中向服務器發送異步請求,最大的優勢是:無刷新獲取數據。

Ajax不是新的編程語言,而是一種將現有的標準組合在一起使用的新方式。

1.2XML簡介

xml 可擴展標記語言

xml 被設計用來傳輸和保存數據

xml和HTML類似,,不同的是HTML中都是預定義標簽;而XML中沒有預定義標簽,全都是自定義標簽,用來保存一些數據

最開始Ajax在進行數據交換的時候,使用的格式就是XML,服務器端給瀏覽器返回結果時就是返回XML格式的字符串,前端的JS在接收到結果之后對XML格式的字符串進行解析,把數據提取出來。

但是現在使用AJAX時候就不再使用XML了,而是換成了JSON格式,JSON相對于XML更加簡潔,在數據轉換方面也相對容易、更靈活。

<student> <name>名字</name> <age>年齡</age> <gender></gender></student>1.3AJAX的特點1.3.1AJAX的優點

可以無需刷新頁面與服務器進行通信允許你根據用戶事件來更新部分頁面內容

1.3.2AJAX的缺點

沒有瀏覽歷史,不能回退存在跨域問題(同源)SEO(搜索引擎優化)不友好,網頁爬蟲爬不到,源代碼(響應體)第一次請求時沒有要請求內容的信息,他是通過Ajax向服務端發請求,服務端返回結果,然后js動態創建到頁面中的,爬蟲爬不到數據。IE緩存問題:ie瀏覽器會對Ajax請求結果進行緩存,把結果緩存起來;當下一次再去請求數據時候,會到緩存里找,而不是服務器返回的最新的請求結果,這樣的話可能會影響結果,解決的辦法是在url?后面加一個時間戳,讓瀏覽器知道這是兩次不同的請求。

1.4HTTP協議

hypertext transport protocol 超文本傳輸協議,協議詳細規定了瀏覽器和萬維網服務器之間互相通信的規則。

協議就是一種約定、規則。主要約定了請求報文、響應報文這兩塊的內容。

請求報文

格式:

一個完整的HTTP請求報文請求行:{請求類型GET/POST URL路徑 HTTP協議版本1.0 / 1.1 / 2.0}請求頭:{Host: baidu.comCiikie: name=baiduContent-type: application/x-www-from-urlencoded //告知服務器我的請求體是什么類型的User-Agent: chrome 83}空行:{}請求體:{//如果是get請求,請求體是空的;如果是POST請求,請求體可以不為空username=admin&password=admin}一個完整的HTTP響應報文行:HTTP/1.1 200 OK (協議版本 響應狀態碼 響應狀態字符串)頭: Content-type:text/html;charset=utf-8//類型 就是對響應體內 容進行一些相關的描述 Content-length:2048 //長度 Content-encoding:gzip //壓縮方式空行:必須要有體:<html><body><h1> html響應的內容是放在了響應的報文當中,瀏覽器在接到結果之后會把響應體結果提取出來,對內容進行解析,在頁面渲染并顯示</h1></body> </html>

參數:

1.4.1 Express// 1. 引入expressconst express = require('express');// 2. 創建應用對象const app = express();// 3. 創建路由規則 request是對請求報文的封裝 response是對響應報文的封裝app.get('/server',(request,response)=>{ // 設置響應頭. 名字,* (設置允許跨域) response.setHeader('Access-Control-Allow-Origin','*'); // 設置響應體 response.send('Hello 原生AJAX!');});// 4. 監聽端口啟動服務app.listen(8082,()=>{ console.log('服務已經啟動8082端口監聽中......');})1.5AJAX的應用1.5.1原生Ajax GET請求

只需要四步:

創建XMLHttpRequest對象 const xhr = new XMLHttpRequest();設置請求的方法和url xhr.open('GET','//127.0.0.1:8082/server');發送 xhr.send();處理服務端返回的結果 xhr.onreadystatechange = function(){}

當xhr對象里的readystate屬性改變時處理。

readyState四個值的意義

0 未初始化1 open方法已經調用完畢2 send方法已經調用完畢3 服務端返回了部分結果4 服務端返回了所有結果 <button id='btn'>點擊發送請求</button> <div id='result'></div> <script>const btn = document.getElementsByTagName('button')[0];const result=document.getElementById('result');btn.onclick=function(){ // ajax的操作 // 1. 創建對象, const xhr = new XMLHttpRequest(); // 2. 設置請求的方法和url xhr.open('GET','http://127.0.0.1:8082/server'); // 3. 發送 xhr.send(); // 4. 事件綁定,處理服務端返回的結果 // on==when. readystate是xhr對象中的屬性,表示狀態 .change 改變會改變四次 // 0未初始化 1(open方法已經調用完畢) 2(send方法已經調用完畢) 3(服務端返回了部分結果) 4(服務端返回了所有結果) xhr.onreadystatechange = function(){// 判斷服務端是否返回了所有結果if(xhr.readyState === 4){ //判斷響應狀態碼 if(xhr.status >= 200 && xhr.status < 300){// 處理結果 行 頭 空行 體// 1.響應行console.log(xhr.status);//狀態碼console.log(xhr.statusText);//狀態字符串console.log(xhr.getAllResponseHeaders.toString());//所有響應頭console.log(xhr.response);//響應體result.innerHTML = xhr.response; }else{ }} }} </script>

設置參數

可以在url后面直接加上?參數名:值&參數名:值…

xhr.open('GET','//127.0.0.1:8082/server?name=admin&password=admin');

POST請求

<script>const RESULT = document.getElementById('RESULT'); RESULT.addEventListener('mouseover',function(){ // 1. 創建對象 const xhr = new XMLHttpRequest(); // 2.初始化,設置請求類型 與 方法 xhr.open('POST','http://127.0.0.1:8082/server'); // 3. 發送請求 xhr.send(); // 4.事件處理 xhr.onreadystatechange=function(){if(xhr.readyState === 4){ if(xhr.status >=200 && xhr.status<300){RESULT.innerHTML=xhr.response;// console.log(xhr.getAllResponseHeaders()); }} }}); </script>報錯信息Access to XMLHttpRequest at 'http://127.0.0.1:8082/server' from origin 'null' has been blocked by CORS policy: No 'Access-Control-Allow-Origin' header is present on the requested resource.已攔截跨源請求:同源策略禁止讀取位于 http://127.0.0.1:8082/server 的遠程資源。(原因:CORS 頭缺少 'Access-Control-Allow-Origin')。狀態碼:404。因為服務端沒有一個與之匹配的路由規則,而且沒有設置響應頭

參數設置

// 在send方法里可以設置參數,可以設置任意類型,任意格式的數據xhr.send('a=100&b=200&c=300');1.6設置請求頭信息 // 設置請求頭信息 一般設置一些預定義的請求頭 // Content-Type 用來設置請求體的內容類型 // application/x-www-form-urlencoded 設置參數查詢字符串的類型 // 請求頭信息也可以自定義,但是瀏覽器會有安全機制, xhr.setRequestHeader('Content-Type','application/x-www-form-urlencoded'); // 設置請求頭的信息是因為 要把身份校驗的信息放在頭信息里面,把他傳遞給服務器,由服務器對參數做提取,對用戶的身份進行校驗 xhr.setRequestHeader('name','yxj');

后端操作

// all表示可以接受所有類型的請求app.all('/server',(request,response)=>{ // 設置響應頭. 名字,* (設置允許跨域) response.setHeader('Access-Control-Allow-Origin','*'); // 響應頭,允許所有的響應頭類型 response.setHeader('Access-Control-Allow-Headers','*') // 設置響應體 response.send('Hello 原生AJAX POST!');});2.1服務端響應JSON數據

nodemon工具可以實時重啟服務器

<script>const result = document.getElementById('result');// 綁定鍵盤按下事件window.onkeydown=function(){ // 1. 獲取xhr對象 const xhr = new XMLHttpRequest(); // 設置響應體數據類型 xhr.responseType = 'json'; // 2.初始化 xhr.open('GET','http://127.0.0.1:8082/json-server'); // 3.發送 xhr.send(); // 4. 處理數據 xhr.onreadystatechange=function(){if(xhr.readyState === 4){ if(xhr.status >=200 && xhr.status <300 ){// 手動將數據轉換// let data = JSON.parse(xhr.response);// result.innerHTML= data.name;// console.log(data);// 自動轉換console.log(xhr.response);result.innerHTML= xhr.response.name; }} }} </script>

后臺

app.all('/json-server',(request,response)=>{ // 設置響應頭. 名字,* (設置允許跨域) response.setHeader('Access-Control-Allow-Origin','*'); // 響應頭,允許所有的響應頭類型 response.setHeader('Access-Control-Allow-Headers','*') // 設置一個響應數據 const data={name:'winter',age:18,sex:'man' } // 設置響應體,send方法里只能接收字符串和Buffer 類型 //所以要對對象進行一個轉換 let str = JSON.stringify(data); response.send(str);});2.2解決ie緩存問題xhr.open('GET','http://127.0.0.1:8082/json-server?t='+Date.now());//加一個時間戳,讓瀏覽器知道這是兩次不同的請求。2.3超時與網絡錯誤的處理 //超時設置 請求超過2s則取消請求 xhr.timeout = 2000; // 超時回調 實際中應該采取更加友好的方式 xhr.ontimeout = function(){alert('網絡請求超時!'); } // 網絡異常回調 xhr.onerror = function(){alert('網絡異常!'); } xhr.open('GET','http://127.0.0.1:8082/out?'+Date.now()); xhr.send();2.4取消AJAX請求const xhr = new XMLHttpRequest();xhr.abort();2.5Ajax重復發送請求情況

如果客戶端一直向服務器發送相同的請求,服務器的壓力就會很大,會接收到很多的相同請求。

解決辦法:

在向服務器發送請求之前先判斷之前有沒有發起過相同的請求,如果有就將之前的請求取消掉,重新發起請求。這樣一來我們向服務器發起的請求始終只有一個,服務器壓力就會小一些

<script>const btn = document.getElementsByTagName('button')[0];const result=document.getElementById('result');let xhr = null;//標識變量let isSending = false; //是否正在發送AJAX請求btn.onclick=function(){ // 判斷標識變量 if(isSending) xhr.abort();//如果正在發送,則取消該請求,創建一個新的請求 xhr = new XMLHttpRequest(); // 修改 標識變量的值 isSending = true; xhr.open('GET','http://127.0.0.1:8082/out?'+Date.now()); xhr.send(); xhr.onreadystatechange = function(){if(xhr.readyState === 4){ //修改標識變量 isSending = false; if(xhr.status >= 200 && xhr.status < 300){result.innerHTML = xhr.response;console.log(xhr.response); }else{ }} }} </script>3.1JQuery發送AJAX請求<script>$('button').eq(0).click(function(){ //$.get/post方法接收的是參數 // 參數1:url 參數2:要發送的對象{} 參數三:回調函數(響應體)操作服務器端返回的數據 參數4:設置響應體類型 $.get('http://127.0.0.1:8082/getjquery',{a:100,b:200},function(data){console.log(data);//對象 },'json')});$('button').eq(1).click(function(){ $.post('http://127.0.0.1:8082/postjquery',{a:300,b:400},function(data){console.log(data);//沒+json會返回字符串 })});$('button').eq(2).click(function(){ //$.ajax方法接接收的是一個對象,對象里有響應的屬性,通過屬性設置參數 $.ajax({// url:url:'http://127.0.0.1:8082/alljquery',// 參數,post請求才能設置請求體data:{a:100,b:200},// 類型type:'POST',// 響應體結果dataType:'json',// 成功的回調success:function(data){ console.log(data);},// 超時時間timeout:8000,// 失敗的回調 超時、網絡異常error:function(){ console.log('出錯了');},// 頭信息設置headers:{ name:'headers', msg:'hiashfi',} });}); </script>app.get('/getjquery',(request,response)=>{ // 設置響應頭. 名字,* (設置允許跨域) response.setHeader('Access-Control-Allow-Origin','*'); // 設置響應體 const data = {name:'Jquery JSON',type:'get JSON Type' } response.send(JSON.stringify(data));});// JQuery postapp.post('/postjquery',(request,response)=>{ // 設置響應頭. 名字,* (設置允許跨域) response.setHeader('Access-Control-Allow-Origin','*'); // 響應頭,允許所有的響應頭類型 response.setHeader('Access-Control-Allow-Headers','*'); // 設置響應體 const data = {name:'Jquery JSON',type:'POST JSON Type' } response.send(JSON.stringify(data));});4.1 axios

Axios 是一個基于 promise 網絡請求庫,作用于node.js 和瀏覽器中。 在服務端它使用原生 node.js http 模塊, 而在客戶端 (瀏覽端) 則使用 XMLHttpRequests。

特性:

從瀏覽器創建 XMLHttpRequests從 node.js 創建 http請求支持 Promise API攔截請求和響應轉換請求和響應數據取消請求自動轉換JSON數據客戶端支持防御XSRF4.12發起一個get請求// 向給定ID的用戶發起請求axios.get('/user?ID=12345') .then(function (response) { // 處理成功情況 console.log(response); }) .catch(function (error) { // 處理錯誤情況 console.log(error); }) .then(function () { // 總是會執行 });4.13 發起一個 POST 請求axios.post('/user', { firstName: 'Fred', lastName: 'Flintstone' }) .then(function (response) { console.log(response); }) .catch(function (error) { console.log(error); });

發起多個并發請求:

function getUserAccount() { return axios.get('/user/12345');}function getUserPermissions() { return axios.get('/user/12345/permissions');}Promise.all([getUserAccount(), getUserPermissions()]) .then(function (results) { const acct = results[0]; const perm = results[1]; });4.1.4 可以向 axios 傳遞相關配置來創建請求// 發起一個post請求axios({ method: 'post', url: '/user/12345', data: { firstName: 'Fred', lastName: 'Flintstone' }});// 在 node.js 用GET請求獲取遠程圖片axios({ method: 'get', url: 'http://bit.ly/2mTM3nY', responseType: 'stream'}) .then(function (response) { response.data.pipe(fs.createWriteStream('ada_lovelace.jpg')) });5.1使用fetch函數發送Ajax請求

fetch函數屬于全局對象,可以直接調用,返回的結果是promise對象

btns[0].onclick = function(){ // fetch(url,{}) fetch('http://127.0.0.1:8082/allaxios',{// 請求方法method:'POST',// 請求頭headers:{ name:'fetch'},// 請求體body:'username=admin,password=123456' }).then(response=>{// console.log(response);// return response.text();//轉成stringreturn response.json();//轉成json }).then(response=>{console.log(response); })}6.1同源策略

same-Oringin Policy最早由Netscape公司提出,是瀏覽器的一種安全策略

**同源:**協議、域名、端口號必須完全相同。

就是來自相同的一個服務

Ajax是默認遵循同源策略的。不滿足同源策略是無法直接發送Ajax請求的。

例:

當前網頁http://a.com 8000端口目標資源的協議也必須是http協議,a.com域名,8000端口

跨域原因:

因為單臺服務器,能力受限加入更多的服務器提供更多的服務6.2跨域的解決6.2.1 JSONP

jsonp是什么?

JSONP(JSON with Padding),是一個非官方的解決方案,純粹憑借程序員的聰明才智開發出來的,只支持get請求。

jsonp怎么工作?

在網頁有一些標簽天生具有跨域能力,比如:img、link、iframe、script.jsonp利用script標簽的跨域能力來發送請求的。

jsonp的使用

動態創建一個script標簽var script = document.createElement('script');設置script的src,設置回調函數script.src = 'http://localhost:3000/testAJAX?callback=abc';7. CORS// 設置響應頭. 名字,* (設置所有協議、域名、端口、允許跨域) response.setHeader('Access-Control-Allow-Origin','*'); // 指定端口允許跨域 response.setHeader('Access-Control-Allow-Origin','http://127.0.0.1:8082'); // 響應頭,允許所有的響應頭類型 response.setHeader('Access-Control-Allow-Headers','*'); // 允許所有請求類型(get、post、...) response.setHeader('Access-Control-Allow-Method','*');

https://developer.mozilla.org/zh-CN/docs/Web/HTTP/CORS

CORS是什么?

CORS (Cross - Origin - Resource Sharing), 跨域資源共享。

CORS是官方的跨域解決方案,他的特點是愛不需要在客戶端做任何特殊的操作,完全在服務器中進行處理,支持get和post請求。

跨域資源共享新增了一組HTTP首部字段,允許服務器聲明哪些源站通過瀏覽器有權限訪問哪些資源。

CORS是怎么工作的?

CORS通過設置一個響應頭來告訴瀏覽器,該請求允許跨域,瀏覽器收到該響應以后就會對響應放行。

CORS的使用

主要是服務器里的設置:

router.get(“/testAJAX”,function(req,res){

})

btn.onclick = function(){ // 創建對象 var xhr = new XMLHttpRequest(); // xhr.open('GET','http://127.0.0.1:8082/getcors'); // xhr.send(); xhr.onreadystatechange = function(){if(xhr.readyState === 4){ if(xhr.status >= 200 && xhr.status<300){console.log(xhr.response); }} }}

到此這篇關于Ajax基礎使用詳解的文章就介紹到這了,更多相關Ajax基礎內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Ajax
相關文章:
主站蜘蛛池模板: 久久亚洲视频 | 久久精品久久久 | 欧美精品网站 | 日韩成人在线观看 | 美女超碰 | 欧美日韩不卡 | 午夜av电影 | 日日干夜夜干 | 9999亚洲 | 你懂的在线视频播放 | 久久一| 日韩一区在线播放 | 99精品欧美一区二区三区综合在线 | av激情在线 | 免费av观看| 日韩一区免费观看 | 在线免费视频一区 | 精品久久久久一区二区三区 | 久久九九国产精品 | 国产精品乱码一区二区三区 | 在线高清av | 久久av网 | av中文字幕在线播放 | 久久精彩视频 | 久久精品国产亚洲一区二区三区 | 久久精品一区二区三区中文字幕 | 香蕉久久久久久 | 日日网| 精品久久久久久久久久久久久久久久久久 | 欧美一级二级视频 | 一区二区不卡视频 | 特黄特黄视频 | 91原创视频在线观看 | 国产精品亚洲成在人线 | 国产精品无码专区在线观看 | 久久久久久久久久国产 | 中文字幕亚洲区 | 国产精品久久 | 一区二区三区的视频 | 欧美亚洲国产一区 | 999这里只有是极品 免费的一级黄色片 | 亚洲人成网站999久久久综合 | www日韩| 欧美日韩午夜 | 欧美黄色一区二区 | 久久久999成人 | 国产亚洲精品精品国产亚洲综合 | 久久久久高清 | 国产一区二区三区在线 | 中文字幕_第2页_高清免费在线 | 国产一级纯肉体一级毛片 | www.成人在线视频 | 亚州国产精品视频 | 国产一区二区三区免费 | 久久毛片| 国产视频一区二区 | 日韩特黄一级欧美毛片特黄 | 在线免费视频一区二区 | 午夜私人视频 | 在线观看国产精品一区 | 精品国产一区二区三区小蝌蚪 | 日韩免费视频中文字幕 | av大片 | 日本在线一区二区三区 | 99这里只有精品 | 韩日中文字幕 | 羞羞午夜 | 欧美一区二区三区精品免费 | 亚洲国产aⅴ成人精品无吗 国产精品永久在线观看 | 国产欧美综合一区二区三区 | 亚洲国产成人一区二区精品区 | 久久久香蕉 | 中文在线一区二区 | av一级久久 | 亚洲欧美电影 | 9999国产精品 | 午夜视频| 一二三精品区 | 四虎免费在线播放 | 日韩欧美高清视频 | 欧美激情在线播放 | 美女又黄又免费 | 免费观看欧美一级 | 蜜桃臀一区二区三区 | 美女视频一区二区三区 | 亚洲精品中文字幕中文字幕 | 一区日韩 | 成人激情免费视频 | 欧美在线综合视频 | 亚洲一区二区三区四区五区中文 | 国产一区在线看 | 国产影音先锋 | 亚洲欧美中文字幕 | 久久精品国产99国产精品 | 久草视频在线播放 | 日韩成人av在线 | 欧美综合久久 | 成人免费淫片aa视频免费 | jizzjizz亚洲中国少妇 | www.在线播放 | 毛片免费观看 | 久久波多野结衣 | 成人中文视频 | 国产精品亚洲精品日韩已方 | 一级免费视频 | 久久综合久久久 | 国产精品美女久久久久久久久久久 | 男女羞羞网站 | 精品久久久久久久 | 一级a性色生活片毛片 | 欧美一级一区 | 美女二区| 日韩网站免费观看 | 日韩小视频| 在线观看亚洲大片短视频 | 久久色av | 九色av| 成人午夜电影在线 | 午夜精品久久久久久久久久久久 | 中文字幕日韩在线 | 美女视频一区二区三区 | 中文字幕在线观看 | 国产最新精品 | 日韩欧美在线观看一区二区三区 | 国产成人av一区二区三区 | 精品亚洲一区二区三区四区五区 | 精品国产不卡一区二区三区 | 欧美日本韩国一区二区三区 | 成人激情视频免费观看 | 免费的日批视频 | 深夜成人小视频 | 亚洲成人免费在线观看 | 欧美一级欧美三级在线观看 | 亚洲欧美一区二区三区在线 | 久久男人天堂 | 国产精品18久久久久久久久 | 国产精品久久国产愉拍 | 精品久久影院 | 国产亚洲欧美一区二区 | 美女一级毛片 | 在线播放国产精品 | 国产一区二区三区视频 | 国产精品久久久久久久福利院 | 国产超碰人人爽人人做人人爱 | 日韩久久精品一区二区 | 国产成人精品久久二区二区 | 狠狠操狠狠操 | 97久久久国产精品 | 影音先锋亚洲资源 | 男女羞羞羞视频午夜视频 | 亚洲一区二区 | 日韩av免费 | 日韩av福利 | 亚洲一区二区在线 | 国产高清精品一区二区三区 | 久久久久国产一区二区三区 | 中文字幕毛片 | 久久久久久影院 | 久久视频精品 | 精品国偷自产国产一区 | 国产精品第一国产精品 | 国产精品毛片一区二区在线看 | 成人在线观看免费 | 奇米在线777 | 国产亚洲精品精品国产亚洲综合 | 亚洲www啪成人一区二区 | 国产大片aaa| 日韩在线不卡视频 | 国产一级片在线 | 中文字幕视频一区 | 国产欧美日韩综合精品一区二区 | 亚洲精品一区中文字幕乱码 | 久久九九精品视频 | 伊人免费网 | 九一亚洲精品 | 99久久久成人国产精品 | 国产精品久久久久国产精品 | 夜夜爽网址 | 黄色的视频免费 | 四虎影院网站 | 国产专区一区二区三区 | 伊人狠狠| 综合一区 | 美女在线视频一区二区 | 免费在线看a | 色婷婷综合网 | 欧美日韩精品网站 | 欧美日韩在线免费观看 | 久久久久亚洲一区二区三区 | 亚洲国产精品99久久久久久久久 | 激情欧美一区二区三区中文字幕 | 成人欧美在线视频 | 我和我的祖国电影在线观看免费版高清 | 亚洲一区久久 | 国产精品欧美久久久久一区二区 | 久久亚洲一区 | 亚洲一区二区三区四区 | 久久久久久久久久久久久九 | 一区二区三区视频免费 | 龙珠z在线观看 | 羞羞的视频在线观看 | 欧洲精品一区 | 成人午夜毛片 | xxxx欧美 | 精品久久久久久久 | 日韩精品视频在线 | 成人午夜av | 日本成人中文字幕 | 999久久久国产999久久久 | 色婷婷欧美 | 国产视频一视频二 | 精品视频在线播放 | 亚洲精品一区二区三区在线 | 操操操夜夜操 | 一区二区三区免费在线观看 | 涩涩片影院 | 99在线视频精品 | 欧美一级在线 | 久在线看 | 国产精品一二 | 91麻豆精品久久久久蜜臀 | 久久久久国产精品免费免费搜索 | 精品三级三级三级三级三级 | 亚洲第一免费网站 | 久久久久国产精品 | 无码日韩精品一区二区免费 | 国产高清在线精品一区二区三区 | 日本三级全黄 | 日韩视频一区 | 91在线影院 | 一区二区日韩视频 | 国产一区二区久久 | 亚洲高清视频在线观看 | 欧美日韩视频网站 | 在线免费观看毛片 | 欧美日韩不卡合集视频 | 久久久久久久久综合 | 欧美日韩一区二区三 | 久久不卡| 国产小视频在线看 | 精品免费视频一区二区 | 亚洲一区二区三区四区五区中文 | 日韩素人一区二区三区 | 狠狠干美女 | 国产免费一区二区三区 | 日韩手机专区 | 日韩欧美在线一区二区 | 少妇久久久久 | 色橹橹欧美在线观看视频高清 | 国产精品国产精品国产专区不卡 | 欧美精品一区二区三区手机在线 | 91免费版在线观看 | www.在线播放 | 亚洲国产精品久久久久久久 | 欧美高清成人 | 欧美区视频 | 久久久精品免费观看 | 日韩av一区二区在线观看 | 最新日韩在线观看视频 | www.视频在线观看 | 久久一视频 | 日韩一区二区在线观看 | 欧美日韩免费一区二区三区 | 欧美一区二区三区xxxx监狱 | 中文字幕三区 | 久久99成人| www.一区| 国产一区二区在线免费观看 | 国产高清精品在线 | 理论片一区 | 无套内谢孕妇毛片免费看红桃影视 | 日韩一区二区影视 | 精品香蕉一区二区三区 | 亚洲精品视频在线观看免费视频 | 91在线免费观看 | 九九综合九九 | 成人福利在线 | 99亚洲精品| 国产在线欧美 | 午夜欧美一区二区三区在线播放 | 91精品久久久久久久久久入口 | 欧美乱淫 | 久国久产久精永久网页 | 国产精品一区二区不卡 | 韩国精品视频在线观看 | 中文字幕 国产 | 日本一区二区三区免费观看 | 欧美日韩亚洲国产 | 亚洲视频观看 | 欧美一区二区三区免费 | 一级性视频 | 午夜小电影 | 亚洲一区二区中文字幕 | 欧美中文字幕在线 | 欧美成人一区二区三区片免费 | 在线视频91 | 国产日韩一区二区三免费高清 | 91夜夜| 亚洲欧美在线一区 | 亚洲+变态+欧美+另类+精品 | 天堂网av2020 | 久久久久国产亚洲日本 | 日日干夜夜操 | 欧美激情视频一区二区三区在线播放 | 伊人精品影院 | 成人日韩在线观看 | 一区二区在线视频 | 亚洲丶国产丶欧美一区二区三区 | 91.com在线| 视频一区在线 | 国产精品一区二区三 | 日本一区二区三区在线视频 | 久久国产精品99精国产 | 国内自拍视频网 | 亚洲 欧美 日韩 在线 | 91原创视频在线观看 | 国产精品毛片久久久久久久 | 亚洲一区中文字幕在线观看 | 国产精品久久久久久吹潮 | 久久久一二三 | 久久九九国产精品 | 少妇无套高潮一二三区 | 经典法国性xxxx精品 | 欧美日韩精品一区二区三区 | 亚洲人成在线观看 | 91一区| 日韩精品 | 亚洲人成网站999久久久综合 | 91在线一区二区 | 亚洲欧美精品一区二区三区 | 亚洲日韩欧美一区二区在线 | 国产精品99 | 成人欧美日韩一区二区三区 | 国产91 在线播放 | 欧美亚洲一 | 亚洲视频一区在线 | 超碰在线人人 | 国产精品网站在线看 | 成人情趣视频 | 男人阁久久 | 欧美精品国产精品 | 国产大学生一区 | 欧美福利在线 | 狠狠色综合欧美激情 | а天堂中文最新一区二区三区 | www.av在线播放| 日韩欧美一区二区三区久久婷婷 | 91精品国产综合久久福利软件 | 国产男女做爰免费网站 | 久久久国产一区二区三区四区小说 | 国产精品s色 | 精品一区二区三区免费 | 天天综合网久久综合网 | 亚洲免费在线视频 | 欧美日本一区二区三区 | 超碰天堂 | 狠狠天天 | 九九免费视频 | 97视频在线 | 亚洲精品久久一区二区三区 | 久草在线在线精品观看 | 国产亚洲成av人片在线观看桃 | 国产成人一区二区三区影院在线 | 精品国产乱码久久久久久闺蜜 | 亚洲天堂久| 久久最新| 天堂中文视频在线观看 | 99国产精品久久久久老师 | 亚洲欧美综合一区 | 久久2| www.44181com| 国产午夜精品久久久久免费视高清 | 一级免费黄视频 | 国产精自产拍久久久久久 | 久久二| 高清精品一区二区 | 98精品国产高清在线xxxx天堂 | 成人网址在线观看 | 欧一区二区 | 91在线免费观看 | 武道仙尊动漫在线观看 | 欧美日韩国产中文 | 欧美日韩中文国产一区发布 | 欧美国产日韩一区 | 精品久久99 | 日韩免费在线观看视频 | 亚洲视频免费网站 | 日韩高清国产一区在线 | 日韩一区二区视频 | 久在线视频 | 天天躁人人躁人人躁狂躁 | 亚洲精品三级 | 中文字幕日韩久久 | 日韩精品一区二区三区四区 | 黄色一级毛片在线观看 | 欧美一区二区三区国产精品 | 日韩和的一区二在线 | 欧美一区二区三区在线观看视频 | 欧美综合视频 | 日韩视频精品 | 午夜黄色影院 | 一级a性色生活片毛片 | 久久99精品国产自在现线 | 亚洲国产中文字幕 | 黄瓜av| 亚洲成av人乱码色午夜 | jvid美女成人福利视频 | 国产真实精品久久二三区 | 自拍偷拍第一页 | 日韩午夜激情 | 亚洲毛片 | 九一精品| 毛片网站大全 | 精品国产一区二区三区成人影院 | 日韩精品久久久 | 91超碰caoporm国产香蕉 | 天天草天天干 | 日本免费电影一区 | 日本福利在线观看 | 久久久久久99 | 亚洲久久一区 | 久久蜜桃视频 | 91久久久久久久久 | 91资源在线观看 | 日韩成人在线播放 | 日韩欧美在线播放 | www.日韩视频 | 欧美一区二区久久久 | 精品日韩一区二区 | 一级欧美一级日韩 | 欧美福利影院 | 免费国产视频 | 国产成人av一区 | 中文字幕一区在线观看视频 | 午夜国产一级 | 龙珠z国语291集普通话 | 久久夫妻网 | av成人免费 | 超碰美女 | 国产香蕉97碰碰久久人人九色 | 欧美日免费 | 一区二区三区四区免费观看 | 国产精品久久久久久久久久久免费看 | 日韩欧美在线观看一区二区 | 久久久久久久久国产精品 | 久久久国产视频 | 天天操天天色天天 | 国产视频一区二区三区四区 | 久久久久国 | 成年人视频免费在线看 | 成人欧美一区二区三区黑人孕妇 | 午夜看片在线观看 | 三级特黄特色视频 | 国产大片aaa | 欧洲美女7788成人免费视频 | 国产91在线播放精品 | 精品国产一区二区三区四区 | 亚洲一区二区三区视频 | 国产传媒在线 | 伊人免费在线观看高清版 | 姐姐在线观看动漫第二集免费 | 免费一区二区三区视频在线 | 日韩性xxx | 欧美性猛交xxxx黑人猛交 | 午夜精品一区二区三区免费视频 | 五月婷婷导航 | 国产精品国产三级国产aⅴ 羞羞的视频在线 | 羞羞视频免费观看 | 女男羞羞视频网站免费 | 91视频网址 | 成人精品免费视频 | 五月天婷婷综合 | 日韩免费| 久久久久久九九九九九九 | 越南性xxxx精品hd | 成人精品 | 国产一区二区三区四区五区加勒比 | 久久精品国产一区二区三 | 国产一区二区三区在线视频 | 91av导航| 成人精品一区二区三区 | 视频1区| 日韩一区三区 | 国产成人影院在线观看 | 中文字幕亚洲字幕一区二区 | 一区福利视频 | 亚洲欧美激情精品一区二区 | 欧洲精品一区 | 精品国产乱码久久久久久1区2区 | 一本一道久久a久久精品综合 | 中文字幕av一区二区三区免费看 | 久久免费国产 | 国产精品视频999 | 国产精品99久久久久久动医院 | 四虎欧美| 中文字幕66页 | 色综合久久天天综合网 | 亚洲视频一区二区 | 免费成人毛片 | 亚洲风情在线观看 | 青青久草在线 | 亚洲中午字幕在线观看 | 一区二区三区无码高清视频 | 日本特黄特色aaa大片免费 | 亚洲网站在线观看 | 毛片免费视频 | 妞干网av | 欧美日韩一区二区三区 | 亚洲乱码国产乱码精品精 | 亚洲精品一区二区三区蜜桃下载 | 久久蜜桃精品一区二区三区综合网 | 亚洲狠狠爱一区二区三区 | 99福利视频 | 在线播放国产一区二区三区 | 色爱区综合五月激情 | 日韩中文久久 | 激情网在线观看 | 日韩精品视频在线 | 香蕉久久夜色精品国产使用方法 | 国产色 | 激情欧美一区二区三区中文字幕 | 日韩中文视频 | 精品www| 极黄视频 | 中文字幕第66页 | 亚洲一级黄色 | 国产精品三级久久久久久电影 | 玖玖成人 | 久久久久久综合 | 一区二区免费视频 | 日韩一区二区不卡 | 国产免费av大片 | av官网在线 | 久久涩涩 | 91性高湖久久久久久久久网站 | 国产精品视频网站 | 日韩亚洲视频在线观看 | 国内精品视频一区二区三区八戒 | 国产精品久久久久久久久久东京 | 久久aⅴ国产欧美74aaa | 永久91嫩草亚洲精品人人 | 久久久久久久久久久九 | 6080yy午夜一二三区久久 | 精品视频网 | 国产在线乱 | 国产乱码精品一区二区三区手机版 | 91在线视频播放 | 国产福利一区二区 | 这里有精品在线视频 | 成人国产精品色哟哟 | 精品在线播放 | 免费一区 | av影院在线观看 | 欧美一卡二卡在线观看 | 国产高清视频在线 | 日韩一区不卡 | 久久久蜜桃一区二区人 | 国产专区一区二区三区 | 日韩精品免费在线观看 | 91视视频在线观看入口直接观看 | 超碰九七在线 | 国产视频综合 | 五月婷婷激情 | 国产日韩中文字幕 | 日本不卡免费新一二三区 | 在线观看你懂的网站 | 久久精品欧美一区二区三区不卡 | 国产精品一区二区久久 | 成人精品鲁一区一区二区 | 中文字幕在线第一页 | 韩国精品一区二区三区 | 精品中文字幕在线 | 精品在线| 久久精品在线视频 | 91久久国产精品 | 国产精品免费一区二区三区四区 | 欧美精品二区 | 午夜激情视频在线观看 | av片在线免费观看 | 午夜精品久久久久99蜜 | 日本小视频网站 | 亚洲一二| 成人在线不卡 | 中文字幕免费看 | 91精品国产日韩91久久久久久 | 精品一区二区在线观看 | 午夜国产影院 | 神马久久久久久久久 | 国产大学生情侣呻吟视频 | 欧美 日韩 国产 一区 | 麻豆久久久9性大片 | 成人在线免费视频 | 精品在线一区二区 | 亚洲伦理 | 在线观看日韩av | 欧美激情一区二区三区四区 | 久久99精品久久久久子伦 | 午夜爽爽影院 | 日本黄色一级电影 | 亚洲成人av在线 | 丰满少妇久久久久久久 | 久久久久中文字幕 | 欧美一区二区大片 | 中文字幕 亚洲一区 | 精品视频免费观看 | 亚洲国产免费 | 免费成人高清 | 国产在线观看高清 | 日韩成人av在线 | 婷婷久久五月天 | 久二影院| 国产亚洲精品久久久久动 | 亚洲最大的黄色网 | 国产高清美女一级a毛片久久 | 最新日韩免费 |