日韩成人免费在线_国产成人一二_精品国产免费人成电影在线观..._日本一区二区三区久久久久久久久不

當前位置:首頁 > 科技  > 軟件

良苦用心啊!我把七大跨域解決方法原理畫成十張圖,做成圖解!

來源: 責編: 時間:2024-03-20 17:25:40 255觀看
導讀前言大家好,我是林三心。用最通俗易懂的話講最難的知識點是我的座右銘,基礎是進階的前提是我的初衷。咱們做前端的,平時跟后端對接接口那是必須的事情,但是可能很多同學忽略了一個對接過程中可能會發生的問題——跨域,那跨

前言

大家好,我是林三心。用最通俗易懂的話講最難的知識點是我的座右銘,基礎是進階的前提是我的初衷。ljN28資訊網——每日最新資訊28at.com

咱們做前端的,平時跟后端對接接口那是必須的事情,但是可能很多同學忽略了一個對接過程中可能會發生的問題——跨域,那跨域到底是啥呢?為什么會跨域呢?又怎么才能解決呢?ljN28資訊網——每日最新資訊28at.com

截屏2021-10-01 上午7.16.06.png截屏2021-10-01 上午7.16.06.pngljN28資訊網——每日最新資訊28at.com

為什么跨域?

為什么會出現跨域問題呢?那就不得不講瀏覽器的同源策略了,它規定了協議號-域名-端口號這三者必須都相同才符合同源策略ljN28資訊網——每日最新資訊28at.com

圖片圖片ljN28資訊網——每日最新資訊28at.com

截屏2021-10-01 上午8.50.11.pngljN28資訊網——每日最新資訊28at.com

如有有一個不相同,就會出現跨域問題,不符合同源策略導致的后果有ljN28資訊網——每日最新資訊28at.com

1、LocalStorge、SessionStorge、Cookie等瀏覽器內存無法跨域訪問ljN28資訊網——每日最新資訊28at.com

2、DOM節點無法跨域操作ljN28資訊網——每日最新資訊28at.com

3、Ajax請求無法跨域請求ljN28資訊網——每日最新資訊28at.com

注意點:一個IP是可以注冊多個不同域名的,也就是多個域名可能指向同一個IP,即使是這樣,他們也不符合同源策略ljN28資訊網——每日最新資訊28at.com

圖片圖片ljN28資訊網——每日最新資訊28at.com

截屏2021-10-01 上午9.02.55.pngljN28資訊網——每日最新資訊28at.com

跨域的時機?

跨域發生在什么時候呢?我考過很多位同學,得到了兩種答案ljN28資訊網——每日最新資訊28at.com

1、請求一發出就被瀏覽器的跨域報錯攔下來了(大多數人回答)ljN28資訊網——每日最新資訊28at.com

2、請求發出去到后端,后端返回數據,在瀏覽器接收后端數據時被瀏覽器的跨域報錯攔下來ljN28資訊網——每日最新資訊28at.com

那到底是哪種呢?我們可以驗證下,咱們先npm i nodemon -g,然后創建一個index.js,然后nodemon index起一個node服務ljN28資訊網——每日最新資訊28at.com

// index.js  http://127.0.0.1:8000const http = require('http');const port = 8000;http.createServer(function (req, res) {    const { query } = urllib.parse(req.url, true);    console.log(query.name)    console.log('到后端嘍')    res.end(JSON.stringify('林三心'));}).listen(port, function () {    console.log('server is listening on port ' + port);})

再創建一個index.html,用來寫前端的請求代碼,咱們就寫一個簡單的AJAX請求吧ljN28資訊網——每日最新資訊28at.com

// index.html  http://127.0.0.1:5500/index.html<script>    //步驟一:創建異步對象    var ajax = new XMLHttpRequest();    //步驟二:設置請求的url參數,參數一是請求的類型,參數二是請求的url,可以帶參數    ajax.open('get', 'http://127.0.0.1:8000?name=前端過來的林三心');    //步驟三:發送請求    ajax.send();    //步驟四:注冊事件 onreadystatechange 狀態改變就會調用    ajax.onreadystatechange = function () {        if (ajax.readyState == 4 && ajax.status == 200) {            //步驟五 如果能夠進到這個判斷 說明 數據 完美的回來了,并且請求的頁面是存在的            console.log(ajax.responseText);//輸入相應的內容        }    }</script>

