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

幾種常見的跨域解決方案

開發 前端
跨域是指指的是瀏覽器不能執行其他網站的腳本,從一個域名的網頁去請求另一個域名的資源時,域名、端口、協議任一不同,都是跨域。跨域是由瀏覽器的同源策略造成的,是瀏覽器施加的安全限制。

什么是跨域?

跨域是指指的是瀏覽器不能執行其他網站的腳本,從一個域名的網頁去請求另一個域名的資源時,域名、端口、協議任一不同,都是跨域。跨域是由瀏覽器的同源策略造成的,是瀏覽器施加的安全限制。

什么是同源策略?

同源策略是一種約定,由Netscape公司1995年引入瀏覽器,它是瀏覽器最核心也最基本的安全功能,如果缺少了同源策略,瀏覽器很容易受到XSS、CSFR等攻擊。所謂同源是指協議+域名+端口三者相同,三者中只要有一個不相同就會造成跨域。

同源策略限制以下幾種行為:

  • Cookie、LocalStorage 和 IndexDB 無法讀取
  • DOM和JS對象無法獲得
  • AJAX 請求不能發送

常見的跨域場景

URL

說明

是否允許通信

www.domain.com/a.js www.domain.com/b.js www.domain.com/lab/c.js

同一域名,不同文件或路徑

允許

www.domain.com:8000/a.js www.domain.com/b.js

同一域名,不同端口

不允許

http://www.domain.com/a.js https://www.domain.com/b.js

同一域名,不同協議

不允許

http://www.domain.com/a.js http://192.168.4.12/b.js

域名和域名對應相同ip

不允許

http://www.domain.com/a.js http://x.domain.com/b.js http://domain.com/c.js

主域相同,子域不同

不允許

http://www.domain1.com/a.js http://www.domain2.com/b.js

不同域名

不允許

幾種跨域解決方案

JSONP跨域

jsonp的原理就是利用<script>標簽沒有跨域限制,通過<script>標簽src屬性,發送帶有callback參數的GET請求,服務端將接口返回數據拼湊到callback函數中,返回給瀏覽器,瀏覽器解析執行,從而前端拿到callback函數返回的數據。

「原生JS實現:」

<script>
    var script = document.createElement('script');
    script.type = 'text/javascript';

    // 傳參一個回調函數名給后端,方便后端返回時執行這個在前端定義的回調函數
    script.src = 'http://www.domain2.com:8080/login?user=admin&callback=handleCallback';
    document.head.appendChild(script);

    // 回調執行函數
    function handleCallback(res) {
        alert(JSON.stringify(res));
    }
 </script>

服務端返回如下(返回時即執行全局函數):

handleCallback({"success": true, "user": "admin"})

「axios實現:」

this.$http = axios;
this.$http.jsonp('http://www.domain2.com:8080/login', {
    params: {},
    jsonp: 'handleCallback'
}).then((res) => {
    console.log(res); 
})

后端node.js代碼:

var querystring = require('querystring');
var http = require('http');
var server = http.createServer();

server.on('request', function(req, res) {
    var params = querystring.parse(req.url.split('?')[1]);
    var fn = params.callback;

    // jsonp返回設置
    res.writeHead(200, { 'Content-Type': 'text/javascript' });
    res.write(fn + '(' + JSON.stringify(params) + ')');

    res.end();
});

server.listen('8080');
console.log('Server is running at port 8080...');

jsonp的缺點:只能發送get一種請求。

跨域資源共享(CORS)

「CORS」是一個W3C標準,全稱是"跨域資源共享"(Cross-origin resource sharing)。 它允許瀏覽器向跨源服務器,發出XMLHttpRequest請求,從而克服了AJAX只能同源使用的限制。 CORS需要瀏覽器和服務器同時支持。目前,所有瀏覽器都支持該功能,IE瀏覽器不能低于IE10。

瀏覽器將CORS跨域請求分為簡單請求和非簡單請求。

只要同時滿足一下兩個條件,就屬于簡單請求

(1)使用下列方法之一:

  • head
  • get
  • post

(2)請求的Heder是

  • Accept
  • Accept-Language
  • Content-Language
  • Content-Type: 只限于三個值:application/x-www-form-urlencoded、multipart/form-data、text/plain

不同時滿足上面的兩個條件,就屬于非簡單請求。瀏覽器對這兩種的處理,是不一樣的。

簡單請求