圖片圖片ljN28資訊網——每日最新資訊28at.com

最終,前端確實是跨域報錯了。但這不是結果,我們要想知道是哪一個答案,關鍵在于看后端的node服務那里有沒有輸出,就一目了然了。所以,答案2才是對的。ljN28資訊網——每日最新資訊28at.com

圖片圖片ljN28資訊網——每日最新資訊28at.com

圖片圖片ljN28資訊網——每日最新資訊28at.com

同域情況 && 跨域情況?

前面提到了同源策略,滿足協議號-域名-端口號這三者都相同就是同域,反之就是跨域,會導致跨域報錯,下面通過幾個例子讓大家鞏固一下對同域和跨域的認識把!ljN28資訊網——每日最新資訊28at.com

圖片圖片ljN28資訊網——每日最新資訊28at.com

解決跨域的方案

跨域其實是一個很久的問題了,對應的解決方案也有很多,一起接著往下讀吧!!!ljN28資訊網——每日最新資訊28at.com

JSONP

前面咱們說了,因為瀏覽器同源策略的存在,導致存在跨域問題,那有沒有不受跨域問題所束縛的東西呢?其實是有的,以下這三個標簽加載資源路徑是不受束縛的ljN28資訊網——每日最新資訊28at.com

  • 1、script標簽:<script src="加載資源路徑"></script>
  • 2、link標簽:<link herf="加載資源路徑"></link>
  • 3、img標簽:<img src="加載資源路徑"></img>

而JSONP就是利用了script的src加載不受束縛,從而可以擁有從不同的域拿到數據的能力。但是JSONP需要前端后端配合,才能實現最終的跨域獲取數據。ljN28資訊網——每日最新資訊28at.com

JSONP通俗點說就是:利用script的src去發送請求,將一個方法名callback傳給后端,后端拿到這個方法名,將所需數據,通過字符串拼接成新的字符串callback(所需數據),并發送到前端,前端接收到這個字符串之后,就會自動執行方法callback(所需數據)。老規矩,先上圖,再上代碼。ljN28資訊網——每日最新資訊28at.com

圖片圖片ljN28資訊網——每日最新資訊28at.com

后端代碼:ljN28資訊網——每日最新資訊28at.com

// index.js  http://127.0.0.1:8000const http = require('http');const urllib = require('url');const port = 8000;http.createServer(function (req, res) {    const { query } = urllib.parse(req.url, true);    if (query && query.callback) {        const { name, age, callback } = query        const person = `${name}今年${age}歲啦!!!`        const str = `${callback}(${JSON.stringify(person)})` // 拼成callback(data)        res.end(str);    } else {        res.end(JSON.stringify('沒東西啊你'));    }}).listen(port, function () {    console.log('server is listening on port ' + port);})

前端代碼:ljN28資訊網——每日最新資訊28at.com

// index.html  http://127.0.0.1:5500/index.html    const jsonp = (url, params, cbName) => {        return new Promise((resolve, reject) => {            const script = document.createElement('script')            window[cbName] = (data) => {                resolve(data)                document.body.removeChild(script)            }            params = { ...params, callback: cbName }            const arr = Object.keys(params).map(key => `${key}=${params[key]}`)            script.src = `${url}?${arr.join('&')}`            document.body.appendChild(script)        })    }    jsonp('http://127.0.0.1:8000', { name: '林三心', age: 23 }, 'callback').then(data => {        console.log(data) // 林三心今年23歲啦!!!    })

圖片圖片ljN28資訊網——每日最新資訊28at.com

JSONP的缺點就是,需要前后端配合,并且只支持get請求方法。ljN28資訊網——每日最新資訊28at.com

WebSocket

WebSocket是什么東西?其實我也不怎么懂,但是我也不會像別人一樣把MDN的資料直接復制過來,因為復制過來相信大家也是看不懂的。ljN28資訊網——每日最新資訊28at.com

我理解的WebSocket是一種協議(跟http同級,都是協議),并且他可以進行跨域通信,為什么他支持跨域通信呢?我這里找到一篇文章WebSocket憑啥可以跨域?,講的挺好。ljN28資訊網——每日最新資訊28at.com

圖片圖片ljN28資訊網——每日最新資訊28at.com