對于簡單請求,瀏覽器直接發出CORS請求。具體來說,就是在頭信息之中,增加一個Origin字段。

GET /cors HTTP/1.1
Origin: http://api.bob.com
Host: api.alice.com
Accept-Language: en-US
Connection: keep-alive
User-Agent: Mozilla/5.0...

上面的頭信息中,Origin字段用來說明,本次請求來自哪個源(協議 + 域名 + 端口)。服務器根據這個值,決定是否同意這次請求。

CORS請求設置的響應頭字段,都以 Access-Control-開頭:

「1)Access-Control-Allow-Origin」:必選

它的值要么是請求時Origin字段的值,要么是一個*,表示接受任意域名的請求。

「2)Access-Control-Allow-Credentials」:可選

它的值是一個布爾值,表示是否允許發送Cookie。默認情況下,Cookie不包括在CORS請求之中。設為true,即表示服務器明確許可,Cookie可以包含在請求中,一起發給服務器。這個值也只能設為true,如果服務器不要瀏覽器發送Cookie,刪除該字段即可。

「3)Access-Control-Expose-Headers」:可選

CORS請求時,XMLHttpRequest對象的getResponseHeader()方法只能拿到6個基本字段:Cache-Control、Content-Language、Content-Type、Expires、Last-Modified、Pragma。如果想拿到其他字段,就必須在Access-Control-Expose-Headers里面指定。上面的例子指定,getResponseHeader(‘FooBar’)可以返回FooBar字段的值。

非簡單請求

非簡單請求是那種對服務器有特殊要求的請求,比如請求方法是PUT或DELETE,或者Content-Type字段的類型是application/json。非簡單請求的CORS請求,會在正式通信之前,增加一次HTTP查詢請求,稱為"預檢"請求(preflight)。

預檢請求

預檢"請求用的請求方法是OPTIONS,表示這個請求是用來詢問的。請求頭信息里面,關鍵字段是Origin,表示請求來自哪個源。除了Origin字段,"預檢"請求的頭信息包括兩個特殊字段。

OPTIONS /cors HTTP/1.1
Origin: http://api.bob.com
Access-Control-Request-Method: PUT
Access-Control-Request-Headers: X-Custom-Header
Host: api.alice.com
Accept-Language: en-US
Connection: keep-alive
User-Agent: Mozilla/5.0..

「1)Access-Control-Request-Method」:必選

用來列出瀏覽器的CORS請求會用到哪些HTTP方法,上例是PUT。

「2)Access-Control-Request-Headers」:可選

該字段是一個逗號分隔的字符串,指定瀏覽器CORS請求會額外發送的頭信息字段,上例是X-Custom-Header。

預檢請求的回應

服務器收到"預檢"請求以后,檢查了Origin、Access-Control-Request-Method和Access-Control-Request-Headers字段以后,確認允許跨源請求,就可以做出回應。

HTTP回應中,除了關鍵的是Access-Control-Allow-Origin字段,其他CORS相關字段如下:

「1)Access-Control-Allow-Methods」:必選

它的值是逗號分隔的一個字符串,表明服務器支持的所有跨域請求的方法。注意,返回的是所有支持的方法,而不單是瀏覽器請求的那個方法。這是為了避免多次"預檢"請求。

「2)Access-Control-Allow-Headers」

如果瀏覽器請求包括Access-Control-Request-Headers字段,則Access-Control-Allow-Headers字段是必需的。它也是一個逗號分隔的字符串,表明服務器支持的所有頭信息字段,不限于瀏覽器在"預檢"中請求的字段。

「3)Access-Control-Allow-Credentials」:可選

該字段與簡單請求時的含義相同。

「4)Access-Control-Max-Age」:可選

用來指定本次預檢請求的有效期,單位為秒。

CORS跨域示例

「1)前端設置」

  • 原生ajax:
var xhr = new XMLHttpRequest(); // IE8/9需用window.XDomainRequest兼容

// 前端設置是否帶cookie
xhr.withCredentials = true;

xhr.open('post', 'http://www.domain2.com:8080/login', true);
xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
xhr.send('user=admin');

xhr.onreadystatechange = function() {
    if (xhr.readyState == 4 && xhr.status == 200) {
        alert(xhr.responseText);
    }
};

「2)服務端設置」

  • nodejs代碼
var http = require('http');
var server = http.createServer();
var qs = require('querystring');

server.on('request', function(req, res) {
    var postData = '';

    // 數據塊接收中
    req.addListener('data', function(chunk) {
        postData += chunk;
    });

    // 數據接收完畢
    req.addListener('end', function() {
        postData = qs.parse(postData);

        // 跨域后臺設置
        res.writeHead(200, {
            'Access-Control-Allow-Credentials': 'true',     // 后端允許發送Cookie
            'Access-Control-Allow-Origin': 'http://www.domain1.com',    // 允許訪問的域(協議+域名+端口)
            /* 
             * 此處設置的cookie還是domain2的而非domain1,因為后端也不能跨域寫cookie(nginx反向代理可以實現),
             * 但只要domain2中寫入一次cookie認證,后面的跨域接口都能從domain2中獲取cookie,從而實現所有的接口都能跨域訪問
             */
            'Set-Cookie': 'l=a123456;Path=/;Domain=www.domain2.com;HttpOnly'  // HttpOnly的作用是讓js無法讀取cookie
        });

        res.write(JSON.stringify(postData));
        res.end();
    });
});

server.listen('8080');
console.log('Server is running at port 8080...');

nginx代理跨域

nginx代理跨域,實質和CORS跨域原理一樣,通過配置文件設置請求響應頭Access-Control-Allow-Origin…等字段。

nginx配置解決iconfont跨域

瀏覽器跨域訪問js、css、img等常規靜態資源被同源策略許可,但iconfont字體文件(eot|otf|ttf|woff|svg)例外,此時可在nginx的靜態資源服務器中加入以下配置。

location / {
  add_header Access-Control-Allow-Origin *;
}

nginx反向代理接口跨域

跨域問題:同源策略僅是針對瀏覽器的安全策略。服務器端調用HTTP接口只是使用HTTP協議,不需要同源策略,也就不存在跨域問題。

實現思路:通過Nginx配置一個代理服務器域名與domain1相同,端口不同)做跳板機,反向代理訪問domain2接口,并且可以順便修改cookie中domain信息,方便當前域cookie寫入,實現跨域訪問。

「nginx具體配置:」

#proxy服務器
server {
    listen       81;
    server_name  www.domain1.com;

    location / {
        proxy_pass   http://www.domain2.com:8080;  #反向代理
        proxy_cookie_domain www.domain2.com www.domain1.com; #修改cookie里域名
        index  index.html index.htm;

        # 當用webpack-dev-server等中間件代理接口訪問nignx時,此時無瀏覽器參與,故沒有同源限制,下面的跨域配置可不啟用
        add_header Access-Control-Allow-Origin http://www.domain1.com;  #當前端只跨域不帶cookie時,可為*
        add_header Access-Control-Allow-Credentials true;
    }
}

nodejs中間件代理跨域

node中間件實現跨域代理,原理大致與nginx相同,都是通過啟一個代理服務器,實現數據的轉發,也可以通過設置cookieDomainRewrite參數修改響應頭中cookie中域名,實現當前域的cookie寫入,方便接口登錄認證。

非vue框架的跨域

使用node + express + http-proxy-middleware搭建一個proxy服務器。

  • 前端代碼:
var xhr = new XMLHttpRequest();

// 前端開關:瀏覽器是否讀寫cookie
xhr.withCredentials = true;

// 訪問http-proxy-middleware代理服務器
xhr.open('get', 'http://www.domain1.com:3000/login?user=admin', true);
xhr.send();
  • 中間件服務器代碼:
var express = require('express');
var proxy = require('http-proxy-middleware');
var app = express();

app.use('/', proxy({
    // 代理跨域目標接口
    target: 'http://www.domain2.com:8080',
    changeOrigin: true,

    // 修改響應頭信息,實現跨域并允許帶cookie
    onProxyRes: function(proxyRes, req, res) {
        res.header('Access-Control-Allow-Origin', 'http://www.domain1.com');
        res.header('Access-Control-Allow-Credentials', 'true');
    },

    // 修改響應信息中的cookie域名
    cookieDomainRewrite: 'www.domain1.com'  // 可以為false,表示不修改
}));

app.listen(3000);
console.log('Proxy server is listen at port 3000...');

vue框架的跨域

node + vue + webpack + webpack-dev-server搭建的項目,跨域請求接口,直接修改webpack.config.js配置。開發環境下,vue渲染服務和接口代理服務都是webpack-dev-server同一個,所以頁面與代理接口之間不再跨域。

webpack.config.js部分配置:

module.exports = {
    entry: {},
    module: {},
    ...
    devServer: {
        historyApiFallback: true,
        proxy: [{
            context: '/login',
            target: 'http://www.domain2.com:8080',  // 代理跨域目標接口
            changeOrigin: true,
            secure: false,  // 當代理某些https服務報錯時用
            cookieDomainRewrite: 'www.domain1.com'  // 可以為false,表示不修改
        }],
        noInfo: true
    }
}

document.domain + iframe跨域

此方案僅限主域相同,子域不同的跨域應用場景。實現原理:兩個頁面都通過js強制設置document.domain為基礎主域,就實現了同域。

1)父窗口:http://www.domain.com/a.html

<iframe id="iframe" src="http://child.domain.com/b.html"></iframe>
<script>
    document.domain = 'domain.com';
    var user = 'admin';
</script>

1)子窗口:http://child.domain.com/a.html

<script>
    document.domain = 'domain.com';
    // 獲取父窗口中變量
    console.log('get js data from parent ---> ' + window.parent.user);
</script>

location.hash + iframe跨域

實現原理: a欲與b跨域相互通信,通過中間頁c來實現。 三個頁面,不同域之間利用iframe的location.hash傳值,相同域之間直接js訪問來通信。

具體實現:A域:a.html -> B域:b.html -> A域:c.html,a與b不同域只能通過hash值單向通信,b與c也不同域也只能單向通信,但c與a同域,所以c可通過parent.parent訪問a頁面所有對象。

1)a.html:http://www.domain1.com/a.html

<iframe id="iframe" src="http://www.domain2.com/b.html" style="display:none;"></iframe>
<script>
    var iframe = document.getElementById('iframe');

    // 向b.html傳hash值
    setTimeout(function() {
        iframe.src = iframe.src + '#user=admin';
    }, 1000);
    
    // 開放給同域c.html的回調方法
    function onCallback(res) {
        alert('data from c.html ---> ' + res);
    }
</script>

2)b.html:http://www.domain2.com/b.html

<iframe id="iframe" src="http://www.domain1.com/c.html" style="display:none;"></iframe>
<script>
    var iframe = document.getElementById('iframe');

    // 監聽a.html傳來的hash值,再傳給c.html
    window.onhashchange = function () {
        iframe.src = iframe.src + location.hash;
    };
</script>

3)c.html:http://www.domain1.com/c.html

<script>
    // 監聽b.html傳來的hash值
    window.onhashchange = function () {
        // 再通過操作同域a.html的js回調,將結果傳回
        window.parent.parent.onCallback('hello: ' + location.hash.replace('#user=', ''));
    };
</script>

window.name + iframe跨域

window.name屬性的獨特之處:name值在不同的頁面(甚至不同域名)加載后依舊存在,并且可以支持非常長的 name 值(2MB)。

1)a.html:http://www.domain1.com/a.html

var proxy = function(url, callback) {
    var state = 0;
    var iframe = document.createElement('iframe');

    // 加載跨域頁面
    iframe.src = url;

    // onload事件會觸發2次,第1次加載跨域頁,并留存數據于window.name
    iframe.onload = function() {
        if (state === 1) {
            // 第2次onload(同域proxy頁)成功后,讀取同域window.name中數據
            callback(iframe.contentWindow.name);
            destoryFrame();

        } else if (state === 0) {
            // 第1次onload(跨域頁)成功后,切換到同域代理頁面
            iframe.contentWindow.location = 'http://www.domain1.com/proxy.html';
            state = 1;
        }
    };

    document.body.appendChild(iframe);

    // 獲取數據以后銷毀這個iframe,釋放內存;這也保證了安全(不被其他域frame js訪問)
    function destoryFrame() {
        iframe.contentWindow.document.write('');
        iframe.contentWindow.close();
        document.body.removeChild(iframe);
    }
};

// 請求跨域b頁面數據
proxy('http://www.domain2.com/b.html', function(data){
    alert(data);
});

2)proxy.html:http://www.domain1.com/proxy.html

中間代理頁,與a.html同域,內容為空即可。

3)b.html:http://www.domain2.com/b.html

<script>
    window.name = 'This is domain2 data!';
</script>

通過iframe的src屬性由外域轉向本地域,跨域數據即由iframe的window.name從外域傳遞到本地域。這個就巧妙地繞過了瀏覽器的跨域訪問限制,但同時它又是安全操作。

postMessage跨域