后端代碼

先安裝npm i ws。ljN28資訊網——每日最新資訊28at.com

// index.js  http://127.0.0.1:8000const Websocket = require('ws');const port = 8000;const ws = new Websocket.Server({ port })ws.on('connection', (obj) => {    obj.on('message', (data) => {        data = JSON.parse(data.toString())        const { name, age } = data        obj.send(`${name}今年${age}歲啦!!!`)    })})

前端代碼:ljN28資訊網——每日最新資訊28at.com

// index.html  http://127.0.0.1:5500/index.html    function myWebsocket(url, params) {        return new Promise((resolve, reject) => {            const socket = new WebSocket(url)            socket.onopen = () => {                socket.send(JSON.stringify(params))            }            socket.onmessage = (e) => {                resolve(e.data)            }        })    }    myWebsocket('ws://127.0.0.1:8000', { name: '林三心', age: 23 }).then(data => {        console.log(data) // 林三心今年23歲啦!!!    })

結果如下:ljN28資訊網——每日最新資訊28at.com

圖片圖片ljN28資訊網——每日最新資訊28at.com

截屏2021-10-01 下午1.47.29.pngljN28資訊網——每日最新資訊28at.com

Cors

Cors,全稱是Cross-Origin Resource Sharing,意思是跨域資源共享,Cors一般是由后端來開啟的,一旦開啟,前端就可以跨域訪問后端。ljN28資訊網——每日最新資訊28at.com

為什么后端開啟Cors,前端就能跨域請求后端呢?我的理解是:前端跨域訪問到后端,后端開啟Cors,發送Access-Control-Allow-Origin: 域名 字段到前端(其實不止一個),前端瀏覽器判斷Access-Control-Allow-Origin的域名如果跟前端域名一樣,瀏覽器就不會實行跨域攔截,從而解決跨域問題。ljN28資訊網——每日最新資訊28at.com

圖片圖片ljN28資訊網——每日最新資訊28at.com

后端代碼

// index.js  http://127.0.0.1:8000const http = require('http');const urllib = require('url');const port = 8000;http.createServer(function (req, res) {    // 開啟Cors    res.writeHead(200, {        //設置允許跨域的域名,也可設置*允許所有域名        'Access-Control-Allow-Origin': 'http://127.0.0.1:5500',        //跨域允許的請求方法,也可設置*允許所有方法        "Access-Control-Allow-Methods": "DELETE,PUT,POST,GET,OPTIONS",        //允許的header類型        'Access-Control-Allow-Headers': 'Content-Type'    })    const { query: { name, age } } = urllib.parse(req.url, true);    res.end(`${name}今年${age}歲啦!!!`);}).listen(port, function () {    console.log('server is listening on port ' + port);})

前端代碼

// index.html  http://127.0.0.1:5500/index.html    //步驟一:創建異步對象    var ajax = new XMLHttpRequest();    //步驟二:設置請求的url參數,參數一是請求的類型,參數二是請求的url,可以帶參數    ajax.open('get', 'http://127.0.0.1:8000?name=林三心&age=23');    //步驟三:發送請求    ajax.send();    //步驟四:注冊事件 onreadystatechange 狀態改變就會調用    ajax.onreadystatechange = function () {        if (ajax.readyState == 4 && ajax.status == 200) {            //步驟五 如果能夠進到這個判斷 說明 數據 完美的回來了,并且請求的頁面是存在的            console.log(ajax.responseText);//輸入相應的內容        }    }

結果如下:ljN28資訊網——每日最新資訊28at.com

圖片圖片ljN28資訊網——每日最新資訊28at.com

截屏2021-10-01 下午1.47.29.pngljN28資訊網——每日最新資訊28at.com

圖片圖片ljN28資訊網——每日最新資訊28at.com

Node接口代理

還是回到同源策略,同源策略它只是瀏覽器的一個策略而已,它是限制不到后端的,也就是前端-后端會被同源策略限制,但是后端-后端則不會被限制,所以可以通過Node接口代理,先訪問已設置Cors的后端1,再讓后端1去訪問后端2獲取數據到后端1,后端1再把數據傳到前端。ljN28資訊網——每日最新資訊28at.com

圖片圖片ljN28資訊網——每日最新資訊28at.com

后端2代碼