postMessage是HTML5 XMLHttpRequest Level 2中的API,且是為數不多可以跨域操作的window屬性之一,它可用于解決以下方面的問題:

  • 頁面和其打開的新窗口的數據傳遞
  • 多窗口之間消息傳遞
  • 頁面與嵌套的iframe消息傳遞
  • 上面三個場景的跨域數據傳遞

用法:postMessage(data,origin)方法接受兩個參數:

  • 「data」: html5規范支持任意基本類型或可復制的對象,但部分瀏覽器只支持字符串,所以傳參時最好用JSON.stringify()序列化。
  • 「origin」: 協議+主機+端口號,也可以設置為"*",表示可以傳遞給任意窗口,如果要指定和當前窗口同源的話設置為"/"。

1)a.html:http://www.domain1.com/a.html

<iframe id="iframe" src="http://www.domain2.com/b.html" style="display:none;"></iframe>
<script>       
    var iframe = document.getElementById('iframe');
    iframe.onload = function() {
        var data = {
            name: 'aym'
        };
        // 向domain2傳送跨域數據
        iframe.contentWindow.postMessage(JSON.stringify(data), 'http://www.domain2.com');
    };

    // 接受domain2返回數據
    window.addEventListener('message', function(e) {
        alert('data from domain2 ---> ' + e.data);
    }, false);
</script>

2)b.html:http://www.domain2.com/b.html

<script>
    // 接收domain1的數據
    window.addEventListener('message', function(e) {

        var data = JSON.parse(e.data);
        if (data) {
            data.number = 16;

            // 處理后再發回domain1
            window.parent.postMessage(JSON.stringify(data), 'http://www.domain1.com');
        }
    }, false);
</script>

WebSocket協議跨域

WebSocket protocol是HTML5一種新的協議。它實現了瀏覽器與服務器全雙工通信,同時允許跨域通訊,是server push技術的一種很好的實現。 原生WebSocket API使用起來不太方便,我們使用http://Socket.io,它很好地封裝了webSocket接口,提供了更簡單、靈活的接口,也對不支持webSocket的瀏覽器提供了向下兼容。

1)前端代碼:

<div>user input:<input type="text"></div>
<script src="https://cdn.bootcss.com/socket.io/2.2.0/socket.io.js"></script>
<script>
var socket = io('http://www.domain2.com:8080');

// 連接成功處理
socket.on('connect', function() {
    // 監聽服務端消息
    socket.on('message', function(msg) {
        console.log('data from server: ---> ' + msg); 
    });

    // 監聽服務端關閉
    socket.on('disconnect', function() { 
        console.log('Server socket has closed.'); 
    });
});

document.getElementsByTagName('input')[0].onblur = function() {
    socket.send(this.value);
};
</script>

2)Nodejs socket后臺:

var http = require('http');
var socket = require('socket.io');

// 啟http服務
var server = http.createServer(function(req, res) {
    res.writeHead(200, {
        'Content-type': 'text/html'
    });
    res.end();
});

server.listen('8080');
console.log('Server is running at port 8080...');

// 監聽socket連接
socket.listen(server).on('connection', function(client) {
    // 接收信息
    client.on('message', function(msg) {
        client.send('hello:' + msg);
        console.log('data from client: ---> ' + msg);
    });

    // 斷開處理
    client.on('disconnect', function() {
        console.log('Client socket has closed.'); 
    });
});

小結

以上就是幾種常見的跨域解決方案

  • jsonp(只支持get請求,支持老的IE瀏覽器)適合加載不同域名的js、css,img等靜態資源;
  • CORS(支持所有類型的HTTP請求,但瀏覽器IE10以下不支持)適合做ajax各種跨域請求;
  • Nginx代理跨域和nodejs中間件跨域原理都相似,都是搭建一個服務器,直接在服務器端請求HTTP接口,這適合前后端分離的前端項目調后端接口。
  • document.domain+iframe適合主域名相同,子域名不同的跨域請求。
  • postMessage、websocket都是HTML5新特性,兼容性不是很好,只適用于主流瀏覽器和IE10+。
責任編輯:華軒 來源: 前端南玖
相關推薦

2018-01-26 08:39:03

2018-12-12 15:50:13

2024-05-20 09:28:44

Spring客戶端瀏覽器

2020-09-17 13:33:39

開發

2018-10-10 10:23:53

數據庫RedisNoSQL

2024-12-02 14:30:20

2019-11-11 17:34:16

前端開發技術

2024-08-28 08:45:22

2023-11-17 09:38:21

2024-05-22 19:10:18