// index.js  http://127.0.0.1:8000const http = require('http');const urllib = require('url');const port = 8000;http.createServer(function (req, res) {    console.log(888)    const { query: { name, age } } = urllib.parse(req.url, true);    res.end(`${name}今年${age}歲啦!!!`)}).listen(port, function () {    console.log('server is listening on port ' + port);})

創建一個index2.js,并nodemon index2.jsljN28資訊網——每日最新資訊28at.com

后端1代碼

// index2.js  http://127.0.0.1:8888const http = require('http');const urllib = require('url');const querystring = require('querystring');const port = 8888;http.createServer(function (req, res) {    // 開啟Cors    res.writeHead(200, {        //設置允許跨域的域名,也可設置*允許所有域名        'Access-Control-Allow-Origin': 'http://127.0.0.1:5500',        //跨域允許的請求方法,也可設置*允許所有方法        "Access-Control-Allow-Methods": "DELETE,PUT,POST,GET,OPTIONS",        //允許的header類型        'Access-Control-Allow-Headers': 'Content-Type'    })    const { query } = urllib.parse(req.url, true);    const { methods = 'GET', headers } = req    const proxyReq = http.request({        host: '127.0.0.1',        port: '8000',        path: `/?${querystring.stringify(query)}`,        methods,        headers    }, proxyRes => {        proxyRes.on('data', chunk => {            console.log(chunk.toString())            res.end(chunk.toString())        })    }).end()}).listen(port, function () {    console.log('server is listening on port ' + port);})

前端代碼

// index.html  http://127.0.0.1:5500//步驟一:創建異步對象    var ajax = new XMLHttpRequest();    //步驟二:設置請求的url參數,參數一是請求的類型,參數二是請求的url,可以帶參數,動態的傳遞參數starName到服務端    ajax.open('get', 'http://127.0.0.1:8888?name=林三心&age=23');    //步驟三:發送請求    ajax.send();    //步驟四:注冊事件 onreadystatechange 狀態改變就會調用    ajax.onreadystatechange = function () {        if (ajax.readyState == 4 && ajax.status == 200) {            //步驟五 如果能夠進到這個判斷 說明 數據 完美的回來了,并且請求的頁面是存在的            console.log(ajax.responseText);//輸入相應的內容        }    }

結果如下:ljN28資訊網——每日最新資訊28at.com

圖片圖片ljN28資訊網——每日最新資訊28at.com

Nginx

其實Nginx跟Node接口代理是一個道理,只不過Nginx就不需要我們自己去搭建一個中間服務。ljN28資訊網——每日最新資訊28at.com

圖片圖片ljN28資訊網——每日最新資訊28at.com

先下載nginx[1],然后將nginx目錄下的nginx.conf修改如下:ljN28資訊網——每日最新資訊28at.com

server{        listen 8888;        server_name  127.0.0.1;         location /{            proxy_pass 127.0.0.1:8000;        }    }

最后通過命令行nginx -s reload啟動nginx。ljN28資訊網——每日最新資訊28at.com

后端代碼

// index.js  http://127.0.0.1:8000const http = require('http');const urllib = require('url');const port = 8000;http.createServer(function (req, res) {    const { query: { name, age } } = urllib.parse(req.url, true);    res.end(`${name}今年${age}歲啦!!!`);}).listen(port, function () {    console.log('server is listening on port ' + port);})

前端代碼

// index.html  http://127.0.0.1:5500//步驟一:創建異步對象    var ajax = new XMLHttpRequest();    //步驟二:設置請求的url參數,參數一是請求的類型,參數二是請求的url,可以帶參數,動態的傳遞參數starName到服務端    ajax.open('get', 'http://127.0.0.1:8888?name=林三心&age=23');    //步驟三:發送請求    ajax.send();    //步驟四:注冊事件 onreadystatechange 狀態改變就會調用    ajax.onreadystatechange = function () {        if (ajax.readyState == 4 && ajax.status == 200) {            //步驟五 如果能夠進到這個判斷 說明 數據 完美的回來了,并且請求的頁面是存在的            console.log(ajax.responseText);//輸入相應的內容        }    }

結果如下:ljN28資訊網——每日最新資訊28at.com

圖片圖片ljN28資訊網——每日最新資訊28at.com

postMessage