跨域Web開發

2022-02-10 08:57:45

分布式線程鎖

2010-02-24 10:55:01

WCF跨域訪問

2010-07-30 12:40:00

Flex跨域訪問

2022-03-01 09:31:06

JWTSession跨域

2021-06-25 09:04:39

Cors跨域JSONP vs CO

2011-12-08 10:39:29

JavaLucene

2017-12-19 17:54:31

前端ajax跨域cors

2022-03-11 10:01:47

開發跨域技術

2019-05-14 14:27:21

跨庫分頁分庫數據

2010-10-21 21:35:35

聯網監控多域視頻H3C
點贊
收藏

51CTO技術棧公眾號

在线xxxxx| 色撸撸在线观看| 国产无遮挡又黄又爽又色视频| 精品国产午夜| 欧美一区二区人人喊爽| 99在线免费视频观看| 国产系列电影在线播放网址| 国产一区二三区好的| 欧美亚洲国产成人精品| 久久福利免费视频| 久久亚洲黄色| 在线观看91精品国产麻豆| 国内精品视频一区二区三区| 国产免费av高清在线| 国产成人在线看| 国产精品69av| 国产在线拍揄自揄拍| 日韩久久精品网| 亚洲高清福利视频| 亚洲免费成人在线视频| www.日韩| 亚洲成人777| 亚洲一卡二卡三卡| 美州a亚洲一视本频v色道| 国产精品99久久久久久宅男| 国产精品久久久久久久电影 | 97超碰人人模人人人爽人人爱| 欧美日韩国产综合网| 中文字幕日本精品| v8888av| 亚洲一二三区视频| 宅男在线国产精品| 超碰在线公开97| 天堂中文av在线资源库| 亚洲无线码一区二区三区| 在线丝袜欧美日韩制服| 国产精品久久久久一区二区国产| 成人福利视频在线| 91精品国产一区二区三区动漫| 波多野结衣黄色| 亚洲一区二区伦理| 97视频免费看| 日韩和一区二区| 黑人一区二区| 欧美高清视频免费观看| h色网站在线观看| 日韩精品四区| 亚洲天堂男人天堂| 免费看污黄网站在线观看| av成人综合| 日韩色视频在线观看| 特黄视频免费观看| 国产999精品在线观看| 在线播放中文一区| 亚洲天堂av一区二区三区| 日本中文字幕视频一区| 欧美日本在线视频| 久久久九九九热| 精品国产一区二| 欧美zozozo| 男男一级淫片免费播放| 久久中文资源| 亚洲色无码播放| 国产又粗又黄又猛| 天天色综合色| 欧美大胆在线视频| 国产在线视频你懂的| 亚洲美女少妇无套啪啪呻吟| 欧美在线一级va免费观看| 黄色片视频免费| 青草国产精品久久久久久| 国产欧美日韩中文| 精品二区在线观看| www.欧美日韩国产在线| 久久99精品久久久久久三级| 毛片在线播放网址| 国产精品每日更新在线播放网址| 亚洲一区二三| a级在线观看| 黄色一区二区在线| www.xxx亚洲| 久久天堂久久| 日韩精品久久久久| 色撸撸在线视频| 欧美一区二区三区另类| 8090成年在线看片午夜| 瑟瑟视频在线免费观看| 国产乱子伦一区二区三区国色天香| 99高清视频有精品视频| 色中色在线视频| 国产精品家庭影院| 国产婷婷一区二区三区| 精品国产欧美日韩一区二区三区| 欧美日韩成人综合天天影院| 白丝校花扒腿让我c| 免费观看久久av| 久久久国产成人精品| 日本学生初尝黑人巨免费视频| 日日夜夜精品视频免费| 丁香五月网久久综合| 酒色婷婷桃色成人免费av网| 亚洲欧美日韩国产另类专区| 亚洲午夜精品久久久久久人妖| 99久久婷婷国产综合精品首页| 欧美成人一区二区三区片免费| 丰满圆润老女人hd| 欧美福利视频| 国产精品电影网站| 婷婷伊人综合中文字幕| 亚洲情趣在线观看| 一级在线免费视频| 视频福利一区| 欧美激情第三页| 亚洲综合视频在线播放| 久久理论电影网| 国产妇女馒头高清泬20p多| 91成人app| 亚洲视频在线观看免费| 精品成人免费视频| 国产91精品一区二区麻豆网站 | 亚洲大胆av| 成人看片人aa| 在线毛片网站| 欧美亚一区二区| aaaaa一级片| 日韩视频一区| 国产日韩精品一区观看| 哥也色在线视频| 欧美日韩黄色一区二区| 久久精品视频18| 亚洲在线一区| 国新精品乱码一区二区三区18| av网址在线| 337p亚洲精品色噜噜噜| 婷婷丁香综合网| 人禽交欧美网站| 色综合666| 日韩欧美精品电影| 亚洲图片在线综合| 欧美一区免费看| 久久久久久久一区| 国产精品人人妻人人爽人人牛| 伊甸园亚洲一区| 国内成人精品视频| 日本黄色免费视频| 午夜日韩在线电影| 91黄色免费视频| 在线亚洲一区| 日本精品一区二区三区视频 | 国产女人水真多18毛片18精品| av片在线观看永久免费| 欧美一区二区三区公司| 九九精品在线观看视频| 成人午夜又粗又硬又大| 成人免费在线网| 卡一精品卡二卡三网站乱码| 8x拔播拔播x8国产精品| 欧美日本韩国一区二区| 日本高清成人免费播放| 少妇视频在线播放| 国产综合色在线视频区| 成年在线观看视频| 国产精品对白久久久久粗| 97超级碰碰人国产在线观看| 嫩草研究院在线| 欧美日韩国产免费| 1024手机在线视频| 成人av第一页| 国产一级片黄色| 91av精品| 国产一区二区黄色| 性感美女一区二区在线观看| 色视频www在线播放国产成人| 国产毛片毛片毛片毛片毛片| 亚洲国产婷婷综合在线精品| 国产一级二级在线观看| 丝袜美腿亚洲色图| 99亚洲精品视频| 久久av国产紧身裤| 国产精品美女在线观看| 一区二区三区伦理| 亚洲精选在线观看| 国产精品一区二区免费视频 | 中文字幕激情视频| 亚洲美女在线一区| 黄色性生活一级片| 久久国产剧场电影| 拔插拔插海外华人免费| 欧美日韩国产传媒| 国产精品加勒比| 另类中文字幕国产精品| 精品少妇v888av| 美女毛片在线看| 精品久久国产老人久久综合| 无码人妻精品一区二区50| 亚洲欧美日韩精品久久久久| av网站免费在线播放| 国产精品自拍毛片| 中文字幕欧美人妻精品一区| 伊人成人在线| 一区二区三区四区欧美| 亚洲免费福利一区| 99视频国产精品免费观看| 春暖花开亚洲一区二区三区| 欧美极品少妇xxxxx| a视频网址在线观看| 亚洲国产中文字幕在线观看| 一级特黄aaa| 日韩欧美成人精品| 久久久久无码精品国产| 国产精品乱码一区二三区小蝌蚪| 好男人香蕉影院| 国产米奇在线777精品观看| 老头吃奶性行交视频| 亚洲欧洲视频| 国产精品视频一二三四区| 青青草97国产精品麻豆| 欧美不卡在线一区二区三区| silk一区二区三区精品视频 | 2019av中文字幕| 人妖欧美1区| www.亚洲一区| 大胆av不用播放器在线播放| 精品香蕉在线观看视频一| 亚洲国产成人一区二区| 91精品综合久久久久久| 中文字幕一区二区三区四区免费看| 狠狠综合久久av一区二区小说| 欧美日韩精品一区二区三区视频播放| 国产精品乱人伦| youjizz亚洲女人| 国产日产精品一区| 免费在线观看成年人视频| 91网址在线看| 日b视频在线观看| 成人精品亚洲人成在线| xxxxwww一片| 大胆亚洲人体视频| 中国xxxx性xxxx产国| 国产成人精品综合在线观看| 国产裸体视频网站| 国产精品系列在线播放| 日本黄色www| 国产成人a级片| 亚洲免费观看在线| 成人黄色777网| 久久久久国产精品无码免费看| 99久久精品一区二区| 免费的av网站| 久久综合成人精品亚洲另类欧美| 亚洲天堂网一区二区| 久久久久9999亚洲精品| jizz中文字幕| 国产精品灌醉下药二区| 免费看特级毛片| 一区二区免费视频| 国产无遮挡aaa片爽爽| 天天做天天摸天天爽国产一区| 久久黄色精品视频| 在线观看网站黄不卡| 中文字幕av网站| 日韩一区二区三区精品视频| 成人乱码一区二区三区| 亚洲精品久久久久久久久久久久久| 台湾av在线二三区观看| 中国china体内裑精亚洲片| 麻豆传媒在线免费| 欧美激情欧美激情在线五月| 涩涩视频在线免费看| 国产精品久久久久久久久男| 四虎国产精品免费久久5151| 粉嫩精品一区二区三区在线观看 | 日韩精品福利在线| 国产在线一二| 久久人人爽人人爽爽久久| 欧美理论片在线播放| 欧美在线激情视频| 久久亚洲人体| 国产伦精品一区二区三| 精品日本12videosex| 九九久久九九久久| 国产精品婷婷| 黄色一级片免费播放| youjizz国产精品| 国产精品酒店视频| 亚洲制服丝袜av| 欧美人一级淫片a免费播放| 91精选在线观看| 免费在线视频你懂得| 欧美巨乳美女视频| 性感美女一区二区在线观看| 99久久久久国产精品免费 | 日日噜噜噜夜夜爽爽| 一区二区三区福利| 日本一二区免费| 99热这里都是精品| 久久国产高清视频| 日韩欧美第一页| 精品人妻无码一区二区色欲产成人 | 国内精品美女av在线播放| 播放一区二区| 精选一区二区三区四区五区| 999久久久91| 妺妺窝人体色www在线小说| 狠狠色丁香久久婷婷综合_中| 色呦呦一区二区| 亚洲综合视频在线| 亚洲无码久久久久久久| 亚洲欧美日韩一区二区在线 | 亚洲综合色网站| 正在播放木下凛凛xv99| 亚洲国产成人av在线| 黄网页在线观看| 国产精品美女久久久免费 | 国产一区二区免费在线| 91中文字幕永久在线| 亚洲成人高清在线| 99久久久国产精品无码网爆| 国产一区二区成人| 一区二区精品伦理...| 国产91一区二区三区| 亚洲成av人片乱码色午夜| 爱情岛论坛成人| 久久女同精品一区二区| 五月天婷婷网站| 日韩免费成人网| 超碰免费公开在线| 91精品久久久久久久久久入口| 精品日韩欧美一区| 欧美三级午夜理伦三级| 久久综合九色综合欧美就去吻| 久久久久免费看| 欧美videofree性高清杂交| 国产在线一区二区视频| 91免费人成网站在线观看18| 久久影院100000精品| 91国产精品视频在线观看| 国产喂奶挤奶一区二区三区 | 91精品久久久久久久91蜜桃| 自拍视频在线免费观看| 国产精品一区二区久久| 成人午夜av| 色噜噜狠狠永久免费| 国产精品久久久久久妇女6080 | 精品成人一区二区| 免费影视亚洲| 国产乱码精品一区二区三区不卡| 亚洲先锋成人| 中文字幕一区二区三区乱码不卡| 亚洲国产精品人人做人人爽| 欧美熟妇乱码在线一区| 性视频1819p久久| 日韩大胆成人| 色综合手机在线| 亚洲丝袜制服诱惑| www国产一区| 77777亚洲午夜久久多人| 网友自拍一区| 9久久婷婷国产综合精品性色| 中文字幕精品综合| 国产精品主播一区二区| 久久99精品久久久久久青青91 | 国精产品一区一区三区mba桃花 | 成人av毛片| 成人性生交xxxxx网站| 欧美激情四色| 性欧美丰满熟妇xxxx性久久久| 色综合天天综合网天天狠天天| eeuss影院在线播放| 91美女片黄在线观| 亚洲美洲欧洲综合国产一区| 少妇久久久久久久久久| 欧美精品丝袜久久久中文字幕| 欧美xxxx免费虐| 欧美精品在线一区| 精品一区二区av| 亚洲视频免费播放| 在线电影中文日韩| 亚洲视频国产| 成年人小视频网站| 亚洲精品国产精华液| 青青草免费在线视频| 成人性生交大片免费看视频直播 | 国精产品一区一区三区有限在线| 亚洲涩涩av| 久久精品一二三四| 日韩欧美精品在线观看| 激情在线小视频| 久久精精品视频| 国模娜娜一区二区三区| 国产剧情在线视频| 欧美成人精品一区二区| 久久99青青| 久久久久中文字幕亚洲精品| 色婷婷久久综合| 色爱综合区网| 亚洲欧美日韩不卡一区二区三区| jlzzjlzz亚洲日本少妇| 一区二区三区免费观看视频| 91国内在线视频|