場景:http://127.0.0.1:5500/index.html頁面中使用了iframe標簽內嵌了一個http://127.0.0.1:5555/index.html的頁面。ljN28資訊網——每日最新資訊28at.com

雖然這兩個頁面存在于一個頁面中,但是需要iframe標簽來嵌套才行,這兩個頁面之間是無法進行通信的,因為他們端口號不同,根據同源策略,他們之間存在跨域問題。ljN28資訊網——每日最新資訊28at.com

那應該怎么辦呢?使用postMessage可以使這兩個頁面進行通信。ljN28資訊網——每日最新資訊28at.com

圖片圖片ljN28資訊網——每日最新資訊28at.com

// http:127.0.0.1:5500/index.html<body>    <iframe src="http://127.0.0.1:5555/index.html" id="frame"></iframe></body><script>    document.getElementById('frame').onload = function () {        this.contentWindow.postMessage({ name: '林三心', age: 23 }, 'http://127.0.0.1:5555')        window.onmessage = function (e) {            console.log(e.data) // 林三心今年23歲啦!!!        }    }</script>
// http://127.0.0.1:5555/index.html<script>        window.onmessage = function (e) {            const { data: { name, age }, origin } = e            e.source.postMessage(`${name}今年${age}歲啦!!!`, origin)        }</script>

document.domain && iframe

場景:a.sanxin.com/index.html 與 b.sanxin.com/index.html之間的通信。ljN28資訊網——每日最新資訊28at.com

其實上面這兩個正常情況下是無法通信的,因為他們的域名不相同,屬于跨域通信。ljN28資訊網——每日最新資訊28at.com

那怎么辦呢?其實他們有一個共同點,那就是他們的二級域名都是sanxin.com,這使得他們可以通過document.domain && iframe的方式來通信。ljN28資訊網——每日最新資訊28at.com

圖片圖片ljN28資訊網——每日最新資訊28at.com

由于本菜鳥暫時沒有服務器,所以暫時使用本地來模擬。ljN28資訊網——每日最新資訊28at.com

// http://127.0.0.1:5500/index.html<body>    <iframe src="http://127.0.0.1:5555/index.html" id="frame"></iframe></body><script>    document.domain = '127.0.0.1'    document.getElementById('frame').onload = function () {        console.log(this.contentWindow.data) // 林三心今年23歲啦!!!    }</script>
// http://127.0.0.1:5555/index.html <script>        // window.name="林三心今年23歲啦!!!"        document.domain = '127.0.0.1'        var data = '林三心今年23歲啦!!!';</script>

結果如下:ljN28資訊網——每日最新資訊28at.com

圖片圖片ljN28資訊網——每日最新資訊28at.com

本文鏈接:http://m.www897cc.com/showinfo-26-78142-0.html良苦用心啊!我把七大跨域解決方法原理畫成十張圖,做成圖解!

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。郵件:2376512515@qq.com

上一篇: 微軟推出 Garnet 緩存存儲系統:高吞吐量、低延遲、可擴展

下一篇: 月之暗面技術重磅突破:Kimi200萬字上下文窗口內測開啟

標簽:
  • 熱門焦點
  • 俄羅斯:將審查iPhone等外國公司設備 保數據安全

    iPhone和特斯拉都屬于在各自領域領頭羊的品牌,推出的產品也也都是數一數二的,但對于一些國家而言,它們的產品可靠性和安全性還是在限制范圍內。近日,俄羅斯聯邦通信、信息技術
  • 8月總票房已突破10億!《封神》第一:口碑已經成了

    8月5日消息,據燈塔專業版數據,截至8月5日9時35分,8月總票房(含預售)已突破10億。其中,《封神》以大比分的優勢領先。根據官方消息,目前該片總票房已經超過14.
  • 0糖0卡0脂 旭日森林仙草烏龍茶優惠:15瓶到手29元

    旭日森林無糖仙草烏龍茶510ml*15瓶平時要賣為79.9元,今日下單領取50元優惠券,到手價為29.9元。產品規格:0糖0卡0脂,添加草本仙草汁,清涼爽口,富含茶多酚,保留
  • 線程通訊的三種方法!通俗易懂

    線程通信是指多個線程之間通過某種機制進行協調和交互,例如,線程等待和通知機制就是線程通訊的主要手段之一。 在 Java 中,線程等待和通知的實現手段有以下幾種方式:Object 類下
  • 把LangChain跑起來的三個方法

    使用LangChain開發LLM應用時,需要機器進行GLM部署,好多同學第一步就被勸退了,那么如何繞過這個步驟先學習LLM模型的應用,對Langchain進行快速上手?本片講解3個把LangChain跑起來
  • 三言兩語說透設計模式的藝術-單例模式

    寫在前面單例模式是一種常用的軟件設計模式,它所創建的對象只有一個實例,且該實例易于被外界訪問。單例對象由于只有一個實例,所以它可以方便地被系統中的其他對象共享,從而減少
  • 小紅書1周漲粉49W+,我總結了小白可以用的N條漲粉筆記

    作者:黃河懂運營一條性教育視頻,被54萬人&ldquo;珍藏&rdquo;是什么體驗?最近,情感博主@公主是用鮮花做的,火了!僅僅憑借一條視頻,光小紅書就有超過128萬人,為她瘋狂點贊!更瘋狂的是,這
  • 當家的盒馬,加速謀生

    來源 | 價值星球Planet作者 | 歸去來自己&ldquo;當家&rdquo;的盒馬,開始加速謀生了。據盒馬官微消息,盒馬計劃今年開放生鮮供應鏈,將其生鮮商品送往食堂。目前,盒馬在上海已經與
  • 榮耀Magicbook V 14 2021曙光藍版本正式開售,擁有觸摸屏

    榮耀 Magicbook V 14 2021 曙光藍版本正式開售,搭載 i7-11390H 處理器與 MX450 顯卡,配備 16GB 內存與 512GB SSD,重 1.48kg,厚 14.5mm,具有 1.5mm 鍵盤鍵程、
Top 日韩成人免费在线_国产成人一二_精品国产免费人成电影在线观..._日本一区二区三区久久久久久久久不
在线观看91精品国产入口| 欧美日韩一区二区精品| 亚洲欧美久久久久一区二区三区| 亚洲女人小视频在线观看| 久久精品国产久精国产一老狼| 免费成人av在线看| 欧美视频中文一区二区三区在线观看| 国产欧美一区二区三区沐欲| 影视先锋久久| 在线一区亚洲| 久久精品国产第一区二区三区| 欧美~级网站不卡| 国产精品啊v在线| 精东粉嫩av免费一区二区三区| 日韩网站在线观看| 欧美在线视频免费| 欧美国产三区| 国产欧美在线观看一区| 亚洲人成网站777色婷婷| 亚洲欧美日本视频在线观看| 老司机一区二区| 欧美香蕉视频| 在线观看视频欧美| 亚洲一区影音先锋| 欧美成人r级一区二区三区| 国产精品丝袜91| 亚洲精品国产拍免费91在线| 欧美专区18| 欧美视频四区| 亚洲国产日韩精品| 欧美一级二区| 欧美日韩视频专区在线播放| 伊人精品久久久久7777| 亚洲欧美日韩国产中文| 欧美粗暴jizz性欧美20| 国产一区二区你懂的| 一区二区三区欧美日韩| 你懂的国产精品永久在线| 国产精品自拍三区| 一区二区三区精品国产| 免费不卡视频| 国产在线拍偷自揄拍精品| 亚洲视频在线观看视频| 欧美国产日产韩国视频| 国产综合欧美| 亚洲免费在线| 欧美日韩综合视频网址| 91久久嫩草影院一区二区| 久久久久久亚洲精品杨幂换脸| 国产精品视频网| 一本不卡影院| 欧美大片专区| 尤妮丝一区二区裸体视频| 欧美一区二区三区在线观看| 欧美丝袜一区二区| 日韩一区二区高清| 欧美不卡在线视频| 一区二区三区无毛| 久久精品人人做人人爽| 国产美女扒开尿口久久久| 日韩午夜在线电影| 欧美成人一区二区三区片免费| 狠狠狠色丁香婷婷综合久久五月| 欧美一级视频| 国产麻豆精品theporn| 亚洲欧美国内爽妇网| 欧美午夜精品久久久久久久| 99精品视频一区| 欧美日韩国产色综合一二三四| 亚洲精品视频在线观看网站| 欧美国产欧美亚洲国产日韩mv天天看完整 | 欧美日韩国产va另类| 亚洲国产99| 老牛嫩草一区二区三区日本| 禁久久精品乱码| 久久免费黄色| 在线看片欧美| 美腿丝袜亚洲色图| 亚洲国产精品久久久久秋霞蜜臀| 免费看av成人| 亚洲人体1000| 欧美国产欧美亚洲国产日韩mv天天看完整| 亚洲黄色成人久久久| 欧美高清在线一区| 日韩视频免费在线| 欧美视频中文一区二区三区在线观看 | 欧美v日韩v国产v| 亚洲激情亚洲| 欧美美女bbbb| 在线亚洲欧美专区二区| 国产精品乱子乱xxxx| 午夜久久美女| 激情综合色综合久久| 久久夜色精品国产| 亚洲人永久免费| 欧美日韩一区二区视频在线观看| 亚洲一区二区在线视频 | 亚洲无线一线二线三线区别av| 国产精品激情电影| 篠田优中文在线播放第一区| 国产亚洲免费的视频看| 久久免费视频网| 亚洲日本va在线观看| 欧美日韩一区二区在线观看视频| 亚洲香蕉视频| 国产一区在线播放| 你懂的国产精品| 99视频超级精品| 国产精品一区二区视频| 久久久久高清| 亚洲精品小视频| 久久激情久久| 午夜精品区一区二区三| 午夜精品999| 久久久久久久久久久久久女国产乱| 亚洲欧美日韩成人高清在线一区| 欧美在线精品免播放器视频| 激情丁香综合| 国产日本欧美一区二区三区| 国产精品久久久久天堂| 国产精品视频午夜| 精品二区视频| 亚洲乱码国产乱码精品精98午夜| 亚洲一区三区视频在线观看| 欧美国产视频日韩| 亚洲精品一区二区三区av| 久久精品国产99精品国产亚洲性色| 欧美性大战久久久久久久| 国产丝袜一区二区三区| 狠狠色综合日日| 亚洲小说欧美另类婷婷| 欧美激情一级片一区二区| 欧美三级小说| 国产精品一区一区| 国内成+人亚洲+欧美+综合在线| 狠狠色香婷婷久久亚洲精品| 先锋影音久久| 欧美一区二区啪啪| 欧美精品免费视频| 国内精品视频一区| 久久av在线看| 欧美成人综合| 亚洲人成网站影音先锋播放| 久久美女性网| 欧美日韩情趣电影| 精品av久久707| 久久精品系列| 国产日韩欧美综合在线| 亚洲性色视频| 久久国产精品99久久久久久老狼| 国产中文一区二区三区| 欧美精品电影| 久久精品国产91精品亚洲| 日韩视频三区| 欧美日韩三级一区二区| 亚洲伊人伊色伊影伊综合网| 国产一区二区三区免费观看| 亚洲一区二区三区中文字幕| 亚洲激情在线观看| 国产精品亚洲аv天堂网| 欧美成年网站| 久久久精品欧美丰满| 亚洲一区图片| 日韩一级片网址| 亚洲二区在线视频| 国产一区二区三区黄视频| 欧美午夜欧美| 欧美精品二区| 老司机精品视频一区二区三区| 欧美一区二区三区在| 亚洲一区二区高清视频| 亚洲美女免费视频| 亚洲福利视频一区二区| 国语精品中文字幕| 国产美女精品视频免费观看| 欧美日韩国产在线播放网站| 免费高清在线一区| 久久免费黄色| 久久精品成人一区二区三区| 午夜一区二区三区不卡视频| 中日韩美女免费视频网站在线观看| 亚洲人成网在线播放| 亚洲国产欧美日韩另类综合| 精品二区视频| 精久久久久久| 国内精品美女av在线播放| 国产日韩欧美综合| 国产精品夜夜夜一区二区三区尤| 欧美三级欧美一级| 欧美日韩国产精品成人| 欧美极品色图| 欧美精品色网| 欧美精品在线看| 欧美激情中文字幕一区二区| 黄色av一区| 久久亚洲视频| 久久国产视频网| 欧美一二三区精品| 亚洲欧美日韩专区| 亚洲一级黄色片| 中文av一区特黄| 一区二区三区免费看| 一区二区欧美在线| 在线视频欧美日韩|